test-rebase-collapse.t
592 lines
| 8.3 KiB
| text/troff
|
Tads3Lexer
/ tests / test-rebase-collapse.t
Adrian Buehlmann
|
r12608 | $ cat >> $HGRCPATH <<EOF | ||
> [extensions] | ||||
> graphlog= | ||||
> rebase= | ||||
> | ||||
Pierre-Yves David
|
r15742 | > [phases] | ||
> publish=False | ||||
> | ||||
Adrian Buehlmann
|
r12608 | > [alias] | ||
> tglog = log -G --template "{rev}: '{desc}' {branches}\n" | ||||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | > tglogp = log -G --template "{rev}:{phase} '{desc}' {branches}\n" | ||
Adrian Buehlmann
|
r12608 | > EOF | ||
Create repo a: | ||||
$ hg init a | ||||
$ cd a | ||||
Thomas Arendsen Hein
|
r16350 | $ hg unbundle "$TESTDIR/bundles/rebase.hg" | ||
Nicolas Dumazet
|
r14119 | adding changesets | ||
adding manifests | ||||
adding file changes | ||||
added 8 changesets with 7 changes to 7 files (+2 heads) | ||||
(run 'hg heads' to see heads, 'hg merge' to merge) | ||||
$ hg up tip | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Adrian Buehlmann
|
r12608 | |||
$ hg tglog | ||||
@ 7: 'H' | ||||
| | ||||
| o 6: 'G' | ||||
|/| | ||||
o | 5: 'F' | ||||
| | | ||||
| o 4: 'E' | ||||
|/ | ||||
| o 3: 'D' | ||||
| | | ||||
| o 2: 'C' | ||||
| | | ||||
| o 1: 'B' | ||||
|/ | ||||
o 0: 'A' | ||||
$ cd .. | ||||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | Rebasing B onto H and collapsing changesets with different phases: | ||
Adrian Buehlmann
|
r12608 | |||
$ hg clone -q -u 3 a a1 | ||||
$ cd a1 | ||||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | $ hg phase --force --secret 3 | ||
Adrian Buehlmann
|
r12608 | $ hg rebase --collapse --keepbranches | ||
Mads Kiilerich
|
r12640 | saved backup bundle to $TESTTMP/a1/.hg/strip-backup/*-backup.hg (glob) | ||
Adrian Buehlmann
|
r12608 | |||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | $ hg tglogp | ||
@ 5:secret 'Collapsed revision | ||||
Adrian Buehlmann
|
r12608 | | * B | ||
| * C | ||||
| * D' | ||||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | o 4:draft 'H' | ||
Adrian Buehlmann
|
r12608 | | | ||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | | o 3:draft 'G' | ||
Adrian Buehlmann
|
r12608 | |/| | ||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | o | 2:draft 'F' | ||
Adrian Buehlmann
|
r12608 | | | | ||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | | o 1:draft 'E' | ||
Adrian Buehlmann
|
r12608 | |/ | ||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | o 0:draft 'A' | ||
Adrian Buehlmann
|
r12608 | |||
$ hg manifest | ||||
A | ||||
B | ||||
C | ||||
D | ||||
F | ||||
H | ||||
$ cd .. | ||||
Pierre-Yves David
|
r15267 | Rebasing E onto H: | ||
Adrian Buehlmann
|
r12608 | |||
$ hg clone -q -u . a a2 | ||||
$ cd a2 | ||||
Alain Leufroy <alain.leufroyATgmailMYDOTcom>
|
r15917 | $ hg phase --force --secret 6 | ||
Pierre-Yves David
|
r15267 | $ hg rebase --source 4 --collapse | ||
Mads Kiilerich
|
r12640 | saved backup bundle to $TESTTMP/a2/.hg/strip-backup/*-backup.hg (glob) | ||
Adrian Buehlmann
|
r12608 | |||
$ hg tglog | ||||
@ 6: 'Collapsed revision | ||||
| * E | ||||
| * G' | ||||
o 5: 'H' | ||||
| | ||||
o 4: 'F' | ||||
| | ||||
| o 3: 'D' | ||||
| | | ||||
| o 2: 'C' | ||||
| | | ||||
| o 1: 'B' | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg manifest | ||||
A | ||||
E | ||||
F | ||||
H | ||||
$ cd .. | ||||
Radomir Dopieralski
|
r13661 | Rebasing G onto H with custom message: | ||
$ hg clone -q -u . a a3 | ||||
$ cd a3 | ||||
$ hg rebase --base 6 -m 'custom message' | ||||
abort: message can only be specified with collapse | ||||
[255] | ||||
Pierre-Yves David
|
r15267 | $ hg rebase --source 4 --collapse -m 'custom message' | ||
Radomir Dopieralski
|
r13661 | saved backup bundle to $TESTTMP/a3/.hg/strip-backup/*-backup.hg (glob) | ||
$ hg tglog | ||||
@ 6: 'custom message' | ||||
| | ||||
o 5: 'H' | ||||
| | ||||
o 4: 'F' | ||||
| | ||||
| o 3: 'D' | ||||
| | | ||||
| o 2: 'C' | ||||
| | | ||||
| o 1: 'B' | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg manifest | ||||
A | ||||
E | ||||
F | ||||
H | ||||
$ cd .. | ||||
Adrian Buehlmann
|
r12608 | |||
Create repo b: | ||||
$ hg init b | ||||
$ cd b | ||||
$ echo A > A | ||||
$ hg ci -Am A | ||||
adding A | ||||
$ echo B > B | ||||
$ hg ci -Am B | ||||
adding B | ||||
$ hg up -q 0 | ||||
$ echo C > C | ||||
$ hg ci -Am C | ||||
adding C | ||||
created new head | ||||
$ hg merge | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ echo D > D | ||||
$ hg ci -Am D | ||||
adding D | ||||
$ hg up -q 1 | ||||
$ echo E > E | ||||
$ hg ci -Am E | ||||
adding E | ||||
created new head | ||||
$ echo F > F | ||||
$ hg ci -Am F | ||||
adding F | ||||
$ hg merge | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m G | ||||
$ hg up -q 0 | ||||
$ echo H > H | ||||
$ hg ci -Am H | ||||
adding H | ||||
created new head | ||||
$ hg tglog | ||||
@ 7: 'H' | ||||
| | ||||
| o 6: 'G' | ||||
| |\ | ||||
| | o 5: 'F' | ||||
| | | | ||||
| | o 4: 'E' | ||||
| | | | ||||
| o | 3: 'D' | ||||
| |\| | ||||
| o | 2: 'C' | ||||
|/ / | ||||
| o 1: 'B' | ||||
|/ | ||||
o 0: 'A' | ||||
$ cd .. | ||||
Rebase and collapse - more than one external (fail): | ||||
$ hg clone -q -u . b b1 | ||||
$ cd b1 | ||||
$ hg rebase -s 2 --collapse | ||||
abort: unable to collapse, there is more than one external parent | ||||
[255] | ||||
Rebase and collapse - E onto H: | ||||
$ hg rebase -s 4 --collapse | ||||
Mads Kiilerich
|
r12640 | saved backup bundle to $TESTTMP/b1/.hg/strip-backup/*-backup.hg (glob) | ||
Adrian Buehlmann
|
r12608 | |||
$ hg tglog | ||||
@ 5: 'Collapsed revision | ||||
|\ * E | ||||
| | * F | ||||
| | * G' | ||||
| o 4: 'H' | ||||
| | | ||||
o | 3: 'D' | ||||
|\ \ | ||||
| o | 2: 'C' | ||||
| |/ | ||||
o / 1: 'B' | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg manifest | ||||
A | ||||
B | ||||
C | ||||
D | ||||
E | ||||
F | ||||
H | ||||
$ cd .. | ||||
Create repo c: | ||||
$ hg init c | ||||
$ cd c | ||||
$ echo A > A | ||||
$ hg ci -Am A | ||||
adding A | ||||
$ echo B > B | ||||
$ hg ci -Am B | ||||
adding B | ||||
$ hg up -q 0 | ||||
$ echo C > C | ||||
$ hg ci -Am C | ||||
adding C | ||||
created new head | ||||
$ hg merge | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ echo D > D | ||||
$ hg ci -Am D | ||||
adding D | ||||
$ hg up -q 1 | ||||
$ echo E > E | ||||
$ hg ci -Am E | ||||
adding E | ||||
created new head | ||||
$ echo F > E | ||||
$ hg ci -m 'F' | ||||
$ echo G > G | ||||
$ hg ci -Am G | ||||
adding G | ||||
$ hg merge | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m H | ||||
$ hg up -q 0 | ||||
$ echo I > I | ||||
$ hg ci -Am I | ||||
adding I | ||||
created new head | ||||
$ hg tglog | ||||
@ 8: 'I' | ||||
| | ||||
| o 7: 'H' | ||||
| |\ | ||||
| | o 6: 'G' | ||||
| | | | ||||
| | o 5: 'F' | ||||
| | | | ||||
| | o 4: 'E' | ||||
| | | | ||||
| o | 3: 'D' | ||||
| |\| | ||||
| o | 2: 'C' | ||||
|/ / | ||||
| o 1: 'B' | ||||
|/ | ||||
o 0: 'A' | ||||
$ cd .. | ||||
Rebase and collapse - E onto I: | ||||
$ hg clone -q -u . c c1 | ||||
$ cd c1 | ||||
$ hg rebase -s 4 --collapse | ||||
merging E | ||||
Mads Kiilerich
|
r12640 | saved backup bundle to $TESTTMP/c1/.hg/strip-backup/*-backup.hg (glob) | ||
Adrian Buehlmann
|
r12608 | |||
$ hg tglog | ||||
@ 5: 'Collapsed revision | ||||
|\ * E | ||||
| | * F | ||||
| | * G | ||||
| | * H' | ||||
| o 4: 'I' | ||||
| | | ||||
o | 3: 'D' | ||||
|\ \ | ||||
| o | 2: 'C' | ||||
| |/ | ||||
o / 1: 'B' | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg manifest | ||||
A | ||||
B | ||||
C | ||||
D | ||||
E | ||||
G | ||||
I | ||||
$ cat E | ||||
F | ||||
$ cd .. | ||||
Create repo d: | ||||
$ hg init d | ||||
$ cd d | ||||
$ echo A > A | ||||
$ hg ci -Am A | ||||
adding A | ||||
$ echo B > B | ||||
$ hg ci -Am B | ||||
adding B | ||||
$ echo C > C | ||||
$ hg ci -Am C | ||||
adding C | ||||
$ hg up -q 1 | ||||
$ echo D > D | ||||
$ hg ci -Am D | ||||
adding D | ||||
created new head | ||||
$ hg merge | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m E | ||||
$ hg up -q 0 | ||||
$ echo F > F | ||||
$ hg ci -Am F | ||||
adding F | ||||
created new head | ||||
$ hg tglog | ||||
@ 5: 'F' | ||||
| | ||||
| o 4: 'E' | ||||
| |\ | ||||
| | o 3: 'D' | ||||
| | | | ||||
| o | 2: 'C' | ||||
| |/ | ||||
| o 1: 'B' | ||||
|/ | ||||
o 0: 'A' | ||||
$ cd .. | ||||
Rebase and collapse - B onto F: | ||||
$ hg clone -q -u . d d1 | ||||
$ cd d1 | ||||
$ hg rebase -s 1 --collapse | ||||
Mads Kiilerich
|
r12640 | saved backup bundle to $TESTTMP/d1/.hg/strip-backup/*-backup.hg (glob) | ||
Adrian Buehlmann
|
r12608 | |||
$ hg tglog | ||||
@ 2: 'Collapsed revision | ||||
| * B | ||||
| * C | ||||
| * D | ||||
| * E' | ||||
o 1: 'F' | ||||
| | ||||
o 0: 'A' | ||||
$ hg manifest | ||||
A | ||||
B | ||||
C | ||||
D | ||||
F | ||||
Stefano Tortarolo
|
r14897 | Interactions between collapse and keepbranches | ||
$ cd .. | ||||
$ hg init e | ||||
$ cd e | ||||
$ echo 'a' > a | ||||
$ hg ci -Am 'A' | ||||
adding a | ||||
$ hg branch '1' | ||||
marked working directory as branch 1 | ||||
Matt Mackall
|
r15615 | (branches are permanent and global, did you want a bookmark?) | ||
Stefano Tortarolo
|
r14897 | $ echo 'b' > b | ||
$ hg ci -Am 'B' | ||||
adding b | ||||
$ hg branch '2' | ||||
marked working directory as branch 2 | ||||
Matt Mackall
|
r15615 | (branches are permanent and global, did you want a bookmark?) | ||
Stefano Tortarolo
|
r14897 | $ echo 'c' > c | ||
$ hg ci -Am 'C' | ||||
adding c | ||||
$ hg up -q 0 | ||||
$ echo 'd' > d | ||||
$ hg ci -Am 'D' | ||||
adding d | ||||
$ hg tglog | ||||
@ 3: 'D' | ||||
| | ||||
| o 2: 'C' 2 | ||||
| | | ||||
| o 1: 'B' 1 | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg rebase --keepbranches --collapse -s 1 -d 3 | ||||
abort: cannot collapse multiple named branches | ||||
[255] | ||||
Augie Fackler
|
r15990 | $ repeatchange() { | ||
> hg checkout $1 | ||||
> hg cp d z | ||||
> echo blah >> z | ||||
> hg commit -Am "$2" --user "$3" | ||||
> } | ||||
$ repeatchange 3 "E" "user1" | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ repeatchange 3 "E" "user2" | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
created new head | ||||
$ hg tglog | ||||
@ 5: 'E' | ||||
| | ||||
| o 4: 'E' | ||||
|/ | ||||
o 3: 'D' | ||||
| | ||||
| o 2: 'C' 2 | ||||
| | | ||||
| o 1: 'B' 1 | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg rebase -s 5 -d 4 | ||||
saved backup bundle to $TESTTMP/e/.hg/strip-backup/*-backup.hg (glob) | ||||
$ hg tglog | ||||
@ 4: 'E' | ||||
| | ||||
o 3: 'D' | ||||
| | ||||
| o 2: 'C' 2 | ||||
| | | ||||
| o 1: 'B' 1 | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg export tip | ||||
# HG changeset patch | ||||
# User user1 | ||||
# Date 0 0 | ||||
# Node ID f338eb3c2c7cc5b5915676a2376ba7ac558c5213 | ||||
# Parent 41acb9dca9eb976e84cd21fcb756b4afa5a35c09 | ||||
E | ||||
diff -r 41acb9dca9eb -r f338eb3c2c7c z | ||||
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 | ||||
+++ b/z Thu Jan 01 00:00:00 1970 +0000 | ||||
@@ -0,0 +1,2 @@ | ||||
+d | ||||
+blah | ||||
Patrick Mezard
|
r16551 | |||
$ cd .. | ||||
Rebase, collapse and copies | ||||
$ hg init copies | ||||
$ cd copies | ||||
$ hg unbundle "$TESTDIR/bundles/renames.hg" | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 4 changesets with 11 changes to 7 files (+1 heads) | ||||
(run 'hg heads' to see heads, 'hg merge' to merge) | ||||
$ hg up -q tip | ||||
$ hg tglog | ||||
@ 3: 'move2' | ||||
| | ||||
o 2: 'move1' | ||||
| | ||||
| o 1: 'change' | ||||
|/ | ||||
o 0: 'add' | ||||
$ hg rebase --collapse -d 1 | ||||
merging a and d to d | ||||
merging b and e to e | ||||
merging c and f to f | ||||
merging e and g to g | ||||
merging f and c to c | ||||
saved backup bundle to $TESTTMP/copies/.hg/strip-backup/*-backup.hg (glob) | ||||
$ hg st | ||||
$ hg st --copies --change . | ||||
A d | ||||
a | ||||
A g | ||||
b | ||||
R b | ||||
$ cat c | ||||
c | ||||
c | ||||
$ cat d | ||||
a | ||||
a | ||||
$ cat g | ||||
b | ||||
b | ||||
$ hg log -r . --template "{file_copies}\n" | ||||
d (a)g (b) | ||||
$ cd .. | ||||