test-rename-dir-merge.t
223 lines
| 5.0 KiB
| text/troff
|
Tads3Lexer
/ tests / test-rename-dir-merge.t
Martin Geisler
|
r13956 | $ hg init t | ||
Nicolas Dumazet
|
r12114 | $ cd t | ||
$ mkdir a | ||||
$ echo foo > a/a | ||||
$ echo bar > a/b | ||||
$ hg ci -Am "0" | ||||
adding a/a | ||||
adding a/b | ||||
$ hg co -C 0 | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg mv a b | ||||
Mads Kiilerich
|
r15447 | moving a/a to b/a (glob) | ||
moving a/b to b/b (glob) | ||||
Nicolas Dumazet
|
r12114 | $ hg ci -m "1 mv a/ b/" | ||
$ hg co -C 0 | ||||
2 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||||
$ echo baz > a/c | ||||
$ echo quux > a/d | ||||
$ hg add a/c | ||||
$ hg ci -m "2 add a/c" | ||||
created new head | ||||
$ hg merge --debug 1 | ||||
searching for copies back to rev 1 | ||||
unmatched files in local: | ||||
a/c | ||||
unmatched files in other: | ||||
b/a | ||||
b/b | ||||
Thomas Arendsen Hein
|
r16795 | all copies found (* = to merge, ! = divergent, % = renamed and deleted): | ||
Siddharth Agarwal
|
r18135 | src: 'a/a' -> dst: 'b/a' | ||
src: 'a/b' -> dst: 'b/b' | ||||
Nicolas Dumazet
|
r12114 | checking for directory renames | ||
Siddharth Agarwal
|
r18135 | discovered dir src: 'a/' -> dst: 'b/' | ||
pending file src: 'a/c' -> dst: 'b/c' | ||||
Nicolas Dumazet
|
r12114 | resolving manifests | ||
Siddharth Agarwal
|
r18605 | branchmerge: True, force: False, partial: False | ||
Martin Geisler
|
r15625 | ancestor: f9b20c0d4c51, local: ce36d17b18fb+, remote: 397f8b00a740 | ||
Mads Kiilerich
|
r18360 | a/a: other deleted -> r | ||
Mads Kiilerich
|
r21391 | removing a/a | ||
Nicolas Dumazet
|
r12114 | a/b: other deleted -> r | ||
removing a/b | ||||
FUJIWARA Katsunori
|
r19095 | updating: a/b 2/5 files (40.00%) | ||
Mads Kiilerich
|
r21391 | b/a: remote created -> g | ||
Bryan O'Sullivan
|
r18631 | getting b/a | ||
Mads Kiilerich
|
r21391 | b/b: remote created -> g | ||
Bryan O'Sullivan
|
r18631 | getting b/b | ||
updating: b/b 4/5 files (80.00%) | ||||
Mads Kiilerich
|
r21391 | b/c: remote directory rename - move from a/c -> dm | ||
Mads Kiilerich
|
r20944 | updating: b/c 5/5 files (100.00%) | ||
Brendan Cully
|
r19133 | moving a/c to b/c (glob) | ||
Matt Mackall
|
r16094 | 3 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||
Nicolas Dumazet
|
r12114 | (branch merge, don't forget to commit) | ||
$ echo a/* b/* | ||||
Matt Mackall
|
r16094 | a/d b/a b/b b/c | ||
Nicolas Dumazet
|
r12114 | $ hg st -C | ||
M b/a | ||||
M b/b | ||||
A b/c | ||||
a/c | ||||
R a/a | ||||
R a/b | ||||
R a/c | ||||
Matt Mackall
|
r16094 | ? a/d | ||
Nicolas Dumazet
|
r12114 | $ hg ci -m "3 merge 2+1" | ||
$ hg debugrename b/c | ||||
Mads Kiilerich
|
r15447 | b/c renamed from a/c:354ae8da6e890359ef49ade27b68bbc361f3ca88 (glob) | ||
Nicolas Dumazet
|
r12114 | |||
$ hg co -C 1 | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ hg merge --debug 2 | ||||
searching for copies back to rev 1 | ||||
unmatched files in local: | ||||
b/a | ||||
b/b | ||||
unmatched files in other: | ||||
a/c | ||||
Thomas Arendsen Hein
|
r16795 | all copies found (* = to merge, ! = divergent, % = renamed and deleted): | ||
Siddharth Agarwal
|
r18135 | src: 'a/a' -> dst: 'b/a' | ||
src: 'a/b' -> dst: 'b/b' | ||||
Nicolas Dumazet
|
r12114 | checking for directory renames | ||
Siddharth Agarwal
|
r18135 | discovered dir src: 'a/' -> dst: 'b/' | ||
pending file src: 'a/c' -> dst: 'b/c' | ||||
Nicolas Dumazet
|
r12114 | resolving manifests | ||
Siddharth Agarwal
|
r18605 | branchmerge: True, force: False, partial: False | ||
Martin Geisler
|
r15625 | ancestor: f9b20c0d4c51, local: 397f8b00a740+, remote: ce36d17b18fb | ||
Mads Kiilerich
|
r20944 | b/c: local directory rename - get from a/c -> dg | ||
updating: b/c 1/1 files (100.00%) | ||||
Nicolas Dumazet
|
r12114 | getting a/c to b/c | ||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ echo a/* b/* | ||||
Matt Mackall
|
r16094 | a/d b/a b/b b/c | ||
Nicolas Dumazet
|
r12114 | $ hg st -C | ||
A b/c | ||||
a/c | ||||
Matt Mackall
|
r16094 | ? a/d | ||
Nicolas Dumazet
|
r12114 | $ hg ci -m "4 merge 1+2" | ||
created new head | ||||
$ hg debugrename b/c | ||||
Mads Kiilerich
|
r15447 | b/c renamed from a/c:354ae8da6e890359ef49ade27b68bbc361f3ca88 (glob) | ||
Nicolas Dumazet
|
r12114 | |||
Martin von Zweigbergk
|
r23444 | Local directory rename with conflicting file added in remote source directory | ||
and untracked in local target directory. | ||||
BROKEN: the uncommitted file is overwritten; we should abort | ||||
$ hg co -qC 1 | ||||
Martin von Zweigbergk
|
r23464 | $ echo target > b/c | ||
Martin von Zweigbergk
|
r23444 | $ hg merge 2 | ||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
Martin von Zweigbergk
|
r23464 | $ hg st -A | ||
Martin von Zweigbergk
|
r23444 | A b/c | ||
a/c | ||||
? a/d | ||||
Martin von Zweigbergk
|
r23464 | C b/a | ||
C b/b | ||||
Martin von Zweigbergk
|
r23444 | $ cat b/c | ||
baz | ||||
Local directory rename with conflicting file added in remote source directory | ||||
and committed in local target directory. | ||||
BROKEN: the local file is overwritten; it should be merged | ||||
$ hg co -qC 1 | ||||
Martin von Zweigbergk
|
r23464 | $ echo target > b/c | ||
Martin von Zweigbergk
|
r23444 | $ hg add b/c | ||
$ hg commit -qm 'new file in target directory' | ||||
$ hg merge 2 | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
Martin von Zweigbergk
|
r23464 | $ hg st -A | ||
Martin von Zweigbergk
|
r23444 | A b/c | ||
a/c | ||||
? a/d | ||||
Martin von Zweigbergk
|
r23464 | C b/a | ||
C b/b | ||||
$ cat b/c | ||||
baz | ||||
Remote directory rename with conflicting file added in remote target directory | ||||
and committed in local source directory. | ||||
BROKEN: the remote is ignored; it should be merged | ||||
$ hg co -qC 2 | ||||
$ rm b/c | ||||
$ hg st -A | ||||
? a/d | ||||
C a/a | ||||
C a/b | ||||
C a/c | ||||
$ hg merge 5 | ||||
3 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg st -A | ||||
M b/a | ||||
M b/b | ||||
A b/c | ||||
a/c | ||||
R a/a | ||||
R a/b | ||||
R a/c | ||||
? a/d | ||||
Martin von Zweigbergk
|
r23444 | $ cat b/c | ||
baz | ||||
Nicolas Dumazet
|
r12114 | |||
Second scenario with two repos: | ||||
$ cd .. | ||||
Martin Geisler
|
r13956 | $ hg init r1 | ||
Nicolas Dumazet
|
r12114 | $ cd r1 | ||
$ mkdir a | ||||
$ echo foo > a/f | ||||
$ hg add a | ||||
Mads Kiilerich
|
r15447 | adding a/f (glob) | ||
Nicolas Dumazet
|
r12114 | $ hg ci -m "a/f == foo" | ||
$ cd .. | ||||
$ hg clone r1 r2 | ||||
updating to branch default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd r2 | ||||
$ hg mv a b | ||||
Mads Kiilerich
|
r15447 | moving a/f to b/f (glob) | ||
Nicolas Dumazet
|
r12114 | $ echo foo1 > b/f | ||
$ hg ci -m" a -> b, b/f == foo1" | ||||
$ cd .. | ||||
$ cd r1 | ||||
$ mkdir a/aa | ||||
$ echo bar > a/aa/g | ||||
$ hg add a/aa | ||||
Mads Kiilerich
|
r15447 | adding a/aa/g (glob) | ||
Nicolas Dumazet
|
r12114 | $ hg ci -m "a/aa/g" | ||
$ hg pull ../r2 | ||||
pulling from ../r2 | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files (+1 heads) | ||||
(run 'hg heads' to see heads, 'hg merge' to merge) | ||||
$ hg merge | ||||
2 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg st -C | ||||
M b/f | ||||
A b/aa/g | ||||
a/aa/g | ||||
R a/aa/g | ||||
R a/f | ||||
Mads Kiilerich
|
r16913 | |||
$ cd .. | ||||