..
framework
git
workflow
jj-config.md
jj-init-bare.md
jj-init-colocate.md
rad-auth-errors.md
rad-auth.md
rad-block.md
rad-checkout-repo-config-linux.md
rad-checkout-repo-config-macos.md
rad-checkout.md
rad-clean.md
rad-clone-all.md
rad-clone-bare.md
rad-clone-connect.md
rad-clone-directory.md
rad-clone-partial-fail.md
rad-clone-scope.md
rad-clone-unknown.md
rad-clone.md
rad-cob-log.md
rad-cob-migrate.md
rad-cob-multiset
rad-cob-multiset.md
rad-cob-operations.md
rad-cob-show.md
rad-cob-update-identity.md
rad-cob-update.md
rad-config.md
rad-diff.md
rad-fetch.md
rad-fork.md
rad-help.md
rad-id-collaboration.md
rad-id-conflict.md
rad-id-multi-delegate.md
rad-id-private.md
rad-id-threshold-soft-fork.md
rad-id-threshold.md
rad-id-unauthorized-delegate.md
rad-id-unknown-field.md
rad-id-update-delete-field.md
rad-id.md
rad-inbox.md
rad-init-detached-head.md
rad-init-existing-bare.md
rad-init-existing.md
rad-init-no-git.md
rad-init-no-seed.md
rad-init-private-clone-seed.md
rad-init-private-clone.md
rad-init-private-no-seed.md
rad-init-private-seed.md
rad-init-private.md
rad-init-sync-not-connected.md
rad-init-sync-preferred.md
rad-init-sync-timeout.md
rad-init-sync.md
rad-init-with-existing-remote.md
rad-init.md
rad-inspect-noauth.md
rad-inspect.md
rad-issue-list.md
rad-issue.md
rad-key-mismatch.md
rad-merge-after-update.md
rad-merge-no-ff.md
rad-merge-via-push.md
rad-node.md
rad-patch-ahead-behind.md
rad-patch-change-base.md
rad-patch-checkout-force.md
rad-patch-checkout-revision.md
rad-patch-checkout.md
rad-patch-delete.md
rad-patch-detached-head.md
rad-patch-diff.md
rad-patch-draft.md
rad-patch-edit.md
rad-patch-fetch-1.md
rad-patch-fetch-2.md
rad-patch-jj.md
rad-patch-merge-draft.md
rad-patch-open-explore.md
rad-patch-pull-update.md
rad-patch-revert-merge.md
rad-patch-update.md
rad-patch-via-push.md
rad-patch.md
rad-publish.md
rad-push-and-pull-patches.md
rad-remote.md
rad-review-by-hunk.md
rad-seed-and-follow.md
rad-seed-many.md
rad-seed-policy-allow-no-scope.md
rad-seed-scope.md
rad-self.md
rad-sync-without-node.md
rad-sync.md
rad-unseed-many.md
rad-unseed.md
rad-warn-old-nodes.md
rad-watch.md
Let’s test that merge commits are handled properly in the context of patches. First, let’s create a patch.
$ git checkout -b feature/1 -q
$ git commit --allow-empty -q -m "First change"
$ git push rad HEAD:refs/patches
✓ Patch 696ec5508494692899337afe6713fe1796d0315c opened
To rad://z42hL2jL4XNk6K8oHQaSWfMgCL7ji/z6MknSLrJoTcukLrE435hVNQT4JUhbvWLX4kUzqkEStBU8Vi
* [new reference] HEAD -> refs/patches
Then let’s update the master branch so that merging the patch would create a merge commit.
$ git checkout master -q
$ git commit --amend --allow-empty -q -m "Concurrent change"
$ git rev-parse HEAD
f65977beef04fcc5cd5395feed7ff4c37cd90a2f
Now let’s merge the patch, creating a merge commit. We can see that one of the parents is the patch head.
$ git merge feature/1 -q --no-ff
$ git show --format=raw HEAD
commit 737a10cfa29111afeb0d43cf3545cee386b939ec
tree b4eecafa9be2f2006ce1b709d6857b07069b4608
parent f65977beef04fcc5cd5395feed7ff4c37cd90a2f
parent 20aa5dde6210796c3a2f04079b42316a31d02689
author radicle <radicle@localhost> 1671125284 +0000
committer radicle <radicle@localhost> 1671125284 +0000
Merge branch 'feature/1'
Finally, we push master and expect the patch to be merged.
$ git push rad master
✓ Patch 696ec5508494692899337afe6713fe1796d0315c merged
✓ Canonical reference refs/heads/master updated to target commit 737a10cfa29111afeb0d43cf3545cee386b939ec
To rad://z42hL2jL4XNk6K8oHQaSWfMgCL7ji/z6MknSLrJoTcukLrE435hVNQT4JUhbvWLX4kUzqkEStBU8Vi
f2de534..737a10c master -> master
Let's test that merge commits are handled properly in the context of patches.
First, let's create a patch.
``` (stderr) RAD_SOCKET=/dev/null
$ git checkout -b feature/1 -q
$ git commit --allow-empty -q -m "First change"
$ git push rad HEAD:refs/patches
✓ Patch 696ec5508494692899337afe6713fe1796d0315c opened
To rad://z42hL2jL4XNk6K8oHQaSWfMgCL7ji/z6MknSLrJoTcukLrE435hVNQT4JUhbvWLX4kUzqkEStBU8Vi
* [new reference] HEAD -> refs/patches
```
Then let's update the master branch so that merging the patch would create a merge commit.
```
$ git checkout master -q
$ git commit --amend --allow-empty -q -m "Concurrent change"
$ git rev-parse HEAD
f65977beef04fcc5cd5395feed7ff4c37cd90a2f
```
Now let's merge the patch, creating a merge commit. We can see that one of the
parents is the patch head.
```
$ git merge feature/1 -q --no-ff
$ git show --format=raw HEAD
commit 737a10cfa29111afeb0d43cf3545cee386b939ec
tree b4eecafa9be2f2006ce1b709d6857b07069b4608
parent f65977beef04fcc5cd5395feed7ff4c37cd90a2f
parent 20aa5dde6210796c3a2f04079b42316a31d02689
author radicle <radicle@localhost> 1671125284 +0000
committer radicle <radicle@localhost> 1671125284 +0000
Merge branch 'feature/1'
```
Finally, we push master and expect the patch to be merged.
``` (stderr) RAD_SOCKET=/dev/null
$ git push rad master
✓ Patch 696ec5508494692899337afe6713fe1796d0315c merged
✓ Canonical reference refs/heads/master updated to target commit 737a10cfa29111afeb0d43cf3545cee386b939ec
To rad://z42hL2jL4XNk6K8oHQaSWfMgCL7ji/z6MknSLrJoTcukLrE435hVNQT4JUhbvWLX4kUzqkEStBU8Vi
f2de534..737a10c master -> master
```