Show More
test-rename-merge1.t
235 lines
| 5.5 KiB
| text/troff
|
Tads3Lexer
/ tests / test-rename-merge1.t
Adrian Buehlmann
|
r12298 | $ hg init | ||
$ echo "[merge]" >> .hg/hgrc | ||||
$ echo "followcopies = 1" >> .hg/hgrc | ||||
$ echo foo > a | ||||
$ echo foo > a2 | ||||
$ hg add a a2 | ||||
$ hg ci -m "start" | ||||
$ hg mv a b | ||||
$ hg mv a2 b2 | ||||
$ hg ci -m "rename" | ||||
$ hg co 0 | ||||
2 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||||
$ echo blahblah > a | ||||
$ echo blahblah > a2 | ||||
$ hg mv a2 c2 | ||||
$ hg ci -m "modify" | ||||
created new head | ||||
$ hg merge -y --debug | ||||
unmatched files in local: | ||||
c2 | ||||
unmatched files in other: | ||||
b | ||||
b2 | ||||
Thomas Arendsen Hein
|
r16795 | all copies found (* = to merge, ! = divergent, % = renamed and deleted): | ||
Siddharth Agarwal
|
r18135 | src: 'a' -> dst: 'b' * | ||
src: 'a2' -> dst: 'b2' ! | ||||
Mads Kiilerich
|
r18362 | src: 'a2' -> dst: 'c2' ! | ||
Adrian Buehlmann
|
r12298 | checking for directory renames | ||
resolving manifests | ||||
Siddharth Agarwal
|
r18605 | branchmerge: True, force: False, partial: False | ||
Martin Geisler
|
r15625 | ancestor: af1939970a1c, local: 044f8520aeeb+, remote: 85c198ef2f6c | ||
Martin von Zweigbergk
|
r26957 | note: possible conflict - a2 was renamed multiple times to: | ||
Martin von Zweigbergk
|
r42279 | b2 | ||
Martin von Zweigbergk
|
r26957 | c2 | ||
Mads Kiilerich
|
r21391 | preserving a for resolve of b | ||
removing a | ||||
Mads Kiilerich
|
r21389 | b2: remote created -> g | ||
Bryan O'Sullivan
|
r18631 | getting b2 | ||
Siddharth Agarwal
|
r26618 | b: remote moved from a -> m (premerge) | ||
Siddharth Agarwal
|
r27161 | picked tool ':merge' for b (binary False symlink False changedelete False) | ||
Adrian Buehlmann
|
r12298 | merging a and b to b | ||
my b@044f8520aeeb+ other b@85c198ef2f6c ancestor a@af1939970a1c | ||||
premerge successful | ||||
1 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg status -AC | ||||
M b | ||||
a | ||||
M b2 | ||||
R a | ||||
C c2 | ||||
$ cat b | ||||
blahblah | ||||
$ hg ci -m "merge" | ||||
Sune Foldager
|
r14182 | $ hg debugindex b | ||
Gregory Szorc
|
r37301 | rev linkrev nodeid p1 p2 | ||
0 1 57eacc201a7f 000000000000 000000000000 | ||||
1 3 4727ba907962 000000000000 57eacc201a7f | ||||
Adrian Buehlmann
|
r12298 | |||
$ hg debugrename b | ||||
b renamed from a:dd03b83622e78778b403775d0d074b9ac7387a66 | ||||
Dan Villiom Podlaski Christiansen
|
r12683 | This used to trigger a "divergent renames" warning, despite no renames | ||
$ hg cp b b3 | ||||
$ hg cp b b4 | ||||
$ hg ci -A -m 'copy b twice' | ||||
Martin von Zweigbergk
|
r42359 | $ hg up '.^' | ||
Dan Villiom Podlaski Christiansen
|
r12683 | 0 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||
$ hg up | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg rm b3 b4 | ||||
$ hg ci -m 'clean up a bit of our mess' | ||||
We'd rather not warn on divergent renames done in the same changeset (issue2113) | ||||
$ hg cp b b3 | ||||
$ hg mv b b4 | ||||
$ hg ci -A -m 'divergent renames in same changeset' | ||||
Martin von Zweigbergk
|
r42359 | $ hg up '.^' | ||
Dan Villiom Podlaski Christiansen
|
r12683 | 1 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||
$ hg up | ||||
2 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Matt Mackall
|
r13468 | |||
Check for issue2642 | ||||
$ hg init t | ||||
$ cd t | ||||
$ echo c0 > f1 | ||||
$ hg ci -Aqm0 | ||||
$ hg up null -q | ||||
$ echo c1 > f1 # backport | ||||
$ hg ci -Aqm1 | ||||
$ hg mv f1 f2 | ||||
$ hg ci -qm2 | ||||
$ hg up 0 -q | ||||
$ hg merge 1 -q --tool internal:local | ||||
$ hg ci -qm3 | ||||
$ hg merge 2 | ||||
merging f1 and f2 to f2 | ||||
0 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ cat f2 | ||||
c0 | ||||
Wagner Bruna
|
r13492 | |||
Thomas Arendsen Hein
|
r16793 | $ cd .. | ||
Wagner Bruna
|
r13492 | Check for issue2089 | ||
$ hg init repo2089 | ||||
$ cd repo2089 | ||||
Patrick Mezard
|
r13537 | $ echo c0 > f1 | ||
$ hg ci -Aqm0 | ||||
Wagner Bruna
|
r13492 | |||
Patrick Mezard
|
r13537 | $ hg up null -q | ||
$ echo c1 > f1 | ||||
$ hg ci -Aqm1 | ||||
Wagner Bruna
|
r13492 | |||
Patrick Mezard
|
r13537 | $ hg up 0 -q | ||
Wagner Bruna
|
r13492 | $ hg merge 1 -q --tool internal:local | ||
Patrick Mezard
|
r13537 | $ echo c2 > f1 | ||
$ hg ci -qm2 | ||||
Wagner Bruna
|
r13492 | |||
Patrick Mezard
|
r13537 | $ hg up 1 -q | ||
$ hg mv f1 f2 | ||||
$ hg ci -Aqm3 | ||||
Wagner Bruna
|
r13492 | |||
Patrick Mezard
|
r13537 | $ hg up 2 -q | ||
Wagner Bruna
|
r13492 | $ hg merge 3 | ||
Patrick Mezard
|
r13537 | merging f1 and f2 to f2 | ||
Wagner Bruna
|
r13492 | 0 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||
(branch merge, don't forget to commit) | ||||
Patrick Mezard
|
r13537 | $ cat f2 | ||
c2 | ||||
Thomas Arendsen Hein
|
r16793 | |||
$ cd .. | ||||
Thomas Arendsen Hein
|
r16794 | |||
Check for issue3074 | ||||
$ hg init repo3074 | ||||
$ cd repo3074 | ||||
$ echo foo > file | ||||
$ hg add file | ||||
$ hg commit -m "added file" | ||||
$ hg mv file newfile | ||||
$ hg commit -m "renamed file" | ||||
$ hg update 0 | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ hg rm file | ||||
$ hg commit -m "deleted file" | ||||
created new head | ||||
Thomas Arendsen Hein
|
r16795 | $ hg merge --debug | ||
unmatched files in other: | ||||
newfile | ||||
all copies found (* = to merge, ! = divergent, % = renamed and deleted): | ||||
Siddharth Agarwal
|
r18135 | src: 'file' -> dst: 'newfile' % | ||
Thomas Arendsen Hein
|
r16795 | checking for directory renames | ||
resolving manifests | ||||
Siddharth Agarwal
|
r18605 | branchmerge: True, force: False, partial: False | ||
Thomas Arendsen Hein
|
r16795 | ancestor: 19d7f95df299, local: 0084274f6b67+, remote: 5d32493049f0 | ||
Martin von Zweigbergk
|
r26957 | note: possible conflict - file was deleted and renamed to: | ||
newfile | ||||
Mads Kiilerich
|
r21389 | newfile: remote created -> g | ||
Bryan O'Sullivan
|
r18631 | getting newfile | ||
Thomas Arendsen Hein
|
r16794 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
(branch merge, don't forget to commit) | ||||
$ hg status | ||||
M newfile | ||||
$ cd .. | ||||
Martin von Zweigbergk
|
r42407 | |||
Check that file is considered unrelated when deleted and recreated | ||||
$ hg init unrelated | ||||
$ cd unrelated | ||||
$ echo foo > file | ||||
$ hg add file | ||||
$ hg commit -m "added file" | ||||
$ hg cp file newfile | ||||
$ hg commit -m "copy file" | ||||
$ hg update 0 | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ hg rm file | ||||
$ hg commit -m "deleted file" | ||||
created new head | ||||
$ echo bar > file | ||||
$ hg add file | ||||
$ hg ci -m 'recreate file' | ||||
$ hg log -G -T '{rev} {desc}\n' | ||||
@ 3 recreate file | ||||
| | ||||
o 2 deleted file | ||||
| | ||||
| o 1 copy file | ||||
|/ | ||||
o 0 added file | ||||
BROKEN: this is inconsistent with `hg merge` (below), which doesn't consider | ||||
'file' renamed same since it was deleted for a while | ||||
$ hg st --copies --rev 3 --rev 1 | ||||
M file | ||||
A newfile | ||||
file | ||||
$ hg merge --debug 1 | ||||
unmatched files in other: | ||||
newfile | ||||
all copies found (* = to merge, ! = divergent, % = renamed and deleted): | ||||
src: 'file' -> dst: 'newfile' | ||||
checking for directory renames | ||||
resolving manifests | ||||
branchmerge: True, force: False, partial: False | ||||
ancestor: 19d7f95df299, local: 4e4a42b1cbdf+, remote: 45b14aae7432 | ||||
newfile: remote created -> g | ||||
getting newfile | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg status | ||||
M newfile | ||||
$ cd .. | ||||