test-rebase-cache.t
483 lines
| 8.9 KiB
| text/troff
|
Tads3Lexer
/ tests / test-rebase-cache.t
Adrian Buehlmann
|
r12608 | $ cat >> $HGRCPATH <<EOF | ||
> [extensions] | ||||
> rebase= | ||||
Joshua Redstone
|
r17013 | > mq= | ||
Adrian Buehlmann
|
r12608 | > | ||
Pierre-Yves David
|
r15742 | > [phases] | ||
> publish=False | ||||
> | ||||
Adrian Buehlmann
|
r12608 | > [alias] | ||
> tglog = log -G --template "{rev}: '{desc}' {branches}\n" | ||||
> theads = heads --template "{rev}: '{desc}' {branches}\n" | ||||
> EOF | ||||
$ hg init a | ||||
$ cd a | ||||
$ echo a > a | ||||
$ hg ci -Am A | ||||
adding a | ||||
$ hg branch branch1 | ||||
marked working directory as branch branch1 | ||||
Matt Mackall
|
r15615 | (branches are permanent and global, did you want a bookmark?) | ||
Adrian Buehlmann
|
r12608 | $ hg ci -m 'branch1' | ||
$ echo b > b | ||||
$ hg ci -Am B | ||||
adding b | ||||
$ hg up -q 0 | ||||
$ hg branch branch2 | ||||
marked working directory as branch branch2 | ||||
$ hg ci -m 'branch2' | ||||
$ echo c > C | ||||
$ hg ci -Am C | ||||
adding C | ||||
$ hg up -q 2 | ||||
$ hg branch -f branch2 | ||||
marked working directory as branch branch2 | ||||
$ echo d > d | ||||
$ hg ci -Am D | ||||
adding d | ||||
created new head | ||||
$ echo e > e | ||||
$ hg ci -Am E | ||||
adding e | ||||
$ hg update default | ||||
0 files updated, 0 files merged, 3 files removed, 0 files unresolved | ||||
$ hg branch branch3 | ||||
marked working directory as branch branch3 | ||||
$ hg ci -m 'branch3' | ||||
$ echo f > f | ||||
$ hg ci -Am F | ||||
adding f | ||||
$ cd .. | ||||
Rebase part of branch2 (5-6) onto branch3 (8): | ||||
$ hg clone -q -u . a a1 | ||||
$ cd a1 | ||||
Mads Kiilerich
|
r17345 | $ hg tglog | ||
Adrian Buehlmann
|
r12608 | @ 8: 'F' branch3 | ||
| | ||||
o 7: 'branch3' branch3 | ||||
| | ||||
| o 6: 'E' branch2 | ||||
| | | ||||
| o 5: 'D' branch2 | ||||
| | | ||||
| | o 4: 'C' branch2 | ||||
| | | | ||||
+---o 3: 'branch2' branch2 | ||||
| | | ||||
| o 2: 'B' branch1 | ||||
| | | ||||
| o 1: 'branch1' branch1 | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg branches | ||||
Peter Arrenbrecht
|
r14162 | branch3 8:4666b71e8e32 | ||
branch2 6:5097051d331d | ||||
branch1 2:0a03079c47fd (inactive) | ||||
Adrian Buehlmann
|
r12608 | default 0:1994f17a630e (inactive) | ||
$ hg theads | ||||
8: 'F' branch3 | ||||
6: 'E' branch2 | ||||
4: 'C' branch2 | ||||
2: 'B' branch1 | ||||
0: 'A' | ||||
Pierre-Yves David
|
r17005 | $ hg rebase -s 5 -d 8 | ||
Mads Kiilerich
|
r23517 | rebasing 5:635859577d0b "D" | ||
rebasing 6:5097051d331d "E" | ||||
Matt Harbison
|
r35394 | saved backup bundle to $TESTTMP/a1/.hg/strip-backup/635859577d0b-89160bff-rebase.hg | ||
Adrian Buehlmann
|
r12608 | |||
$ hg branches | ||||
Peter Arrenbrecht
|
r14162 | branch3 8:466cdfb14b62 | ||
branch2 4:e4fdb121d036 | ||||
branch1 2:0a03079c47fd | ||||
Adrian Buehlmann
|
r12608 | default 0:1994f17a630e (inactive) | ||
$ hg theads | ||||
8: 'E' branch3 | ||||
4: 'C' branch2 | ||||
2: 'B' branch1 | ||||
0: 'A' | ||||
Mads Kiilerich
|
r17345 | $ hg tglog | ||
Pierre-Yves David
|
r19925 | o 8: 'E' branch3 | ||
Adrian Buehlmann
|
r12608 | | | ||
o 7: 'D' branch3 | ||||
| | ||||
Pierre-Yves David
|
r19925 | @ 6: 'F' branch3 | ||
Adrian Buehlmann
|
r12608 | | | ||
o 5: 'branch3' branch3 | ||||
| | ||||
| o 4: 'C' branch2 | ||||
| | | ||||
| o 3: 'branch2' branch2 | ||||
|/ | ||||
| o 2: 'B' branch1 | ||||
| | | ||||
| o 1: 'branch1' branch1 | ||||
|/ | ||||
o 0: 'A' | ||||
$ cd .. | ||||
Rebase head of branch3 (8) onto branch2 (6): | ||||
$ hg clone -q -u . a a2 | ||||
$ cd a2 | ||||
$ hg tglog | ||||
@ 8: 'F' branch3 | ||||
| | ||||
o 7: 'branch3' branch3 | ||||
| | ||||
| o 6: 'E' branch2 | ||||
| | | ||||
| o 5: 'D' branch2 | ||||
| | | ||||
| | o 4: 'C' branch2 | ||||
| | | | ||||
+---o 3: 'branch2' branch2 | ||||
| | | ||||
| o 2: 'B' branch1 | ||||
| | | ||||
| o 1: 'branch1' branch1 | ||||
|/ | ||||
o 0: 'A' | ||||
Pierre-Yves David
|
r17005 | $ hg rebase -s 8 -d 6 | ||
Mads Kiilerich
|
r23517 | rebasing 8:4666b71e8e32 "F" (tip) | ||
Matt Harbison
|
r35394 | saved backup bundle to $TESTTMP/a2/.hg/strip-backup/4666b71e8e32-fc1c4e96-rebase.hg | ||
Adrian Buehlmann
|
r12608 | |||
$ hg branches | ||||
Peter Arrenbrecht
|
r14162 | branch2 8:6b4bdc1b5ac0 | ||
branch3 7:653b9feb4616 | ||||
branch1 2:0a03079c47fd (inactive) | ||||
Adrian Buehlmann
|
r12608 | default 0:1994f17a630e (inactive) | ||
$ hg theads | ||||
8: 'F' branch2 | ||||
7: 'branch3' branch3 | ||||
4: 'C' branch2 | ||||
2: 'B' branch1 | ||||
0: 'A' | ||||
$ hg tglog | ||||
@ 8: 'F' branch2 | ||||
| | ||||
| o 7: 'branch3' branch3 | ||||
| | | ||||
o | 6: 'E' branch2 | ||||
| | | ||||
o | 5: 'D' branch2 | ||||
| | | ||||
| | o 4: 'C' branch2 | ||||
| | | | ||||
| | o 3: 'branch2' branch2 | ||||
| |/ | ||||
o | 2: 'B' branch1 | ||||
| | | ||||
o | 1: 'branch1' branch1 | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg verify -q | ||||
$ cd .. | ||||
Rebase entire branch3 (7-8) onto branch2 (6): | ||||
$ hg clone -q -u . a a3 | ||||
$ cd a3 | ||||
$ hg tglog | ||||
@ 8: 'F' branch3 | ||||
| | ||||
o 7: 'branch3' branch3 | ||||
| | ||||
| o 6: 'E' branch2 | ||||
| | | ||||
| o 5: 'D' branch2 | ||||
| | | ||||
| | o 4: 'C' branch2 | ||||
| | | | ||||
+---o 3: 'branch2' branch2 | ||||
| | | ||||
| o 2: 'B' branch1 | ||||
| | | ||||
| o 1: 'branch1' branch1 | ||||
|/ | ||||
o 0: 'A' | ||||
Pierre-Yves David
|
r17005 | $ hg rebase -s 7 -d 6 | ||
Mads Kiilerich
|
r23517 | rebasing 7:653b9feb4616 "branch3" | ||
Martin von Zweigbergk
|
r40900 | note: not rebasing 7:653b9feb4616 "branch3", its destination already has all its changes | ||
Mads Kiilerich
|
r23517 | rebasing 8:4666b71e8e32 "F" (tip) | ||
Matt Harbison
|
r35394 | saved backup bundle to $TESTTMP/a3/.hg/strip-backup/653b9feb4616-3c88de16-rebase.hg | ||
Adrian Buehlmann
|
r12608 | |||
$ hg branches | ||||
Peter Arrenbrecht
|
r14162 | branch2 7:6b4bdc1b5ac0 | ||
branch1 2:0a03079c47fd (inactive) | ||||
Adrian Buehlmann
|
r12608 | default 0:1994f17a630e (inactive) | ||
$ hg theads | ||||
7: 'F' branch2 | ||||
4: 'C' branch2 | ||||
2: 'B' branch1 | ||||
0: 'A' | ||||
Mads Kiilerich
|
r17345 | $ hg tglog | ||
Adrian Buehlmann
|
r12608 | @ 7: 'F' branch2 | ||
| | ||||
o 6: 'E' branch2 | ||||
| | ||||
o 5: 'D' branch2 | ||||
| | ||||
| o 4: 'C' branch2 | ||||
| | | ||||
| o 3: 'branch2' branch2 | ||||
| | | ||||
o | 2: 'B' branch1 | ||||
| | | ||||
o | 1: 'branch1' branch1 | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg verify -q | ||||
Joshua Redstone
|
r17013 | Stripping multiple branches in one go bypasses the fast-case code to | ||
update the branch cache. | ||||
$ hg strip 2 | ||||
0 files updated, 0 files merged, 4 files removed, 0 files unresolved | ||||
Matt Harbison
|
r35394 | saved backup bundle to $TESTTMP/a3/.hg/strip-backup/0a03079c47fd-11b7c407-backup.hg | ||
Joshua Redstone
|
r17013 | |||
$ hg tglog | ||||
o 3: 'C' branch2 | ||||
| | ||||
o 2: 'branch2' branch2 | ||||
| | ||||
| @ 1: 'branch1' branch1 | ||||
|/ | ||||
o 0: 'A' | ||||
$ hg branches | ||||
branch2 3:e4fdb121d036 | ||||
branch1 1:63379ac49655 | ||||
default 0:1994f17a630e (inactive) | ||||
$ hg theads | ||||
3: 'C' branch2 | ||||
1: 'branch1' branch1 | ||||
0: 'A' | ||||
Fast path branchcache code should not be invoked if branches stripped is not | ||||
the same as branches remaining. | ||||
$ hg init b | ||||
$ cd b | ||||
$ hg branch branch1 | ||||
marked working directory as branch branch1 | ||||
(branches are permanent and global, did you want a bookmark?) | ||||
$ hg ci -m 'branch1' | ||||
$ hg branch branch2 | ||||
marked working directory as branch branch2 | ||||
$ hg ci -m 'branch2' | ||||
$ hg branch -f branch1 | ||||
marked working directory as branch branch1 | ||||
$ echo a > A | ||||
$ hg ci -Am A | ||||
adding A | ||||
created new head | ||||
$ hg tglog | ||||
@ 2: 'A' branch1 | ||||
| | ||||
o 1: 'branch2' branch2 | ||||
| | ||||
o 0: 'branch1' branch1 | ||||
$ hg theads | ||||
2: 'A' branch1 | ||||
1: 'branch2' branch2 | ||||
$ hg strip 2 | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Matt Harbison
|
r35394 | saved backup bundle to $TESTTMP/a3/b/.hg/strip-backup/a5b4b27ed7b4-a3b6984e-backup.hg | ||
Joshua Redstone
|
r17013 | |||
$ hg theads | ||||
1: 'branch2' branch2 | ||||
0: 'branch1' branch1 | ||||
Make sure requesting to strip a revision already stripped does not confuse things. | ||||
Try both orders. | ||||
Mads Kiilerich
|
r16913 | $ cd .. | ||
Joshua Redstone
|
r17013 | |||
$ hg init c | ||||
$ cd c | ||||
$ 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 | ||||
$ echo d > d | ||||
$ hg ci -Am D | ||||
adding d | ||||
$ echo e > e | ||||
$ hg ci -Am E | ||||
adding e | ||||
$ hg tglog | ||||
@ 4: 'E' | ||||
| | ||||
o 3: 'D' | ||||
| | ||||
o 2: 'C' | ||||
| | ||||
o 1: 'B' | ||||
| | ||||
o 0: 'A' | ||||
$ hg strip 3 4 | ||||
0 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||||
Matt Harbison
|
r35394 | saved backup bundle to $TESTTMP/a3/c/.hg/strip-backup/67a385d4e6f2-b9243789-backup.hg | ||
Joshua Redstone
|
r17013 | |||
$ hg theads | ||||
2: 'C' | ||||
$ hg strip 2 1 | ||||
0 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||||
Matt Harbison
|
r35394 | saved backup bundle to $TESTTMP/a3/c/.hg/strip-backup/6c81ed0049f8-a687065f-backup.hg | ||
Joshua Redstone
|
r17013 | |||
$ hg theads | ||||
0: 'A' | ||||
Pierre-Yves David
|
r18983 | |||
Make sure rebase does not break for phase/filter related reason | ||||
---------------------------------------------------------------- | ||||
(issue3858) | ||||
$ cd .. | ||||
$ cat >> $HGRCPATH << EOF | ||||
> [ui] | ||||
> logtemplate={rev} {desc} {phase}\n | ||||
> EOF | ||||
$ hg init c4 | ||||
$ cd c4 | ||||
$ echo a > a | ||||
$ hg ci -Am A | ||||
adding a | ||||
$ echo b > b | ||||
$ hg ci -Am B | ||||
adding b | ||||
$ hg up 0 | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ echo c > c | ||||
$ hg ci -Am C | ||||
adding c | ||||
created new head | ||||
$ hg up 1 | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ hg merge | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m d | ||||
$ hg up 2 | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ echo e > e | ||||
$ hg ci -Am E | ||||
adding e | ||||
created new head | ||||
$ hg merge 3 | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m F | ||||
$ hg up 3 | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ echo g > g | ||||
$ hg ci -Am G | ||||
adding g | ||||
created new head | ||||
$ echo h > h | ||||
$ hg ci -Am H | ||||
adding h | ||||
$ hg up 5 | ||||
1 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||||
$ echo i > i | ||||
$ hg ci -Am I | ||||
adding i | ||||
Turn most changeset public | ||||
$ hg ph -p 7 | ||||
$ hg heads | ||||
8 I draft | ||||
7 H public | ||||
$ hg log -G | ||||
@ 8 I draft | ||||
| | ||||
| o 7 H public | ||||
| | | ||||
| o 6 G public | ||||
| | | ||||
o | 5 F draft | ||||
|\| | ||||
o | 4 E draft | ||||
| | | ||||
| o 3 d public | ||||
|/| | ||||
o | 2 C public | ||||
| | | ||||
| o 1 B public | ||||
|/ | ||||
o 0 A public | ||||
FUJIWARA Katsunori
|
r22251 | $ cat > $TESTTMP/checkeditform.sh <<EOF | ||
> env | grep HGEDITFORM | ||||
> true | ||||
> EOF | ||||
$ HGEDITOR="sh $TESTTMP/checkeditform.sh" hg rebase --dest 7 --source 5 -e | ||||
Mads Kiilerich
|
r23517 | rebasing 5:361a99976cc9 "F" | ||
FUJIWARA Katsunori
|
r22251 | HGEDITFORM=rebase.merge | ||
Mads Kiilerich
|
r23517 | rebasing 8:326cfedc031c "I" (tip) | ||
FUJIWARA Katsunori
|
r22251 | HGEDITFORM=rebase.normal | ||
Matt Harbison
|
r35394 | saved backup bundle to $TESTTMP/a3/c4/.hg/strip-backup/361a99976cc9-35e980d0-rebase.hg | ||