##// END OF EJS Templates
commands: add hidden -T option for files/manifest/status/tags...
r22429:7a7eed51 default
Show More
test-rename-merge2.t
962 lines | 28.2 KiB | text/troff | Tads3Lexer
/ tests / test-rename-merge2.t
Matt Mackall
tests: unify test-rename-merge2
r12484
$ mkdir -p t
$ cd t
$ cat <<EOF > merge
> import sys, os
> f = open(sys.argv[1], "wb")
> f.write("merge %s %s %s" % (sys.argv[1], sys.argv[2], sys.argv[3]))
> f.close()
> EOF
perform a test merge with possible renaming
args:
$1 = action in local branch
$2 = action in remote branch
$3 = action in working dir
$4 = expected result
$ tm()
> {
Martin Geisler
tests: remove redundant mkdir...
r13956 > hg init t
Matt Mackall
tests: unify test-rename-merge2
r12484 > cd t
> echo "[merge]" >> .hg/hgrc
> echo "followcopies = 1" >> .hg/hgrc
>
> # base
> echo base > a
> echo base > rev # used to force commits
> hg add a rev
> hg ci -m "base"
>
> # remote
> echo remote > rev
> if [ "$2" != "" ] ; then $2 ; fi
> hg ci -m "remote"
>
> # local
> hg co -q 0
> echo local > rev
> if [ "$1" != "" ] ; then $1 ; fi
> hg ci -m "local"
>
> # working dir
> echo local > rev
> if [ "$3" != "" ] ; then $3 ; fi
>
> # merge
> echo "--------------"
> echo "test L:$1 R:$2 W:$3 - $4"
> echo "--------------"
Steve Borho
merge: implement --tool arguments using new ui.forcemerge configurable...
r12788 > hg merge -y --debug --traceback --tool="python ../merge"
Matt Mackall
tests: unify test-rename-merge2
r12484 >
> echo "--------------"
> hg status -camC -X rev
>
> hg ci -m "merge"
>
> echo "--------------"
> echo
>
> cd ..
> rm -r t
> }
$ up() {
> cp rev $1
> hg add $1 2> /dev/null
> if [ "$2" != "" ] ; then
Adrian Buehlmann
check-code: add 'no tab indent' check for unified tests...
r12743 > cp rev $2
> hg add $2 2> /dev/null
Matt Mackall
tests: unify test-rename-merge2
r12484 > fi
> }
$ uc() { up $1; hg cp $1 $2; } # update + copy
$ um() { up $1; hg mv $1 $2; }
$ nc() { hg cp $1 $2; } # just copy
$ nm() { hg mv $1 $2; } # just move
$ tm "up a " "nc a b" " " "1 get local a to b"
created new head
--------------
test L:up a R:nc a b W: - 1 get local a to b
--------------
searching for copies back to rev 1
unmatched files in other:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b' *
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: e300d1c794ec+, remote: 4ce40f5aca24
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving a for resolve of b
preserving rev for resolve of rev
Mads Kiilerich
merge: let manifestmerge emit 'keep' actions when keeping wd version...
r21082 a: keep -> k
Mads Kiilerich
merge: keep destination filename as key in filemerge actions...
r20945 b: remote copied from a -> m
updating: b 1/2 files (50.00%)
Matt Mackall
tests: unify test-rename-merge2
r12484 picked tool 'python ../merge' for b (binary False symlink False)
merging a and b to b
my b@e300d1c794ec+ other b@4ce40f5aca24 ancestor a@924404dff337
premerge successful
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@e300d1c794ec+ other rev@4ce40f5aca24 ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
a
C a
--------------
$ tm "nc a b" "up a " " " "2 get rem change to a and b"
created new head
--------------
test L:nc a b R:up a W: - 2 get rem change to a and b
--------------
searching for copies back to rev 1
unmatched files in local:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b' *
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 86a2aa42fc76+, remote: f4db7e329e71
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 a: remote is newer -> g
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 getting a
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: a 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 b: local copied/moved from a -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 2/3 files (66.67%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b and a to b
my b@86a2aa42fc76+ other a@f4db7e329e71 ancestor a@924404dff337
premerge successful
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@86a2aa42fc76+ other rev@f4db7e329e71 ancestor rev@924404dff337
1 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M a
M b
a
--------------
$ tm "up a " "nm a b" " " "3 get local a change to b, remove a"
created new head
--------------
test L:up a R:nm a b W: - 3 get local a change to b, remove a
--------------
searching for copies back to rev 1
unmatched files in other:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b' *
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: e300d1c794ec+, remote: bdb19105162a
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving a for resolve of b
preserving rev for resolve of rev
removing a
Mads Kiilerich
merge: keep destination filename as key in filemerge actions...
r20945 b: remote moved from a -> m
updating: b 1/2 files (50.00%)
Matt Mackall
tests: unify test-rename-merge2
r12484 picked tool 'python ../merge' for b (binary False symlink False)
merging a and b to b
my b@e300d1c794ec+ other b@bdb19105162a ancestor a@924404dff337
premerge successful
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@e300d1c794ec+ other rev@bdb19105162a ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
a
--------------
$ tm "nm a b" "up a " " " "4 get remote change to b"
created new head
--------------
test L:nm a b R:up a W: - 4 get remote change to b
--------------
searching for copies back to rev 1
unmatched files in local:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b' *
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 02963e448370+, remote: f4db7e329e71
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Mads Kiilerich
merge: keep destination filename as key in filemerge actions...
r20945 b: local copied/moved from a -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 1/2 files (50.00%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b and a to b
my b@02963e448370+ other a@f4db7e329e71 ancestor a@924404dff337
premerge successful
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@02963e448370+ other rev@f4db7e329e71 ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
a
--------------
$ tm " " "nc a b" " " "5 get b"
created new head
--------------
test L: R:nc a b W: - 5 get b
--------------
searching for copies back to rev 1
unmatched files in other:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b'
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 94b33a1b7f2d+, remote: 4ce40f5aca24
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving rev for resolve of rev
Mads Kiilerich
merge: delay debug messages for merge actions...
r18541 b: remote created -> g
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 getting b
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 1/2 files (50.00%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@94b33a1b7f2d+ other rev@4ce40f5aca24 ancestor rev@924404dff337
1 files updated, 1 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
C a
--------------
$ tm "nc a b" " " " " "6 nothing"
created new head
--------------
test L:nc a b R: W: - 6 nothing
--------------
searching for copies back to rev 1
unmatched files in local:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b'
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 86a2aa42fc76+, remote: 97c705ade336
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 rev: versions differ -> m
updating: rev 1/1 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@86a2aa42fc76+ other rev@97c705ade336 ancestor rev@924404dff337
0 files updated, 1 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
C a
C b
--------------
$ tm " " "nm a b" " " "7 get b"
created new head
--------------
test L: R:nm a b W: - 7 get b
--------------
searching for copies back to rev 1
unmatched files in other:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b'
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 94b33a1b7f2d+, remote: bdb19105162a
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 a: other deleted -> r
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 removing a
FUJIWARA Katsunori
merge: increase safety of parallel updating/removing on icasefs...
r19095 updating: a 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 b: remote created -> g
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 getting b
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 2/3 files (66.67%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@94b33a1b7f2d+ other rev@bdb19105162a ancestor rev@924404dff337
1 files updated, 1 files merged, 1 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
--------------
$ tm "nm a b" " " " " "8 nothing"
created new head
--------------
test L:nm a b R: W: - 8 nothing
--------------
searching for copies back to rev 1
unmatched files in local:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b'
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 02963e448370+, remote: 97c705ade336
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 rev: versions differ -> m
updating: rev 1/1 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@02963e448370+ other rev@97c705ade336 ancestor rev@924404dff337
0 files updated, 1 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
C b
--------------
$ tm "um a b" "um a b" " " "9 do merge with ancestor in a"
created new head
--------------
test L:um a b R:um a b W: - 9 do merge with ancestor in a
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 62e7bf090eba+, remote: 49b6d8032493
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 b: versions differ -> m
updating: b 1/2 files (50.00%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@62e7bf090eba+ other b@49b6d8032493 ancestor a@924404dff337
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@62e7bf090eba+ other rev@49b6d8032493 ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
--------------
m "um a c" "um x c" " " "10 do merge with no ancestor"
$ tm "nm a b" "nm a c" " " "11 get c, keep b"
created new head
--------------
test L:nm a b R:nm a c W: - 11 get c, keep b
--------------
searching for copies back to rev 1
unmatched files in local:
b
unmatched files in other:
c
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Mads Kiilerich
copies: report found copies sorted
r18362 src: 'a' -> dst: 'b' !
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'c' !
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 02963e448370+, remote: fe905ef2c33e
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 c: remote created -> g
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 getting c
updating: c 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Mads Kiilerich
merge: change priority / ordering of merge actions...
r21389 updating: rev 2/3 files (66.67%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@02963e448370+ other rev@fe905ef2c33e ancestor rev@924404dff337
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 a: divergent renames -> dr
Mads Kiilerich
merge: change priority / ordering of merge actions...
r21389 updating: a 3/3 files (100.00%)
Dan Villiom Podlaski Christiansen
merge: make 'diverging renames' diagnostic a more helpful note....
r12757 note: possible conflict - a was renamed multiple times to:
Matt Mackall
tests: unify test-rename-merge2
r12484 b
c
1 files updated, 1 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M c
C b
--------------
$ tm "nc a b" "up b " " " "12 merge b no ancestor"
created new head
--------------
test L:nc a b R:up b W: - 12 merge b no ancestor
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 86a2aa42fc76+, remote: af30c7647fc7
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 b: versions differ -> m
updating: b 1/2 files (50.00%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@86a2aa42fc76+ other b@af30c7647fc7 ancestor b@000000000000
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@86a2aa42fc76+ other rev@af30c7647fc7 ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
C a
--------------
$ tm "up b " "nm a b" " " "13 merge b no ancestor"
created new head
--------------
test L:up b R:nm a b W: - 13 merge b no ancestor
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 59318016310c+, remote: bdb19105162a
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 a: other deleted -> r
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 removing a
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: a 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 b: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 2/3 files (66.67%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@59318016310c+ other b@bdb19105162a ancestor b@000000000000
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@59318016310c+ other rev@bdb19105162a ancestor rev@924404dff337
0 files updated, 2 files merged, 1 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
--------------
$ tm "nc a b" "up a b" " " "14 merge b no ancestor"
created new head
--------------
test L:nc a b R:up a b W: - 14 merge b no ancestor
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 86a2aa42fc76+, remote: 8dbce441892a
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 a: remote is newer -> g
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 getting a
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: a 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 b: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 2/3 files (66.67%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@86a2aa42fc76+ other b@8dbce441892a ancestor b@000000000000
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@86a2aa42fc76+ other rev@8dbce441892a ancestor rev@924404dff337
1 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M a
M b
--------------
$ tm "up b " "nm a b" " " "15 merge b no ancestor, remove a"
created new head
--------------
test L:up b R:nm a b W: - 15 merge b no ancestor, remove a
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 59318016310c+, remote: bdb19105162a
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 a: other deleted -> r
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 removing a
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: a 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 b: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 2/3 files (66.67%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@59318016310c+ other b@bdb19105162a ancestor b@000000000000
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@59318016310c+ other rev@bdb19105162a ancestor rev@924404dff337
0 files updated, 2 files merged, 1 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
--------------
$ tm "nc a b" "up a b" " " "16 get a, merge b no ancestor"
created new head
--------------
test L:nc a b R:up a b W: - 16 get a, merge b no ancestor
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 86a2aa42fc76+, remote: 8dbce441892a
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 a: remote is newer -> g
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 getting a
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: a 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 b: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 2/3 files (66.67%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@86a2aa42fc76+ other b@8dbce441892a ancestor b@000000000000
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@86a2aa42fc76+ other rev@8dbce441892a ancestor rev@924404dff337
1 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M a
M b
--------------
$ tm "up a b" "nc a b" " " "17 keep a, merge b no ancestor"
created new head
--------------
test L:up a b R:nc a b W: - 17 keep a, merge b no ancestor
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 0b76e65c8289+, remote: 4ce40f5aca24
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Mads Kiilerich
merge: let manifestmerge emit 'keep' actions when keeping wd version...
r21082 a: keep -> k
Matt Mackall
tests: unify test-rename-merge2
r12484 b: versions differ -> m
updating: b 1/2 files (50.00%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@0b76e65c8289+ other b@4ce40f5aca24 ancestor b@000000000000
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@0b76e65c8289+ other rev@4ce40f5aca24 ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
C a
--------------
$ tm "nm a b" "up a b" " " "18 merge b no ancestor"
created new head
--------------
test L:nm a b R:up a b W: - 18 merge b no ancestor
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 02963e448370+, remote: 8dbce441892a
Matt Mackall
tests: unify test-rename-merge2
r12484 remote changed a which local deleted
use (c)hanged version or leave (d)eleted? c
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 a: prompt recreating -> g
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 getting a
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: a 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 b: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 2/3 files (66.67%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@02963e448370+ other b@8dbce441892a ancestor b@000000000000
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@02963e448370+ other rev@8dbce441892a ancestor rev@924404dff337
1 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M a
M b
--------------
$ tm "up a b" "nm a b" " " "19 merge b no ancestor, prompt remove a"
created new head
--------------
test L:up a b R:nm a b W: - 19 merge b no ancestor, prompt remove a
--------------
searching for copies back to rev 1
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
b
Matt Mackall
tests: unify test-rename-merge2
r12484 resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 0b76e65c8289+, remote: bdb19105162a
Mads Kiilerich
merge: don't indent "local changed %s which remote deleted" prompt...
r18543 local changed a which remote deleted
Matt Mackall
tests: unify test-rename-merge2
r12484 use (c)hanged version or (d)elete? c
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Matt Mackall
tests: unify test-rename-merge2
r12484 a: prompt keep -> a
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 updating: a 1/3 files (33.33%)
Mads Kiilerich
merge: delay debug messages for merge actions...
r18541 b: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 2/3 files (66.67%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b
my b@0b76e65c8289+ other b@bdb19105162a ancestor b@000000000000
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@0b76e65c8289+ other rev@bdb19105162a ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
C a
--------------
$ tm "up a " "um a b" " " "20 merge a and b to b, remove a"
created new head
--------------
test L:up a R:um a b W: - 20 merge a and b to b, remove a
--------------
searching for copies back to rev 1
unmatched files in other:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b' *
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: e300d1c794ec+, remote: 49b6d8032493
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving a for resolve of b
preserving rev for resolve of rev
removing a
Mads Kiilerich
merge: keep destination filename as key in filemerge actions...
r20945 b: remote moved from a -> m
updating: b 1/2 files (50.00%)
Matt Mackall
tests: unify test-rename-merge2
r12484 picked tool 'python ../merge' for b (binary False symlink False)
merging a and b to b
my b@e300d1c794ec+ other b@49b6d8032493 ancestor a@924404dff337
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@e300d1c794ec+ other rev@49b6d8032493 ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
a
--------------
$ tm "um a b" "up a " " " "21 merge a and b to b"
created new head
--------------
test L:um a b R:up a W: - 21 merge a and b to b
--------------
searching for copies back to rev 1
unmatched files in local:
b
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b' *
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 62e7bf090eba+, remote: f4db7e329e71
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Mads Kiilerich
merge: keep destination filename as key in filemerge actions...
r20945 b: local copied/moved from a -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: b 1/2 files (50.00%)
picked tool 'python ../merge' for b (binary False symlink False)
merging b and a to b
my b@62e7bf090eba+ other a@f4db7e329e71 ancestor a@924404dff337
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 2/2 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@62e7bf090eba+ other rev@f4db7e329e71 ancestor rev@924404dff337
0 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
a
--------------
m "nm a b" "um x a" " " "22 get a, keep b"
$ tm "nm a b" "up a c" " " "23 get c, keep b"
created new head
--------------
test L:nm a b R:up a c W: - 23 get c, keep b
--------------
searching for copies back to rev 1
unmatched files in local:
b
unmatched files in other:
c
Thomas Arendsen Hein
merge: show renamed on one and deleted on the other side in debug output
r16795 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
Siddharth Agarwal
copies: make debug messages more sensible...
r18135 src: 'a' -> dst: 'b' *
Matt Mackall
tests: unify test-rename-merge2
r12484 checking for directory renames
resolving manifests
Siddharth Agarwal
manifestmerge: pass in branchmerge and force separately...
r18605 branchmerge: True, force: False, partial: False
Martin Geisler
merge: make debug output easier to read...
r15625 ancestor: 924404dff337, local: 02963e448370+, remote: 2b958612230f
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving b for resolve of b
preserving rev for resolve of rev
Mads Kiilerich
merge: change priority / ordering of merge actions...
r21389 c: remote created -> g
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 getting c
updating: c 1/3 files (33.33%)
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 b: local copied/moved from a -> m
Bryan O'Sullivan
tests: update test output (will be folded into parent)
r18631 updating: b 2/3 files (66.67%)
Matt Mackall
tests: unify test-rename-merge2
r12484 picked tool 'python ../merge' for b (binary False symlink False)
merging b and a to b
my b@02963e448370+ other a@2b958612230f ancestor a@924404dff337
premerge successful
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 rev: versions differ -> m
Matt Mackall
tests: unify test-rename-merge2
r12484 updating: rev 3/3 files (100.00%)
picked tool 'python ../merge' for rev (binary False symlink False)
merging rev
my rev@02963e448370+ other rev@2b958612230f ancestor rev@924404dff337
1 files updated, 2 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
--------------
M b
a
M c
--------------
Mads Kiilerich
tests: add missing trailing 'cd ..'...
r16913
$ cd ..
Mads Kiilerich
tests: add systematic test of merge ancestor calculation...
r20637
Systematic and terse testing of merge merges and ancestor calculation:
Mads Kiilerich
spelling: fixes from spell checker
r21024 Expected result:
Mads Kiilerich
tests: add systematic test of merge ancestor calculation...
r20637
\ a m1 m2 dst
0 - f f f "versions differ"
1 f g g g "versions differ"
2 f f f f "versions differ"
3 f f g f+g "remote copied to " + f
4 f f g g "remote moved to " + f
5 f g f f+g "local copied to " + f2
6 f g f g "local moved to " + f2
7 - (f) f f "remote differs from untracked local"
8 f (f) f f "remote differs from untracked local"
$ hg init ancestortest
$ cd ancestortest
$ for x in 1 2 3 4 5 6 8; do mkdir $x; echo a > $x/f; done
$ hg ci -Aqm "a"
$ mkdir 0
$ touch 0/f
$ hg mv 1/f 1/g
$ hg cp 5/f 5/g
$ hg mv 6/f 6/g
$ hg rm 8/f
$ for x in */*; do echo m1 > $x; done
$ hg ci -Aqm "m1"
$ hg up -qr0
$ mkdir 0 7
$ touch 0/f 7/f
$ hg mv 1/f 1/g
$ hg cp 3/f 3/g
$ hg mv 4/f 4/g
$ for x in */*; do echo m2 > $x; done
$ hg ci -Aqm "m2"
$ hg up -qr1
$ mkdir 7 8
$ echo m > 7/f
$ echo m > 8/f
$ hg merge -f --tool internal:dump -v --debug -r2 | sed '/^updating:/,$d' 2> /dev/null
searching for copies back to rev 1
unmatched files in local:
5/g
6/g
unmatched files in other:
3/g
4/g
7/f
Mads Kiilerich
copies: when both sides made the same copy, report it as a copy...
r20641 unmatched files new in both:
0/f
1/g
Mads Kiilerich
tests: add systematic test of merge ancestor calculation...
r20637 all copies found (* = to merge, ! = divergent, % = renamed and deleted):
src: '3/f' -> dst: '3/g' *
src: '4/f' -> dst: '4/g' *
src: '5/f' -> dst: '5/g' *
src: '6/f' -> dst: '6/g' *
checking for directory renames
resolving manifests
branchmerge: True, force: True, partial: False
ancestor: e6cb3cf11019, local: ec44bf929ab5+, remote: c62e34d0b898
remote changed 8/f which local deleted
use (c)hanged version or leave (d)eleted? c
Mads Kiilerich
merge: change debug logging - test output changes but no real changes...
r21391 preserving 0/f for resolve of 0/f
preserving 1/g for resolve of 1/g
preserving 2/f for resolve of 2/f
preserving 3/f for resolve of 3/f
preserving 3/f for resolve of 3/g
preserving 4/f for resolve of 4/g
preserving 5/f for resolve of 5/f
preserving 5/g for resolve of 5/g
preserving 6/g for resolve of 6/g
preserving 7/f for resolve of 7/f
removing 4/f
Mads Kiilerich
merge: change priority / ordering of merge actions...
r21389 8/f: prompt recreating -> g
Mads Kiilerich
tests: add systematic test of merge ancestor calculation...
r20637 getting 8/f
$ hg mani
0/f
1/g
2/f
3/f
4/f
5/f
5/g
6/g
$ for f in */*; do echo $f:; cat $f; done
0/f:
m1
0/f.base:
0/f.local:
m1
0/f.orig:
m1
0/f.other:
m2
1/g:
m1
1/g.base:
a
1/g.local:
m1
1/g.orig:
m1
1/g.other:
m2
2/f:
m1
2/f.base:
a
2/f.local:
m1
2/f.orig:
m1
2/f.other:
m2
3/f:
m1
3/f.base:
a
3/f.local:
m1
3/f.orig:
m1
3/f.other:
m2
3/g:
m1
3/g.base:
a
3/g.local:
m1
3/g.orig:
m1
3/g.other:
m2
4/g:
m1
4/g.base:
a
4/g.local:
m1
4/g.orig:
m1
4/g.other:
m2
5/f:
m1
5/f.base:
a
5/f.local:
m1
5/f.orig:
m1
5/f.other:
m2
5/g:
m1
5/g.base:
a
5/g.local:
m1
5/g.orig:
m1
5/g.other:
m2
6/g:
m1
6/g.base:
a
6/g.local:
m1
6/g.orig:
m1
6/g.other:
m2
7/f:
m
7/f.base:
7/f.local:
m
7/f.orig:
m
7/f.other:
m2
8/f:
m2
$ cd ..