test-merge-criss-cross.t
781 lines
| 24.6 KiB
| text/troff
|
Tads3Lexer
/ tests / test-merge-criss-cross.t
Pulkit Goyal
|
r46153 | #testcases old newfilenode | ||
#if newfilenode | ||||
Enable the config option | ||||
------------------------ | ||||
$ cat >> $HGRCPATH <<EOF | ||||
> [experimental] | ||||
> merge-track-salvaged = True | ||||
> EOF | ||||
#endif | ||||
Mads Kiilerich
|
r20636 | Criss cross merging | ||
$ hg init criss-cross | ||||
$ cd criss-cross | ||||
$ echo '0 base' > f1 | ||||
$ echo '0 base' > f2 | ||||
$ hg ci -Aqm '0 base' | ||||
$ echo '1 first change' > f1 | ||||
$ hg ci -m '1 first change f1' | ||||
$ hg up -qr0 | ||||
$ echo '2 first change' > f2 | ||||
$ hg ci -qm '2 first change f2' | ||||
$ hg merge -qr 1 | ||||
$ hg ci -m '3 merge' | ||||
$ hg up -qr2 | ||||
$ hg merge -qr1 | ||||
$ hg ci -qm '4 merge' | ||||
$ echo '5 second change' > f1 | ||||
$ hg ci -m '5 second change f1' | ||||
Mads Kiilerich
|
r21125 | $ hg up -r3 | ||
Martin von Zweigbergk
|
r42330 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Mads Kiilerich
|
r20636 | $ echo '6 second change' > f2 | ||
$ hg ci -m '6 second change f2' | ||||
$ hg log -G | ||||
Martin von Zweigbergk
|
r42330 | @ changeset: 6:3b08d01b0ab5 | ||
Mads Kiilerich
|
r20636 | | tag: tip | ||
Martin von Zweigbergk
|
r42330 | | parent: 3:cf89f02107e5 | ||
Mads Kiilerich
|
r20636 | | user: test | ||
| date: Thu Jan 01 00:00:00 1970 +0000 | ||||
| summary: 6 second change f2 | ||||
| | ||||
Martin von Zweigbergk
|
r42330 | | o changeset: 5:adfe50279922 | ||
Mads Kiilerich
|
r20636 | | | user: test | ||
| | date: Thu Jan 01 00:00:00 1970 +0000 | ||||
| | summary: 5 second change f1 | ||||
| | | ||||
Martin von Zweigbergk
|
r42330 | | o changeset: 4:7d3e55501ae6 | ||
| |\ parent: 2:40663881a6dd | ||||
Mads Kiilerich
|
r20636 | | | | parent: 1:0f6b37dbe527 | ||
| | | user: test | ||||
| | | date: Thu Jan 01 00:00:00 1970 +0000 | ||||
| | | summary: 4 merge | ||||
| | | | ||||
Martin von Zweigbergk
|
r42330 | o---+ changeset: 3:cf89f02107e5 | ||
| | | parent: 2:40663881a6dd | ||||
Mads Kiilerich
|
r20636 | |/ / parent: 1:0f6b37dbe527 | ||
| | user: test | ||||
| | date: Thu Jan 01 00:00:00 1970 +0000 | ||||
| | summary: 3 merge | ||||
| | | ||||
Martin von Zweigbergk
|
r42330 | | o changeset: 2:40663881a6dd | ||
Mads Kiilerich
|
r20636 | | | parent: 0:40494bf2444c | ||
| | user: test | ||||
| | date: Thu Jan 01 00:00:00 1970 +0000 | ||||
| | summary: 2 first change f2 | ||||
| | | ||||
o | changeset: 1:0f6b37dbe527 | ||||
|/ user: test | ||||
| date: Thu Jan 01 00:00:00 1970 +0000 | ||||
| summary: 1 first change f1 | ||||
| | ||||
o changeset: 0:40494bf2444c | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: 0 base | ||||
Mads Kiilerich
|
r22672 | $ hg merge -v --debug --tool internal:dump 5 --config merge.preferancestor='!' | ||
Martin von Zweigbergk
|
r42330 | note: using 0f6b37dbe527 as ancestor of 3b08d01b0ab5 and adfe50279922 | ||
alternatively, use --config merge.preferancestor=40663881a6dd | ||||
Mads Kiilerich
|
r20636 | resolving manifests | ||
branchmerge: True, force: False, partial: False | ||||
Martin von Zweigbergk
|
r42330 | ancestor: 0f6b37dbe527, local: 3b08d01b0ab5+, remote: adfe50279922 | ||
Mads Kiilerich
|
r20636 | f1: remote is newer -> g | ||
getting f1 | ||||
Pulkit Goyal
|
r46060 | preserving f2 for resolve of f2 | ||
Siddharth Agarwal
|
r26618 | f2: versions differ -> m (premerge) | ||
Siddharth Agarwal
|
r27161 | picked tool ':dump' for f2 (binary False symlink False changedelete False) | ||
Mads Kiilerich
|
r20636 | merging f2 | ||
Martin von Zweigbergk
|
r42330 | my f2@3b08d01b0ab5+ other f2@adfe50279922 ancestor f2@0f6b37dbe527 | ||
Siddharth Agarwal
|
r26618 | f2: versions differ -> m (merge) | ||
Siddharth Agarwal
|
r27161 | picked tool ':dump' for f2 (binary False symlink False changedelete False) | ||
Martin von Zweigbergk
|
r42330 | my f2@3b08d01b0ab5+ other f2@adfe50279922 ancestor f2@0f6b37dbe527 | ||
1 files updated, 0 files merged, 0 files removed, 1 files unresolved | ||||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Mads Kiilerich
|
r20636 | [1] | ||
Martin von Zweigbergk
|
r42330 | $ f --dump * | ||
Mads Kiilerich
|
r30855 | f1: | ||
>>> | ||||
Mads Kiilerich
|
r20636 | 5 second change | ||
Mads Kiilerich
|
r30855 | <<< | ||
f2: | ||||
>>> | ||||
Mads Kiilerich
|
r20636 | 6 second change | ||
Mads Kiilerich
|
r30855 | <<< | ||
f2.base: | ||||
>>> | ||||
Mads Kiilerich
|
r20636 | 0 base | ||
Mads Kiilerich
|
r30855 | <<< | ||
f2.local: | ||||
>>> | ||||
Mads Kiilerich
|
r20636 | 6 second change | ||
Mads Kiilerich
|
r30855 | <<< | ||
f2.orig: | ||||
>>> | ||||
Mads Kiilerich
|
r20636 | 6 second change | ||
Mads Kiilerich
|
r30855 | <<< | ||
f2.other: | ||||
>>> | ||||
Mads Kiilerich
|
r20636 | 2 first change | ||
Mads Kiilerich
|
r30855 | <<< | ||
Mads Kiilerich
|
r20636 | |||
Mads Kiilerich
|
r21126 | $ hg up -qC . | ||
$ hg merge -v --tool internal:dump 5 --config merge.preferancestor="null 40663881 3b08d" | ||||
Martin von Zweigbergk
|
r42330 | note: using 40663881a6dd as ancestor of 3b08d01b0ab5 and adfe50279922 | ||
alternatively, use --config merge.preferancestor=0f6b37dbe527 | ||||
Mads Kiilerich
|
r21126 | resolving manifests | ||
Martin von Zweigbergk
|
r42330 | merging f1 | ||
0 files updated, 0 files merged, 0 files removed, 1 files unresolved | ||||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Mads Kiilerich
|
r21126 | [1] | ||
Mads Kiilerich
|
r21128 | Redo merge with merge.preferancestor="*" to enable bid merge | ||
$ rm f* | ||||
$ hg up -qC . | ||||
$ hg merge -v --debug --tool internal:dump 5 --config merge.preferancestor="*" | ||||
Martin von Zweigbergk
|
r42330 | note: merging 3b08d01b0ab5+ and adfe50279922 using bids from ancestors 0f6b37dbe527 and 40663881a6dd | ||
Mads Kiilerich
|
r21128 | |||
calculating bids for ancestor 0f6b37dbe527 | ||||
resolving manifests | ||||
branchmerge: True, force: False, partial: False | ||||
Martin von Zweigbergk
|
r42330 | ancestor: 0f6b37dbe527, local: 3b08d01b0ab5+, remote: adfe50279922 | ||
Mads Kiilerich
|
r21269 | f1: remote is newer -> g | ||
f2: versions differ -> m | ||||
Mads Kiilerich
|
r21128 | |||
Martin von Zweigbergk
|
r42330 | calculating bids for ancestor 40663881a6dd | ||
Mads Kiilerich
|
r21128 | resolving manifests | ||
branchmerge: True, force: False, partial: False | ||||
Martin von Zweigbergk
|
r42330 | ancestor: 40663881a6dd, local: 3b08d01b0ab5+, remote: adfe50279922 | ||
Martin von Zweigbergk
|
r23638 | f1: versions differ -> m | ||
Martin von Zweigbergk
|
r23482 | f2: remote unchanged -> k | ||
Mads Kiilerich
|
r21128 | |||
Pulkit Goyal
|
r46018 | auction for merging merge bids (2 ancestors) | ||
Pulkit Goyal
|
r46031 | list of bids for f1: | ||
remote is newer -> g | ||||
versions differ -> m | ||||
Mads Kiilerich
|
r21128 | f1: picking 'get' action | ||
Pulkit Goyal
|
r46031 | list of bids for f2: | ||
remote unchanged -> k | ||||
versions differ -> m | ||||
Mads Kiilerich
|
r21128 | f2: picking 'keep' action | ||
end of auction | ||||
f1: remote is newer -> g | ||||
getting f1 | ||||
Martin von Zweigbergk
|
r23482 | f2: remote unchanged -> k | ||
Martin von Zweigbergk
|
r42330 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Mads Kiilerich
|
r21128 | (branch merge, don't forget to commit) | ||
Martin von Zweigbergk
|
r42330 | $ f --dump * | ||
Mads Kiilerich
|
r30855 | f1: | ||
>>> | ||||
Mads Kiilerich
|
r21128 | 5 second change | ||
Mads Kiilerich
|
r30855 | <<< | ||
f2: | ||||
>>> | ||||
Mads Kiilerich
|
r21128 | 6 second change | ||
Mads Kiilerich
|
r30855 | <<< | ||
Mads Kiilerich
|
r21128 | |||
The other way around: | ||||
$ hg up -C -r5 | ||||
Martin von Zweigbergk
|
r42330 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Mads Kiilerich
|
r21128 | $ hg merge -v --debug --config merge.preferancestor="*" | ||
Martin von Zweigbergk
|
r42330 | note: merging adfe50279922+ and 3b08d01b0ab5 using bids from ancestors 0f6b37dbe527 and 40663881a6dd | ||
Mads Kiilerich
|
r21128 | |||
calculating bids for ancestor 0f6b37dbe527 | ||||
resolving manifests | ||||
branchmerge: True, force: False, partial: False | ||||
Martin von Zweigbergk
|
r42330 | ancestor: 0f6b37dbe527, local: adfe50279922+, remote: 3b08d01b0ab5 | ||
Martin von Zweigbergk
|
r23482 | f1: remote unchanged -> k | ||
Mads Kiilerich
|
r21269 | f2: versions differ -> m | ||
Mads Kiilerich
|
r21128 | |||
Martin von Zweigbergk
|
r42330 | calculating bids for ancestor 40663881a6dd | ||
Mads Kiilerich
|
r21128 | resolving manifests | ||
branchmerge: True, force: False, partial: False | ||||
Martin von Zweigbergk
|
r42330 | ancestor: 40663881a6dd, local: adfe50279922+, remote: 3b08d01b0ab5 | ||
Martin von Zweigbergk
|
r23638 | f1: versions differ -> m | ||
Mads Kiilerich
|
r21391 | f2: remote is newer -> g | ||
Mads Kiilerich
|
r21128 | |||
Pulkit Goyal
|
r46018 | auction for merging merge bids (2 ancestors) | ||
Pulkit Goyal
|
r46031 | list of bids for f1: | ||
remote unchanged -> k | ||||
versions differ -> m | ||||
Mads Kiilerich
|
r21128 | f1: picking 'keep' action | ||
Pulkit Goyal
|
r46031 | list of bids for f2: | ||
remote is newer -> g | ||||
versions differ -> m | ||||
Mads Kiilerich
|
r21128 | f2: picking 'get' action | ||
end of auction | ||||
Mads Kiilerich
|
r21389 | f2: remote is newer -> g | ||
Mads Kiilerich
|
r21128 | getting f2 | ||
Martin von Zweigbergk
|
r23482 | f1: remote unchanged -> k | ||
Martin von Zweigbergk
|
r42330 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Mads Kiilerich
|
r21128 | (branch merge, don't forget to commit) | ||
Martin von Zweigbergk
|
r42330 | $ f --dump * | ||
Mads Kiilerich
|
r30855 | f1: | ||
>>> | ||||
Mads Kiilerich
|
r21128 | 5 second change | ||
Mads Kiilerich
|
r30855 | <<< | ||
f2: | ||||
>>> | ||||
Mads Kiilerich
|
r21128 | 6 second change | ||
Mads Kiilerich
|
r30855 | <<< | ||
Mads Kiilerich
|
r21128 | |||
Verify how the output looks and and how verbose it is: | ||||
$ hg up -qC | ||||
Mads Kiilerich
|
r22672 | $ hg merge | ||
Martin von Zweigbergk
|
r42330 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Mads Kiilerich
|
r21128 | (branch merge, don't forget to commit) | ||
Pierre-Yves David
|
r28065 | $ hg up -qC tip | ||
Mads Kiilerich
|
r22672 | $ hg merge -v | ||
Martin von Zweigbergk
|
r42330 | note: merging 3b08d01b0ab5+ and adfe50279922 using bids from ancestors 0f6b37dbe527 and 40663881a6dd | ||
Mads Kiilerich
|
r21128 | |||
calculating bids for ancestor 0f6b37dbe527 | ||||
resolving manifests | ||||
Martin von Zweigbergk
|
r42330 | calculating bids for ancestor 40663881a6dd | ||
Mads Kiilerich
|
r21128 | resolving manifests | ||
Pulkit Goyal
|
r46018 | auction for merging merge bids (2 ancestors) | ||
Mads Kiilerich
|
r21128 | f1: picking 'get' action | ||
f2: picking 'keep' action | ||||
end of auction | ||||
getting f1 | ||||
Martin von Zweigbergk
|
r42330 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Mads Kiilerich
|
r21128 | (branch merge, don't forget to commit) | ||
$ hg up -qC | ||||
$ hg merge -v --debug --config merge.preferancestor="*" | ||||
Martin von Zweigbergk
|
r42330 | note: merging 3b08d01b0ab5+ and adfe50279922 using bids from ancestors 0f6b37dbe527 and 40663881a6dd | ||
Mads Kiilerich
|
r21128 | |||
calculating bids for ancestor 0f6b37dbe527 | ||||
resolving manifests | ||||
branchmerge: True, force: False, partial: False | ||||
Martin von Zweigbergk
|
r42330 | ancestor: 0f6b37dbe527, local: 3b08d01b0ab5+, remote: adfe50279922 | ||
Mads Kiilerich
|
r21269 | f1: remote is newer -> g | ||
f2: versions differ -> m | ||||
Mads Kiilerich
|
r21128 | |||
Martin von Zweigbergk
|
r42330 | calculating bids for ancestor 40663881a6dd | ||
Mads Kiilerich
|
r21128 | resolving manifests | ||
branchmerge: True, force: False, partial: False | ||||
Martin von Zweigbergk
|
r42330 | ancestor: 40663881a6dd, local: 3b08d01b0ab5+, remote: adfe50279922 | ||
Martin von Zweigbergk
|
r23638 | f1: versions differ -> m | ||
Martin von Zweigbergk
|
r23482 | f2: remote unchanged -> k | ||
Mads Kiilerich
|
r21128 | |||
Pulkit Goyal
|
r46018 | auction for merging merge bids (2 ancestors) | ||
Pulkit Goyal
|
r46031 | list of bids for f1: | ||
remote is newer -> g | ||||
versions differ -> m | ||||
Mads Kiilerich
|
r21128 | f1: picking 'get' action | ||
Pulkit Goyal
|
r46031 | list of bids for f2: | ||
remote unchanged -> k | ||||
versions differ -> m | ||||
Mads Kiilerich
|
r21128 | f2: picking 'keep' action | ||
end of auction | ||||
f1: remote is newer -> g | ||||
getting f1 | ||||
Martin von Zweigbergk
|
r23482 | f2: remote unchanged -> k | ||
Martin von Zweigbergk
|
r42330 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Mads Kiilerich
|
r21128 | (branch merge, don't forget to commit) | ||
Sean Farley
|
r38644 | Test the greatest common ancestor returning multiple changesets | ||
$ hg log -r 'heads(commonancestors(head()))' | ||||
changeset: 1:0f6b37dbe527 | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: 1 first change f1 | ||||
Martin von Zweigbergk
|
r42330 | changeset: 2:40663881a6dd | ||
Sean Farley
|
r38644 | parent: 0:40494bf2444c | ||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: 2 first change f2 | ||||
Mads Kiilerich
|
r20636 | $ cd .. | ||
Mads Kiilerich
|
r21169 | |||
http://stackoverflow.com/questions/9350005/how-do-i-specify-a-merge-base-to-use-in-a-hg-merge/9430810 | ||||
$ hg init ancestor-merging | ||||
$ cd ancestor-merging | ||||
$ echo a > x | ||||
$ hg commit -A -m a x | ||||
$ hg update -q 0 | ||||
$ echo b >> x | ||||
$ hg commit -m b | ||||
$ hg update -q 0 | ||||
$ echo c >> x | ||||
$ hg commit -qm c | ||||
$ hg update -q 1 | ||||
$ hg merge -q --tool internal:local 2 | ||||
$ echo c >> x | ||||
$ hg commit -m bc | ||||
$ hg update -q 2 | ||||
$ hg merge -q --tool internal:local 1 | ||||
$ echo b >> x | ||||
$ hg commit -qm cb | ||||
Mads Kiilerich
|
r22672 | $ hg merge --config merge.preferancestor='!' | ||
Mads Kiilerich
|
r21169 | note: using 70008a2163f6 as ancestor of 0d355fdef312 and 4b8b546a3eef | ||
alternatively, use --config merge.preferancestor=b211bbc6eb3c | ||||
merging x | ||||
0 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ cat x | ||||
a | ||||
c | ||||
b | ||||
c | ||||
$ hg up -qC . | ||||
$ hg merge --config merge.preferancestor=b211bbc6eb3c | ||||
note: using b211bbc6eb3c as ancestor of 0d355fdef312 and 4b8b546a3eef | ||||
alternatively, use --config merge.preferancestor=70008a2163f6 | ||||
merging x | ||||
0 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ cat x | ||||
a | ||||
b | ||||
c | ||||
b | ||||
$ hg up -qC . | ||||
$ hg merge -v --config merge.preferancestor="*" | ||||
Mads Kiilerich
|
r21171 | note: merging 0d355fdef312+ and 4b8b546a3eef using bids from ancestors 70008a2163f6 and b211bbc6eb3c | ||
Mads Kiilerich
|
r21169 | |||
calculating bids for ancestor 70008a2163f6 | ||||
resolving manifests | ||||
calculating bids for ancestor b211bbc6eb3c | ||||
resolving manifests | ||||
Pulkit Goyal
|
r46018 | auction for merging merge bids (2 ancestors) | ||
Mads Kiilerich
|
r21172 | x: multiple bids for merge action: | ||
versions differ -> m | ||||
versions differ -> m | ||||
Mads Kiilerich
|
r21170 | x: ambiguous merge - picked m action | ||
Mads Kiilerich
|
r21169 | end of auction | ||
merging x | ||||
0 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ cat x | ||||
a | ||||
c | ||||
b | ||||
c | ||||
Mads Kiilerich
|
r22180 | Verify that the old context ancestor works with / despite preferancestor: | ||
$ hg log -r 'ancestor(head())' --config merge.preferancestor=1 -T '{rev}\n' | ||||
1 | ||||
$ hg log -r 'ancestor(head())' --config merge.preferancestor=2 -T '{rev}\n' | ||||
2 | ||||
$ hg log -r 'ancestor(head())' --config merge.preferancestor=3 -T '{rev}\n' | ||||
1 | ||||
Mads Kiilerich
|
r22671 | $ hg log -r 'ancestor(head())' --config merge.preferancestor='1337 * - 2' -T '{rev}\n' | ||
2 | ||||
Mads Kiilerich
|
r22180 | |||
Mads Kiilerich
|
r21169 | $ cd .. | ||
Martin von Zweigbergk
|
r42330 | |||
$ hg init issue5020 | ||||
$ cd issue5020 | ||||
$ echo a > noop | ||||
$ hg ci -qAm initial | ||||
$ echo b > noop | ||||
$ hg ci -qAm 'uninteresting change' | ||||
$ hg up -q 0 | ||||
$ mkdir d1 | ||||
$ echo a > d1/a | ||||
$ echo b > d1/b | ||||
$ hg ci -qAm 'add d1/a and d1/b' | ||||
$ hg merge -q 1 | ||||
$ hg rm d1/a | ||||
$ hg mv -q d1 d2 | ||||
$ hg ci -qm 'merge while removing d1/a and moving d1/b to d2/b' | ||||
$ hg up -q 1 | ||||
$ hg merge -q 2 | ||||
$ hg ci -qm 'merge (no changes while merging)' | ||||
$ hg log -G -T '{rev}:{node|short} {desc}' | ||||
@ 4:c0ef19750a22 merge (no changes while merging) | ||||
|\ | ||||
+---o 3:6ca01f7342b9 merge while removing d1/a and moving d1/b to d2/b | ||||
| |/ | ||||
| o 2:154e6000f54e add d1/a and d1/b | ||||
| | | ||||
o | 1:11b5b303e36c uninteresting change | ||||
|/ | ||||
o 0:7b54db1ebf33 initial | ||||
$ hg merge 3 --debug | ||||
note: merging c0ef19750a22+ and 6ca01f7342b9 using bids from ancestors 11b5b303e36c and 154e6000f54e | ||||
calculating bids for ancestor 11b5b303e36c | ||||
resolving manifests | ||||
branchmerge: True, force: False, partial: False | ||||
ancestor: 11b5b303e36c, local: c0ef19750a22+, remote: 6ca01f7342b9 | ||||
Pulkit Goyal
|
r46095 | d1/a: ancestor missing, remote missing -> kn | ||
d1/b: ancestor missing, remote missing -> kn | ||||
Martin von Zweigbergk
|
r42338 | d2/b: remote created -> g | ||
Martin von Zweigbergk
|
r42330 | |||
calculating bids for ancestor 154e6000f54e | ||||
unmatched files in other: | ||||
d2/b | ||||
all copies found (* = to merge, ! = divergent, % = renamed and deleted): | ||||
Martin von Zweigbergk
|
r44679 | on remote side: | ||
src: 'd1/b' -> dst: 'd2/b' | ||||
Martin von Zweigbergk
|
r42330 | checking for directory renames | ||
discovered dir src: 'd1/' -> dst: 'd2/' | ||||
resolving manifests | ||||
branchmerge: True, force: False, partial: False | ||||
ancestor: 154e6000f54e, local: c0ef19750a22+, remote: 6ca01f7342b9 | ||||
d1/a: other deleted -> r | ||||
d1/b: other deleted -> r | ||||
d2/b: remote created -> g | ||||
Pulkit Goyal
|
r46018 | auction for merging merge bids (2 ancestors) | ||
Pulkit Goyal
|
r46031 | list of bids for d1/a: | ||
Pulkit Goyal
|
r46095 | ancestor missing, remote missing -> kn | ||
Pulkit Goyal
|
r46031 | other deleted -> r | ||
Pulkit Goyal
|
r46095 | d1/a: picking 'keep new' action | ||
Pulkit Goyal
|
r46031 | list of bids for d1/b: | ||
Pulkit Goyal
|
r46095 | ancestor missing, remote missing -> kn | ||
Pulkit Goyal
|
r46031 | other deleted -> r | ||
Pulkit Goyal
|
r46095 | d1/b: picking 'keep new' action | ||
Pulkit Goyal
|
r46031 | list of bids for d2/b: | ||
remote created -> g | ||||
remote created -> g | ||||
Martin von Zweigbergk
|
r42338 | d2/b: consensus for g | ||
Martin von Zweigbergk
|
r42330 | end of auction | ||
d2/b: remote created -> g | ||||
getting d2/b | ||||
Pulkit Goyal
|
r46095 | d1/a: ancestor missing, remote missing -> kn | ||
d1/b: ancestor missing, remote missing -> kn | ||||
Pulkit Goyal
|
r46041 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Martin von Zweigbergk
|
r42330 | (branch merge, don't forget to commit) | ||
r46037 | ||||
Check that removal reversion does not go unotified | ||||
================================================== | ||||
On a merge, a file can be removed and user can revert that removal. This means | ||||
user has made an explicit choice of keeping the file or reverting the removal | ||||
even though the merge algo wanted to remove it. | ||||
Based on this, when we do criss cross merges, merge algorithm should not again | ||||
choose to remove the file as in one of the merges, user made an explicit choice | ||||
to revert the removal. | ||||
Following test cases demonstrate how merge algo does not take in account | ||||
explicit choices made by users to revert the removal and on criss-cross merging | ||||
removes the file again. | ||||
"Simple" case where the filenode changes | ||||
---------------------------------------- | ||||
$ cd .. | ||||
$ hg init criss-cross-merge-reversal-with-update | ||||
$ cd criss-cross-merge-reversal-with-update | ||||
$ echo the-file > the-file | ||||
$ echo other-file > other-file | ||||
$ hg add the-file other-file | ||||
$ hg ci -m 'root-commit' | ||||
$ echo foo >> the-file | ||||
$ echo bar >> other-file | ||||
$ hg ci -m 'updating-both-file' | ||||
$ hg up 'desc("root-commit")' | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg rm the-file | ||||
$ hg ci -m 'delete-the-file' | ||||
created new head | ||||
$ hg log -G -T '{node|short} {desc}\n' | ||||
@ 7801bc9b9899 delete-the-file | ||||
| | ||||
| o 9b610631ab29 updating-both-file | ||||
|/ | ||||
o 955800955977 root-commit | ||||
Do all the merge combination (from the deleted or the update side × keeping and deleting the file | ||||
$ hg update 'desc("delete-the-file")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("updating-both-file")' -t :local | ||||
1 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
Pulkit Goyal
|
r46156 | $ hg debugmergestate | ||
local (working copy): 7801bc9b9899de5e304bd162cafde9b78e10ab9b | ||||
other (merge rev): 9b610631ab29024c5f44af7d2c19658ef8f8f071 | ||||
file: the-file (state "r") | ||||
local path: the-file (hash 0000000000000000000000000000000000000000, flags "") | ||||
ancestor path: the-file (node 4b69178b9bdae28b651393b46e631427a72f217a) | ||||
other path: the-file (node 59e363a07dc876278f0e41756236f30213b6b460) | ||||
extra: ancestorlinknode = 955800955977bd6c103836ee3e437276e940a589 | ||||
extra: other-file (filenode-source = other) | ||||
r46037 | $ hg ci -m "merge-deleting-the-file-from-deleted" | |||
$ hg manifest | ||||
other-file | ||||
Pulkit Goyal
|
r46155 | $ hg debugrevlogindex the-file | ||
rev linkrev nodeid p1 p2 | ||||
0 0 4b69178b9bda 000000000000 000000000000 | ||||
1 1 59e363a07dc8 4b69178b9bda 000000000000 | ||||
r46037 | ||||
$ hg update 'desc("updating-both-file")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("delete-the-file")' -t :other | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
Pulkit Goyal
|
r46156 | $ hg debugmergestate | ||
local (working copy): 9b610631ab29024c5f44af7d2c19658ef8f8f071 | ||||
other (merge rev): 7801bc9b9899de5e304bd162cafde9b78e10ab9b | ||||
file: the-file (state "r") | ||||
local path: the-file (hash 6d2e02da5a9fe0691363dc6b573845fa271eaa35, flags "") | ||||
ancestor path: the-file (node 4b69178b9bdae28b651393b46e631427a72f217a) | ||||
other path: the-file (node 0000000000000000000000000000000000000000) | ||||
extra: ancestorlinknode = 955800955977bd6c103836ee3e437276e940a589 | ||||
r46037 | $ hg ci -m "merge-deleting-the-file-from-updated" | |||
created new head | ||||
$ hg manifest | ||||
other-file | ||||
Pulkit Goyal
|
r46155 | $ hg debugrevlogindex the-file | ||
rev linkrev nodeid p1 p2 | ||||
0 0 4b69178b9bda 000000000000 000000000000 | ||||
1 1 59e363a07dc8 4b69178b9bda 000000000000 | ||||
r46037 | ||||
$ hg update 'desc("delete-the-file")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("updating-both-file")' -t :other | ||||
1 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
Pulkit Goyal
|
r46156 | $ hg debugmergestate | ||
local (working copy): 7801bc9b9899de5e304bd162cafde9b78e10ab9b | ||||
other (merge rev): 9b610631ab29024c5f44af7d2c19658ef8f8f071 | ||||
file: the-file (state "r") | ||||
local path: the-file (hash 0000000000000000000000000000000000000000, flags "") | ||||
ancestor path: the-file (node 4b69178b9bdae28b651393b46e631427a72f217a) | ||||
other path: the-file (node 59e363a07dc876278f0e41756236f30213b6b460) | ||||
extra: ancestorlinknode = 955800955977bd6c103836ee3e437276e940a589 | ||||
extra: other-file (filenode-source = other) | ||||
r46037 | $ hg ci -m "merge-keeping-the-file-from-deleted" | |||
created new head | ||||
$ hg manifest | ||||
other-file | ||||
the-file | ||||
Pulkit Goyal
|
r46155 | XXX: This should create a new filenode because user explicitly decided to keep | ||
the file. If we reuse the same filenode, future merges (criss-cross ones mostly) | ||||
will think that file remain unchanged and user explicit choice will not be taken | ||||
in consideration. | ||||
$ hg debugrevlogindex the-file | ||||
rev linkrev nodeid p1 p2 | ||||
0 0 4b69178b9bda 000000000000 000000000000 | ||||
1 1 59e363a07dc8 4b69178b9bda 000000000000 | ||||
r46037 | $ hg update 'desc("updating-both-file")' | |||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("delete-the-file")' -t :local | ||||
0 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
Pulkit Goyal
|
r46156 | $ hg debugmergestate | ||
local (working copy): 9b610631ab29024c5f44af7d2c19658ef8f8f071 | ||||
other (merge rev): 7801bc9b9899de5e304bd162cafde9b78e10ab9b | ||||
file: the-file (state "r") | ||||
local path: the-file (hash 6d2e02da5a9fe0691363dc6b573845fa271eaa35, flags "") | ||||
ancestor path: the-file (node 4b69178b9bdae28b651393b46e631427a72f217a) | ||||
other path: the-file (node 0000000000000000000000000000000000000000) | ||||
extra: ancestorlinknode = 955800955977bd6c103836ee3e437276e940a589 | ||||
r46037 | $ hg ci -m "merge-keeping-the-file-from-updated" | |||
created new head | ||||
$ hg manifest | ||||
other-file | ||||
the-file | ||||
Pulkit Goyal
|
r46155 | XXX: This should create a new filenode because user explicitly decided to keep | ||
the file. If we reuse the same filenode, future merges (criss-cross ones mostly) | ||||
will think that file remain unchanged and user explicit choice will not be taken | ||||
in consideration. | ||||
$ hg debugrevlogindex the-file | ||||
rev linkrev nodeid p1 p2 | ||||
0 0 4b69178b9bda 000000000000 000000000000 | ||||
1 1 59e363a07dc8 4b69178b9bda 000000000000 | ||||
$ hg log -G -T '{node|short} {desc}\n' | ||||
@ 5e3eccec60d8 merge-keeping-the-file-from-updated | ||||
|\ | ||||
+---o e9b708131723 merge-keeping-the-file-from-deleted | ||||
| |/ | ||||
+---o a4e0e44229dc merge-deleting-the-file-from-updated | ||||
| |/ | ||||
+---o adfd88e5d7d3 merge-deleting-the-file-from-deleted | ||||
| |/ | ||||
| o 7801bc9b9899 delete-the-file | ||||
| | | ||||
o | 9b610631ab29 updating-both-file | ||||
|/ | ||||
o 955800955977 root-commit | ||||
r46037 | There the resulting merge together (leading to criss cross situation). Check | |||
the conflict is properly detected. | ||||
(merging two deletion together → no conflict) | ||||
$ hg update --clean 'desc("merge-deleting-the-file-from-deleted")' | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ hg merge 'desc("merge-deleting-the-file-from-updated")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ ls -1 | ||||
other-file | ||||
(merging a deletion with keeping → conflict) | ||||
BROKEN: this should result in conflict | ||||
$ hg update --clean 'desc("merge-deleting-the-file-from-deleted")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("merge-keeping-the-file-from-deleted")' | ||||
Pulkit Goyal
|
r46040 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | (branch merge, don't forget to commit) | |||
$ ls -1 | ||||
other-file | ||||
(merging a deletion with keeping → conflict) | ||||
BROKEN: this should result in conflict | ||||
$ hg update --clean 'desc("merge-deleting-the-file-from-deleted")' | ||||
Pulkit Goyal
|
r46040 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | $ hg merge 'desc("merge-keeping-the-file-from-updated")' | |||
Pulkit Goyal
|
r46040 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | (branch merge, don't forget to commit) | |||
$ ls -1 | ||||
other-file | ||||
(merging two deletion together → no conflict) | ||||
$ hg update --clean 'desc("merge-deleting-the-file-from-updated")' | ||||
Pulkit Goyal
|
r46040 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | $ hg merge 'desc("merge-deleting-the-file-from-deleted")' | |||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ ls -1 | ||||
other-file | ||||
(merging a deletion with keeping → conflict) | ||||
BROKEN: this should result in conflict | ||||
$ hg update --clean 'desc("merge-deleting-the-file-from-updated")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("merge-keeping-the-file-from-deleted")' | ||||
Pulkit Goyal
|
r46040 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | (branch merge, don't forget to commit) | |||
$ ls -1 | ||||
other-file | ||||
(merging a deletion with keeping → conflict) | ||||
BROKEN: this should result in conflict | ||||
$ hg update --clean 'desc("merge-deleting-the-file-from-updated")' | ||||
Pulkit Goyal
|
r46040 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | $ hg merge 'desc("merge-keeping-the-file-from-updated")' | |||
Pulkit Goyal
|
r46040 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | (branch merge, don't forget to commit) | |||
$ ls -1 | ||||
other-file | ||||
(merging two "keeping" together → no conflict) | ||||
$ hg update --clean 'desc("merge-keeping-the-file-from-updated")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("merge-keeping-the-file-from-deleted")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ ls -1 | ||||
other-file | ||||
the-file | ||||
(merging a deletion with keeping → conflict) | ||||
BROKEN: this should result in conflict | ||||
$ hg update --clean 'desc("merge-keeping-the-file-from-updated")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("merge-deleted-the-file-from-deleted")' | ||||
abort: empty revision set | ||||
[255] | ||||
$ ls -1 | ||||
other-file | ||||
the-file | ||||
(merging a deletion with keeping → conflict) | ||||
BROKEN: this should result in conflict | ||||
$ hg update --clean 'desc("merge-keeping-the-file-from-updated")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("merge-deleting-the-file-from-updated")' | ||||
Pulkit Goyal
|
r46041 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | (branch merge, don't forget to commit) | |||
$ ls -1 | ||||
other-file | ||||
Pulkit Goyal
|
r46041 | the-file | ||
r46037 | ||||
(merging two "keeping" together → no conflict) | ||||
$ hg update --clean 'desc("merge-keeping-the-file-from-deleted")' | ||||
Pulkit Goyal
|
r46041 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | $ hg merge 'desc("merge-keeping-the-file-from-updated")' | |||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ ls -1 | ||||
other-file | ||||
the-file | ||||
(merging a deletion with keeping → conflict) | ||||
BROKEN: this should result in conflict | ||||
$ hg update --clean 'desc("merge-keeping-the-file-from-deleted")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("merge-deleted-the-file-from-deleted")' | ||||
abort: empty revision set | ||||
[255] | ||||
$ ls -1 | ||||
other-file | ||||
the-file | ||||
(merging a deletion with keeping → conflict) | ||||
BROKEN: this should result in conflict | ||||
$ hg update --clean 'desc("merge-keeping-the-file-from-deleted")' | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("merge-deleting-the-file-from-updated")' | ||||
Pulkit Goyal
|
r46041 | 0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
r46037 | (branch merge, don't forget to commit) | |||
$ ls -1 | ||||
other-file | ||||
Pulkit Goyal
|
r46041 | the-file | ||