test-bookmarks-pushpull.t
1277 lines
| 37.7 KiB
| text/troff
|
Tads3Lexer
/ tests / test-bookmarks-pushpull.t
Boris Feld
|
r35264 | #testcases b2-pushkey b2-binary | ||
Boris Feld
|
r35265 | |||
#if b2-pushkey | ||||
$ cat << EOF >> $HGRCPATH | ||||
> [devel] | ||||
> legacy.exchange=bookmarks | ||||
> EOF | ||||
#endif | ||||
Matt Mackall
|
r22046 | #require serve | ||
Mads Kiilerich
|
r15446 | |||
Pierre-Yves David
|
r17551 | $ cat << EOF >> $HGRCPATH | ||
Pierre-Yves David
|
r17864 | > [ui] | ||
> logtemplate={rev}:{node|short} {desc|firstline} | ||||
Pierre-Yves David
|
r17551 | > [phases] | ||
> publish=False | ||||
Durham Goode
|
r22955 | > [experimental] | ||
Boris Feld
|
r34867 | > evolution.createmarkers=True | ||
Boris Feld
|
r34869 | > evolution.exchange=True | ||
Pierre-Yves David
|
r17551 | > EOF | ||
Matt Harbison
|
r34939 | $ cat > $TESTTMP/hook.sh <<'EOF' | ||
> echo "test-hook-bookmark: $HG_BOOKMARK: $HG_OLDNODE -> $HG_NODE" | ||||
> EOF | ||||
$ TESTHOOK="hooks.txnclose-bookmark.test=sh $TESTTMP/hook.sh" | ||||
Boris Feld
|
r34709 | |||
Will Maier
|
r12303 | initialize | ||
$ hg init a | ||||
$ cd a | ||||
$ echo 'test' > test | ||||
$ hg commit -Am'test' | ||||
adding test | ||||
set bookmarks | ||||
$ hg bookmark X | ||||
$ hg bookmark Y | ||||
$ hg bookmark Z | ||||
import bookmark by name | ||||
$ hg init ../b | ||||
$ cd ../b | ||||
Matt Mackall
|
r12969 | $ hg book Y | ||
$ hg book | ||||
* Y -1:000000000000 | ||||
Boris Feld
|
r34709 | $ hg pull ../a --config "$TESTHOOK" | ||
Will Maier
|
r12303 | pulling from ../a | ||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
Mads Kiilerich
|
r18363 | adding remote bookmark X | ||
David Soria Parra
|
r13662 | updating bookmark Y | ||
Levi Bard
|
r16697 | adding remote bookmark Z | ||
Denis Laxalde
|
r34662 | new changesets 4e3505fd9583 | ||
Boris Feld
|
r34709 | test-hook-bookmark: X: -> 4e3505fd95835d721066b76e75dbb8cc554d7f77 | ||
test-hook-bookmark: Y: 0000000000000000000000000000000000000000 -> 4e3505fd95835d721066b76e75dbb8cc554d7f77 | ||||
test-hook-bookmark: Z: -> 4e3505fd95835d721066b76e75dbb8cc554d7f77 | ||||
Will Maier
|
r12303 | (run 'hg update' to get a working copy) | ||
$ hg bookmarks | ||||
Levi Bard
|
r16697 | X 0:4e3505fd9583 | ||
Kevin Bullock
|
r18479 | * Y 0:4e3505fd9583 | ||
Levi Bard
|
r16697 | Z 0:4e3505fd9583 | ||
Matt Mackall
|
r12969 | $ hg debugpushkey ../a namespaces | ||
bookmarks | ||||
namespaces | ||||
Pierre-Yves David
|
r17551 | obsolete | ||
Mads Kiilerich <mads at kiilerich.com>
|
r18255 | phases | ||
Matt Mackall
|
r12969 | $ hg debugpushkey ../a bookmarks | ||
Mads Kiilerich <mads at kiilerich.com>
|
r18255 | X 4e3505fd95835d721066b76e75dbb8cc554d7f77 | ||
Matt Mackall
|
r12969 | Y 4e3505fd95835d721066b76e75dbb8cc554d7f77 | ||
Z 4e3505fd95835d721066b76e75dbb8cc554d7f77 | ||||
Pierre-Yves David
|
r23199 | |||
Mads Kiilerich
|
r23543 | delete the bookmark to re-pull it | ||
Pierre-Yves David
|
r23199 | |||
$ hg book -d X | ||||
$ hg pull -B X ../a | ||||
pulling from ../a | ||||
no changes found | ||||
adding remote bookmark X | ||||
finally no-op pull | ||||
Will Maier
|
r12303 | $ hg pull -B X ../a | ||
pulling from ../a | ||||
no changes found | ||||
$ hg bookmark | ||||
David Soria Parra
|
r13388 | X 0:4e3505fd9583 | ||
Kevin Bullock
|
r18479 | * Y 0:4e3505fd9583 | ||
Levi Bard
|
r16697 | Z 0:4e3505fd9583 | ||
Will Maier
|
r12303 | |||
export bookmark by name | ||||
$ hg bookmark W | ||||
$ hg bookmark foo | ||||
$ hg bookmark foobar | ||||
$ hg push -B W ../a | ||||
pushing to ../a | ||||
searching for changes | ||||
no changes found | ||||
exporting bookmark W | ||||
Matt Mackall
|
r16038 | [1] | ||
Will Maier
|
r12303 | $ hg -R ../a bookmarks | ||
David Soria Parra
|
r13388 | W -1:000000000000 | ||
Will Maier
|
r12303 | X 0:4e3505fd9583 | ||
David Soria Parra
|
r13388 | Y 0:4e3505fd9583 | ||
Will Maier
|
r12303 | * Z 0:4e3505fd9583 | ||
Matt Mackall
|
r12969 | delete a remote bookmark | ||
$ hg book -d W | ||||
Boris Feld
|
r35264 | |||
#if b2-pushkey | ||||
Boris Feld
|
r35031 | $ hg push -B W ../a --config "$TESTHOOK" --debug --config devel.bundle2.debug=yes | ||
Matt Mackall
|
r13368 | pushing to ../a | ||
Boris Feld
|
r35031 | query 1; heads | ||
Matt Mackall
|
r13368 | searching for changes | ||
Boris Feld
|
r35031 | all remote heads known locally | ||
listing keys for "phases" | ||||
checking for updated bookmarks | ||||
listing keys for "bookmarks" | ||||
Matt Mackall
|
r13368 | no changes found | ||
Boris Feld
|
r35260 | bundle2-output-bundle: "HG20", 4 parts total | ||
Boris Feld
|
r35031 | bundle2-output: start emission of HG20 stream | ||
bundle2-output: bundle parameter: | ||||
bundle2-output: start of parts | ||||
bundle2-output: bundle part: "replycaps" | ||||
Boris Feld
|
r36986 | bundle2-output-part: "replycaps" 222 bytes payload | ||
Boris Feld
|
r35031 | bundle2-output: part 0: "REPLYCAPS" | ||
bundle2-output: header chunk size: 16 | ||||
Boris Feld
|
r36986 | bundle2-output: payload chunk size: 222 | ||
Boris Feld
|
r35260 | bundle2-output: closing payload chunk | ||
bundle2-output: bundle part: "check:bookmarks" | ||||
bundle2-output-part: "check:bookmarks" 23 bytes payload | ||||
bundle2-output: part 1: "CHECK:BOOKMARKS" | ||||
bundle2-output: header chunk size: 22 | ||||
bundle2-output: payload chunk size: 23 | ||||
Boris Feld
|
r35031 | bundle2-output: closing payload chunk | ||
bundle2-output: bundle part: "check:phases" | ||||
bundle2-output-part: "check:phases" 48 bytes payload | ||||
Boris Feld
|
r35260 | bundle2-output: part 2: "CHECK:PHASES" | ||
Boris Feld
|
r35031 | bundle2-output: header chunk size: 19 | ||
bundle2-output: payload chunk size: 48 | ||||
bundle2-output: closing payload chunk | ||||
bundle2-output: bundle part: "pushkey" | ||||
bundle2-output-part: "pushkey" (params: 4 mandatory) empty payload | ||||
Boris Feld
|
r35260 | bundle2-output: part 3: "PUSHKEY" | ||
Boris Feld
|
r35031 | bundle2-output: header chunk size: 90 | ||
bundle2-output: closing payload chunk | ||||
bundle2-output: end of bundle | ||||
bundle2-input: start processing of HG20 stream | ||||
bundle2-input: reading bundle2 stream parameters | ||||
bundle2-input-bundle: with-transaction | ||||
bundle2-input: start extraction of bundle2 parts | ||||
bundle2-input: part header size: 16 | ||||
bundle2-input: part type: "REPLYCAPS" | ||||
bundle2-input: part id: "0" | ||||
bundle2-input: part parameters: 0 | ||||
bundle2-input: found a handler for part replycaps | ||||
bundle2-input-part: "replycaps" supported | ||||
Boris Feld
|
r36986 | bundle2-input: payload chunk size: 222 | ||
Boris Feld
|
r35031 | bundle2-input: payload chunk size: 0 | ||
Boris Feld
|
r36986 | bundle2-input-part: total payload size 222 | ||
Boris Feld
|
r35260 | bundle2-input: part header size: 22 | ||
bundle2-input: part type: "CHECK:BOOKMARKS" | ||||
bundle2-input: part id: "1" | ||||
bundle2-input: part parameters: 0 | ||||
bundle2-input: found a handler for part check:bookmarks | ||||
bundle2-input-part: "check:bookmarks" supported | ||||
bundle2-input: payload chunk size: 23 | ||||
bundle2-input: payload chunk size: 0 | ||||
bundle2-input-part: total payload size 23 | ||||
Boris Feld
|
r35031 | bundle2-input: part header size: 19 | ||
bundle2-input: part type: "CHECK:PHASES" | ||||
Boris Feld
|
r35260 | bundle2-input: part id: "2" | ||
Boris Feld
|
r35031 | bundle2-input: part parameters: 0 | ||
bundle2-input: found a handler for part check:phases | ||||
bundle2-input-part: "check:phases" supported | ||||
bundle2-input: payload chunk size: 48 | ||||
bundle2-input: payload chunk size: 0 | ||||
bundle2-input-part: total payload size 48 | ||||
bundle2-input: part header size: 90 | ||||
bundle2-input: part type: "PUSHKEY" | ||||
Boris Feld
|
r35260 | bundle2-input: part id: "3" | ||
Boris Feld
|
r35031 | bundle2-input: part parameters: 4 | ||
bundle2-input: found a handler for part pushkey | ||||
bundle2-input-part: "pushkey" (params: 4 mandatory) supported | ||||
pushing key for "bookmarks:W" | ||||
bundle2-input: payload chunk size: 0 | ||||
bundle2-input: part header size: 0 | ||||
bundle2-input: end of bundle2 stream | ||||
Boris Feld
|
r35260 | bundle2-input-bundle: 3 parts total | ||
Boris Feld
|
r35031 | running hook txnclose-bookmark.test: sh $TESTTMP/hook.sh | ||
Boris Feld
|
r34709 | test-hook-bookmark: W: 0000000000000000000000000000000000000000 -> | ||
Boris Feld
|
r35031 | bundle2-output-bundle: "HG20", 1 parts total | ||
bundle2-output: start emission of HG20 stream | ||||
bundle2-output: bundle parameter: | ||||
bundle2-output: start of parts | ||||
bundle2-output: bundle part: "reply:pushkey" | ||||
bundle2-output-part: "reply:pushkey" (params: 0 advisory) empty payload | ||||
bundle2-output: part 0: "REPLY:PUSHKEY" | ||||
bundle2-output: header chunk size: 43 | ||||
bundle2-output: closing payload chunk | ||||
bundle2-output: end of bundle | ||||
bundle2-input: start processing of HG20 stream | ||||
bundle2-input: reading bundle2 stream parameters | ||||
bundle2-input-bundle: no-transaction | ||||
bundle2-input: start extraction of bundle2 parts | ||||
bundle2-input: part header size: 43 | ||||
bundle2-input: part type: "REPLY:PUSHKEY" | ||||
bundle2-input: part id: "0" | ||||
bundle2-input: part parameters: 2 | ||||
bundle2-input: found a handler for part reply:pushkey | ||||
bundle2-input-part: "reply:pushkey" (params: 0 advisory) supported | ||||
bundle2-input: payload chunk size: 0 | ||||
bundle2-input: part header size: 0 | ||||
bundle2-input: end of bundle2 stream | ||||
bundle2-input-bundle: 0 parts total | ||||
Matt Mackall
|
r12969 | deleting remote bookmark W | ||
Boris Feld
|
r35031 | listing keys for "phases" | ||
Matt Mackall
|
r16038 | [1] | ||
Matt Mackall
|
r12969 | |||
Boris Feld
|
r35264 | #endif | ||
#if b2-binary | ||||
$ hg push -B W ../a --config "$TESTHOOK" --debug --config devel.bundle2.debug=yes | ||||
pushing to ../a | ||||
query 1; heads | ||||
searching for changes | ||||
all remote heads known locally | ||||
listing keys for "phases" | ||||
checking for updated bookmarks | ||||
listing keys for "bookmarks" | ||||
no changes found | ||||
bundle2-output-bundle: "HG20", 4 parts total | ||||
bundle2-output: start emission of HG20 stream | ||||
bundle2-output: bundle parameter: | ||||
bundle2-output: start of parts | ||||
bundle2-output: bundle part: "replycaps" | ||||
Boris Feld
|
r36986 | bundle2-output-part: "replycaps" 222 bytes payload | ||
Boris Feld
|
r35264 | bundle2-output: part 0: "REPLYCAPS" | ||
bundle2-output: header chunk size: 16 | ||||
Boris Feld
|
r36986 | bundle2-output: payload chunk size: 222 | ||
Boris Feld
|
r35264 | bundle2-output: closing payload chunk | ||
bundle2-output: bundle part: "check:bookmarks" | ||||
bundle2-output-part: "check:bookmarks" 23 bytes payload | ||||
bundle2-output: part 1: "CHECK:BOOKMARKS" | ||||
bundle2-output: header chunk size: 22 | ||||
bundle2-output: payload chunk size: 23 | ||||
bundle2-output: closing payload chunk | ||||
bundle2-output: bundle part: "check:phases" | ||||
bundle2-output-part: "check:phases" 48 bytes payload | ||||
bundle2-output: part 2: "CHECK:PHASES" | ||||
bundle2-output: header chunk size: 19 | ||||
bundle2-output: payload chunk size: 48 | ||||
bundle2-output: closing payload chunk | ||||
Boris Feld
|
r35265 | bundle2-output: bundle part: "bookmarks" | ||
bundle2-output-part: "bookmarks" 23 bytes payload | ||||
bundle2-output: part 3: "BOOKMARKS" | ||||
bundle2-output: header chunk size: 16 | ||||
bundle2-output: payload chunk size: 23 | ||||
Boris Feld
|
r35264 | bundle2-output: closing payload chunk | ||
bundle2-output: end of bundle | ||||
bundle2-input: start processing of HG20 stream | ||||
bundle2-input: reading bundle2 stream parameters | ||||
bundle2-input-bundle: with-transaction | ||||
bundle2-input: start extraction of bundle2 parts | ||||
bundle2-input: part header size: 16 | ||||
bundle2-input: part type: "REPLYCAPS" | ||||
bundle2-input: part id: "0" | ||||
bundle2-input: part parameters: 0 | ||||
bundle2-input: found a handler for part replycaps | ||||
bundle2-input-part: "replycaps" supported | ||||
Boris Feld
|
r36986 | bundle2-input: payload chunk size: 222 | ||
Boris Feld
|
r35264 | bundle2-input: payload chunk size: 0 | ||
Boris Feld
|
r36986 | bundle2-input-part: total payload size 222 | ||
Boris Feld
|
r35264 | bundle2-input: part header size: 22 | ||
bundle2-input: part type: "CHECK:BOOKMARKS" | ||||
bundle2-input: part id: "1" | ||||
bundle2-input: part parameters: 0 | ||||
bundle2-input: found a handler for part check:bookmarks | ||||
bundle2-input-part: "check:bookmarks" supported | ||||
bundle2-input: payload chunk size: 23 | ||||
bundle2-input: payload chunk size: 0 | ||||
bundle2-input-part: total payload size 23 | ||||
bundle2-input: part header size: 19 | ||||
bundle2-input: part type: "CHECK:PHASES" | ||||
bundle2-input: part id: "2" | ||||
bundle2-input: part parameters: 0 | ||||
bundle2-input: found a handler for part check:phases | ||||
bundle2-input-part: "check:phases" supported | ||||
bundle2-input: payload chunk size: 48 | ||||
bundle2-input: payload chunk size: 0 | ||||
bundle2-input-part: total payload size 48 | ||||
Boris Feld
|
r35265 | bundle2-input: part header size: 16 | ||
bundle2-input: part type: "BOOKMARKS" | ||||
Boris Feld
|
r35264 | bundle2-input: part id: "3" | ||
Boris Feld
|
r35265 | bundle2-input: part parameters: 0 | ||
bundle2-input: found a handler for part bookmarks | ||||
bundle2-input-part: "bookmarks" supported | ||||
bundle2-input: payload chunk size: 23 | ||||
Boris Feld
|
r35264 | bundle2-input: payload chunk size: 0 | ||
Boris Feld
|
r35265 | bundle2-input-part: total payload size 23 | ||
Boris Feld
|
r35264 | bundle2-input: part header size: 0 | ||
bundle2-input: end of bundle2 stream | ||||
bundle2-input-bundle: 3 parts total | ||||
running hook txnclose-bookmark.test: sh $TESTTMP/hook.sh | ||||
test-hook-bookmark: W: 0000000000000000000000000000000000000000 -> | ||||
Boris Feld
|
r35265 | bundle2-output-bundle: "HG20", 0 parts total | ||
Boris Feld
|
r35264 | bundle2-output: start emission of HG20 stream | ||
bundle2-output: bundle parameter: | ||||
bundle2-output: start of parts | ||||
bundle2-output: end of bundle | ||||
bundle2-input: start processing of HG20 stream | ||||
bundle2-input: reading bundle2 stream parameters | ||||
bundle2-input-bundle: no-transaction | ||||
bundle2-input: start extraction of bundle2 parts | ||||
bundle2-input: part header size: 0 | ||||
bundle2-input: end of bundle2 stream | ||||
bundle2-input-bundle: 0 parts total | ||||
deleting remote bookmark W | ||||
listing keys for "phases" | ||||
[1] | ||||
#endif | ||||
liscju
|
r28182 | export the active bookmark | ||
$ hg bookmark V | ||||
$ hg push -B . ../a | ||||
pushing to ../a | ||||
searching for changes | ||||
no changes found | ||||
exporting bookmark V | ||||
[1] | ||||
liscju
|
r29354 | exporting the active bookmark with 'push -B .' | ||
demand that one of the bookmarks is activated | ||||
$ hg update -r default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(leaving bookmark V) | ||||
$ hg push -B . ../a | ||||
abort: no active bookmark | ||||
[255] | ||||
$ hg update -r V | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
(activating bookmark V) | ||||
liscju
|
r28182 | delete the bookmark | ||
$ hg book -d V | ||||
$ hg push -B V ../a | ||||
pushing to ../a | ||||
searching for changes | ||||
no changes found | ||||
deleting remote bookmark V | ||||
[1] | ||||
$ hg up foobar | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(activating bookmark foobar) | ||||
Will Maier
|
r12303 | push/pull name that doesn't exist | ||
$ hg push -B badname ../a | ||||
Matt Mackall
|
r13368 | pushing to ../a | ||
searching for changes | ||||
Pierre-Yves David
|
r22651 | bookmark badname does not exist on the local or remote repository! | ||
Matt Mackall
|
r13368 | no changes found | ||
Matt Mackall
|
r12316 | [2] | ||
Will Maier
|
r12303 | $ hg pull -B anotherbadname ../a | ||
Matt Mackall
|
r13368 | pulling from ../a | ||
Will Maier
|
r12303 | abort: remote bookmark anotherbadname not found! | ||
Matt Mackall
|
r12316 | [255] | ||
Matt Mackall
|
r12969 | |||
divergent bookmarks | ||||
$ cd ../a | ||||
$ echo c1 > f1 | ||||
$ hg ci -Am1 | ||||
adding f1 | ||||
David M. Carr
|
r17770 | $ hg book -f @ | ||
Matt Mackall
|
r12969 | $ hg book -f X | ||
$ hg book | ||||
David M. Carr
|
r17770 | @ 1:0d2164f0ce0d | ||
David Soria Parra
|
r13388 | * X 1:0d2164f0ce0d | ||
Matt Mackall
|
r12969 | Y 0:4e3505fd9583 | ||
Z 1:0d2164f0ce0d | ||||
$ cd ../b | ||||
Yuya Nishihara
|
r35056 | $ hg up | ||
Matt Mackall
|
r12969 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Kevin Bullock
|
r16010 | updating bookmark foobar | ||
Matt Mackall
|
r12969 | $ echo c2 > f2 | ||
$ hg ci -Am2 | ||||
adding f2 | ||||
Kevin Bullock
|
r18470 | $ hg book -if @ | ||
$ hg book -if X | ||||
Matt Mackall
|
r12969 | $ hg book | ||
David M. Carr
|
r17770 | @ 1:9b140be10808 | ||
Kevin Bullock
|
r18470 | X 1:9b140be10808 | ||
Matt Mackall
|
r12969 | Y 0:4e3505fd9583 | ||
Levi Bard
|
r16697 | Z 0:4e3505fd9583 | ||
Matt Mackall
|
r12969 | foo -1:000000000000 | ||
Kevin Bullock
|
r18470 | * foobar 1:9b140be10808 | ||
Matt Mackall
|
r12969 | |||
Boris Feld
|
r34709 | $ hg pull --config paths.foo=../a foo --config "$TESTHOOK" | ||
Matt Harbison
|
r35394 | pulling from $TESTTMP/a | ||
Matt Mackall
|
r12969 | searching for changes | ||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files (+1 heads) | ||||
Mads Kiilerich
|
r18363 | divergent bookmark @ stored as @foo | ||
Matt Mackall
|
r15614 | divergent bookmark X stored as X@foo | ||
Levi Bard
|
r16697 | updating bookmark Z | ||
Denis Laxalde
|
r34662 | new changesets 0d2164f0ce0d | ||
Boris Feld
|
r34709 | test-hook-bookmark: @foo: -> 0d2164f0ce0d8f1d6f94351eba04b794909be66c | ||
test-hook-bookmark: X@foo: -> 0d2164f0ce0d8f1d6f94351eba04b794909be66c | ||||
test-hook-bookmark: Z: 4e3505fd95835d721066b76e75dbb8cc554d7f77 -> 0d2164f0ce0d8f1d6f94351eba04b794909be66c | ||||
Matt Mackall
|
r12969 | (run 'hg heads' to see heads, 'hg merge' to merge) | ||
$ hg book | ||||
David M. Carr
|
r17770 | @ 1:9b140be10808 | ||
@foo 2:0d2164f0ce0d | ||||
Kevin Bullock
|
r18470 | X 1:9b140be10808 | ||
Matt Mackall
|
r15614 | X@foo 2:0d2164f0ce0d | ||
Matt Mackall
|
r12969 | Y 0:4e3505fd9583 | ||
Levi Bard
|
r16697 | Z 2:0d2164f0ce0d | ||
Matt Mackall
|
r12969 | foo -1:000000000000 | ||
Kevin Bullock
|
r18470 | * foobar 1:9b140be10808 | ||
FUJIWARA Katsunori
|
r24353 | |||
(test that too many divergence of bookmark) | ||||
Augie Fackler
|
r32940 | $ $PYTHON $TESTDIR/seq.py 1 100 | while read i; do hg bookmarks -r 000000000000 "X@${i}"; done | ||
FUJIWARA Katsunori
|
r24353 | $ hg pull ../a | ||
pulling from ../a | ||||
searching for changes | ||||
no changes found | ||||
warning: failed to assign numbered name to divergent bookmark X | ||||
divergent bookmark @ stored as @1 | ||||
$ hg bookmarks | grep '^ X' | grep -v ':000000000000' | ||||
X 1:9b140be10808 | ||||
X@foo 2:0d2164f0ce0d | ||||
FUJIWARA Katsunori
|
r24355 | |||
(test that remotely diverged bookmarks are reused if they aren't changed) | ||||
$ hg bookmarks | grep '^ @' | ||||
@ 1:9b140be10808 | ||||
@1 2:0d2164f0ce0d | ||||
@foo 2:0d2164f0ce0d | ||||
$ hg pull ../a | ||||
pulling from ../a | ||||
searching for changes | ||||
no changes found | ||||
warning: failed to assign numbered name to divergent bookmark X | ||||
divergent bookmark @ stored as @1 | ||||
$ hg bookmarks | grep '^ @' | ||||
@ 1:9b140be10808 | ||||
@1 2:0d2164f0ce0d | ||||
@foo 2:0d2164f0ce0d | ||||
Augie Fackler
|
r32940 | $ $PYTHON $TESTDIR/seq.py 1 100 | while read i; do hg bookmarks -d "X@${i}"; done | ||
FUJIWARA Katsunori
|
r24353 | $ hg bookmarks -d "@1" | ||
Matt Mackall
|
r12969 | $ hg push -f ../a | ||
pushing to ../a | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files (+1 heads) | ||||
$ hg -R ../a book | ||||
David M. Carr
|
r17770 | @ 1:0d2164f0ce0d | ||
David Soria Parra
|
r13388 | * X 1:0d2164f0ce0d | ||
Matt Mackall
|
r12969 | Y 0:4e3505fd9583 | ||
Z 1:0d2164f0ce0d | ||||
Mads Kiilerich
|
r23543 | explicit pull should overwrite the local version (issue4439) | ||
Pierre-Yves David
|
r23199 | |||
liscju
|
r29376 | $ hg update -r X | ||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(activating bookmark X) | ||||
Boris Feld
|
r34709 | $ hg pull --config paths.foo=../a foo -B . --config "$TESTHOOK" | ||
Matt Harbison
|
r35394 | pulling from $TESTTMP/a | ||
Pierre-Yves David
|
r23199 | no changes found | ||
divergent bookmark @ stored as @foo | ||||
importing bookmark X | ||||
Boris Feld
|
r34709 | test-hook-bookmark: @foo: 0d2164f0ce0d8f1d6f94351eba04b794909be66c -> 0d2164f0ce0d8f1d6f94351eba04b794909be66c | ||
test-hook-bookmark: X: 9b140be1080824d768c5a4691a564088eede71f9 -> 0d2164f0ce0d8f1d6f94351eba04b794909be66c | ||||
Pierre-Yves David
|
r23199 | |||
reinstall state for further testing: | ||||
$ hg book -fr 9b140be10808 X | ||||
Kevin Bullock
|
r18495 | revsets should not ignore divergent bookmarks | ||
$ hg bookmark -fr 1 Z | ||||
$ hg log -r 'bookmark()' --template '{rev}:{node|short} {bookmarks}\n' | ||||
0:4e3505fd9583 Y | ||||
1:9b140be10808 @ X Z foobar | ||||
2:0d2164f0ce0d @foo X@foo | ||||
$ hg log -r 'bookmark("X@foo")' --template '{rev}:{node|short} {bookmarks}\n' | ||||
2:0d2164f0ce0d @foo X@foo | ||||
$ hg log -r 'bookmark("re:X@foo")' --template '{rev}:{node|short} {bookmarks}\n' | ||||
2:0d2164f0ce0d @foo X@foo | ||||
Levi Bard
|
r16835 | update a remote bookmark from a non-head to a head | ||
$ hg up -q Y | ||||
$ echo c3 > f2 | ||||
$ hg ci -Am3 | ||||
adding f2 | ||||
created new head | ||||
Boris Feld
|
r34709 | $ hg push ../a --config "$TESTHOOK" | ||
Levi Bard
|
r16835 | pushing to ../a | ||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files (+1 heads) | ||||
Boris Feld
|
r34709 | test-hook-bookmark: Y: 4e3505fd95835d721066b76e75dbb8cc554d7f77 -> f6fc62dde3c0771e29704af56ba4d8af77abcc2f | ||
Levi Bard
|
r16835 | updating bookmark Y | ||
$ hg -R ../a book | ||||
David M. Carr
|
r17770 | @ 1:0d2164f0ce0d | ||
Levi Bard
|
r16835 | * X 1:0d2164f0ce0d | ||
Y 3:f6fc62dde3c0 | ||||
Z 1:0d2164f0ce0d | ||||
Siddharth Agarwal
|
r18851 | update a bookmark in the middle of a client pulling changes | ||
$ cd .. | ||||
$ hg clone -q a pull-race | ||||
Pierre-Yves David
|
r25442 | |||
We want to use http because it is stateless and therefore more susceptible to | ||||
race conditions | ||||
Jun Wu
|
r28549 | $ hg serve -R pull-race -p $HGPORT -d --pid-file=pull-race.pid -E main-error.log | ||
Pierre-Yves David
|
r25442 | $ cat pull-race.pid >> $DAEMON_PIDS | ||
Matt Harbison
|
r32077 | $ cat <<EOF > $TESTTMP/out_makecommit.sh | ||
> #!/bin/sh | ||||
> hg ci -Am5 | ||||
> echo committed in pull-race | ||||
> EOF | ||||
Boris Feld
|
r34709 | $ hg clone -q http://localhost:$HGPORT/ pull-race2 --config "$TESTHOOK" | ||
test-hook-bookmark: @: -> 0d2164f0ce0d8f1d6f94351eba04b794909be66c | ||||
test-hook-bookmark: X: -> 0d2164f0ce0d8f1d6f94351eba04b794909be66c | ||||
test-hook-bookmark: Y: -> f6fc62dde3c0771e29704af56ba4d8af77abcc2f | ||||
test-hook-bookmark: Z: -> 0d2164f0ce0d8f1d6f94351eba04b794909be66c | ||||
Siddharth Agarwal
|
r18851 | $ cd pull-race | ||
$ hg up -q Y | ||||
$ echo c4 > f2 | ||||
$ hg ci -Am4 | ||||
$ echo c5 > f3 | ||||
$ cat <<EOF > .hg/hgrc | ||||
> [hooks] | ||||
Matt Harbison
|
r32077 | > outgoing.makecommit = sh $TESTTMP/out_makecommit.sh | ||
Siddharth Agarwal
|
r18851 | > EOF | ||
Pierre-Yves David
|
r25442 | |||
(new config needs a server restart) | ||||
$ cd .. | ||||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Jun Wu
|
r28549 | $ hg serve -R pull-race -p $HGPORT -d --pid-file=pull-race.pid -E main-error.log | ||
Pierre-Yves David
|
r25442 | $ cat pull-race.pid >> $DAEMON_PIDS | ||
$ cd pull-race2 | ||||
Pierre-Yves David
|
r25441 | $ hg -R $TESTTMP/pull-race book | ||
@ 1:0d2164f0ce0d | ||||
X 1:0d2164f0ce0d | ||||
* Y 4:b0a5eff05604 | ||||
Z 1:0d2164f0ce0d | ||||
Siddharth Agarwal
|
r18851 | $ hg pull | ||
Pierre-Yves David
|
r25442 | pulling from http://localhost:$HGPORT/ | ||
Siddharth Agarwal
|
r18851 | searching for changes | ||
Pierre-Yves David
|
r25352 | adding changesets | ||
Siddharth Agarwal
|
r18851 | adding manifests | ||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
updating bookmark Y | ||||
Denis Laxalde
|
r34662 | new changesets b0a5eff05604 | ||
Siddharth Agarwal
|
r18851 | (run 'hg update' to get a working copy) | ||
$ hg book | ||||
* @ 1:0d2164f0ce0d | ||||
X 1:0d2164f0ce0d | ||||
Y 4:b0a5eff05604 | ||||
Z 1:0d2164f0ce0d | ||||
Pierre-Yves David
|
r25442 | |||
Pierre-Yves David
|
r25446 | Update a bookmark right after the initial lookup -B (issue4689) | ||
$ echo c6 > ../pull-race/f3 # to be committed during the race | ||||
Matt Harbison
|
r32077 | $ cat <<EOF > $TESTTMP/listkeys_makecommit.sh | ||
> #!/bin/sh | ||||
> if hg st | grep -q M; then | ||||
> hg commit -m race | ||||
> echo committed in pull-race | ||||
> else | ||||
> exit 0 | ||||
> fi | ||||
> EOF | ||||
Pierre-Yves David
|
r25446 | $ cat <<EOF > ../pull-race/.hg/hgrc | ||
> [hooks] | ||||
> # If anything to commit, commit it right after the first key listing used | ||||
> # during lookup. This makes the commit appear before the actual getbundle | ||||
> # call. | ||||
Matt Harbison
|
r32077 | > listkeys.makecommit= sh $TESTTMP/listkeys_makecommit.sh | ||
Pierre-Yves David
|
r25446 | > EOF | ||
(new config need server restart) | ||||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Jun Wu
|
r28549 | $ hg serve -R ../pull-race -p $HGPORT -d --pid-file=../pull-race.pid -E main-error.log | ||
Pierre-Yves David
|
r25446 | $ cat ../pull-race.pid >> $DAEMON_PIDS | ||
$ hg -R $TESTTMP/pull-race book | ||||
@ 1:0d2164f0ce0d | ||||
X 1:0d2164f0ce0d | ||||
* Y 5:35d1ef0a8d1b | ||||
Z 1:0d2164f0ce0d | ||||
liscju
|
r29376 | $ hg update -r Y | ||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
(activating bookmark Y) | ||||
$ hg pull -B . | ||||
Pierre-Yves David
|
r25446 | pulling from http://localhost:$HGPORT/ | ||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
updating bookmark Y | ||||
Denis Laxalde
|
r34662 | new changesets 35d1ef0a8d1b | ||
Pierre-Yves David
|
r25446 | (run 'hg update' to get a working copy) | ||
$ hg book | ||||
liscju
|
r29376 | @ 1:0d2164f0ce0d | ||
Pierre-Yves David
|
r25446 | X 1:0d2164f0ce0d | ||
liscju
|
r29376 | * Y 5:35d1ef0a8d1b | ||
Pierre-Yves David
|
r25446 | Z 1:0d2164f0ce0d | ||
Pierre-Yves David
|
r25442 | (done with this section of the test) | ||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Siddharth Agarwal
|
r18851 | $ cd ../b | ||
Levi Bard
|
r16835 | diverging a remote bookmark fails | ||
$ hg up -q 4e3505fd9583 | ||||
$ echo c4 > f2 | ||||
$ hg ci -Am4 | ||||
adding f2 | ||||
created new head | ||||
Pierre-Yves David
|
r17864 | $ echo c5 > f2 | ||
$ hg ci -Am5 | ||||
$ hg log -G | ||||
@ 5:c922c0139ca0 5 | ||||
| | ||||
o 4:4efff6d98829 4 | ||||
| | ||||
| o 3:f6fc62dde3c0 3 | ||||
|/ | ||||
| o 2:0d2164f0ce0d 1 | ||||
|/ | ||||
| o 1:9b140be10808 2 | ||||
|/ | ||||
o 0:4e3505fd9583 test | ||||
Levi Bard
|
r16835 | $ hg book -f Y | ||
Sune Foldager
|
r17043 | |||
$ cat <<EOF > ../a/.hg/hgrc | ||||
> [web] | ||||
> push_ssl = false | ||||
> allow_push = * | ||||
> EOF | ||||
Jun Wu
|
r28549 | $ hg serve -R ../a -p $HGPORT2 -d --pid-file=../hg2.pid | ||
Sune Foldager
|
r17043 | $ cat ../hg2.pid >> $DAEMON_PIDS | ||
$ hg push http://localhost:$HGPORT2/ | ||||
pushing to http://localhost:$HGPORT2/ | ||||
Levi Bard
|
r16835 | searching for changes | ||
Stephen Lee
|
r21580 | abort: push creates new remote head c922c0139ca0 with bookmark 'Y'! | ||
timeless
|
r29973 | (merge or see 'hg help push' for details about pushing new heads) | ||
Levi Bard
|
r16835 | [255] | ||
$ hg -R ../a book | ||||
David M. Carr
|
r17770 | @ 1:0d2164f0ce0d | ||
Levi Bard
|
r16835 | * X 1:0d2164f0ce0d | ||
Y 3:f6fc62dde3c0 | ||||
Z 1:0d2164f0ce0d | ||||
Pierre-Yves David
|
r17551 | |||
Unrelated marker does not alter the decision | ||||
$ hg debugobsolete aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb | ||||
$ hg push http://localhost:$HGPORT2/ | ||||
pushing to http://localhost:$HGPORT2/ | ||||
searching for changes | ||||
Stephen Lee
|
r21580 | abort: push creates new remote head c922c0139ca0 with bookmark 'Y'! | ||
timeless
|
r29973 | (merge or see 'hg help push' for details about pushing new heads) | ||
Pierre-Yves David
|
r17551 | [255] | ||
$ hg -R ../a book | ||||
David M. Carr
|
r17770 | @ 1:0d2164f0ce0d | ||
Pierre-Yves David
|
r17551 | * X 1:0d2164f0ce0d | ||
Y 3:f6fc62dde3c0 | ||||
Z 1:0d2164f0ce0d | ||||
Update to a successor works | ||||
$ hg id --debug -r 3 | ||||
f6fc62dde3c0771e29704af56ba4d8af77abcc2f | ||||
$ hg id --debug -r 4 | ||||
Pierre-Yves David
|
r17864 | 4efff6d98829d9c824c621afd6e3f01865f5439f | ||
$ hg id --debug -r 5 | ||||
c922c0139ca03858f655e4a2af4dd02796a63969 tip Y | ||||
Pierre-Yves David
|
r17865 | $ hg debugobsolete f6fc62dde3c0771e29704af56ba4d8af77abcc2f cccccccccccccccccccccccccccccccccccccccc | ||
Boris Feld
|
r33542 | obsoleted 1 changesets | ||
Pierre-Yves David
|
r17865 | $ hg debugobsolete cccccccccccccccccccccccccccccccccccccccc 4efff6d98829d9c824c621afd6e3f01865f5439f | ||
Pierre-Yves David
|
r17551 | $ hg push http://localhost:$HGPORT2/ | ||
pushing to http://localhost:$HGPORT2/ | ||||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
Pierre-Yves David
|
r17864 | remote: added 2 changesets with 2 changes to 1 files (+1 heads) | ||
Pierre-Yves David
|
r25352 | remote: 2 new obsolescence markers | ||
r33249 | remote: obsoleted 1 changesets | |||
Pierre-Yves David
|
r17551 | updating bookmark Y | ||
$ hg -R ../a book | ||||
David M. Carr
|
r17770 | @ 1:0d2164f0ce0d | ||
Pierre-Yves David
|
r17551 | * X 1:0d2164f0ce0d | ||
Pierre-Yves David
|
r17864 | Y 5:c922c0139ca0 | ||
Pierre-Yves David
|
r17551 | Z 1:0d2164f0ce0d | ||
Matt Mackall
|
r12969 | hgweb | ||
$ cat <<EOF > .hg/hgrc | ||||
> [web] | ||||
> push_ssl = false | ||||
> allow_push = * | ||||
> EOF | ||||
$ hg serve -p $HGPORT -d --pid-file=../hg.pid -E errors.log | ||||
$ cat ../hg.pid >> $DAEMON_PIDS | ||||
$ cd ../a | ||||
Mads Kiilerich
|
r17345 | $ hg debugpushkey http://localhost:$HGPORT/ namespaces | ||
Matt Mackall
|
r12969 | bookmarks | ||
namespaces | ||||
Pierre-Yves David
|
r17551 | obsolete | ||
Mads Kiilerich <mads at kiilerich.com>
|
r18255 | phases | ||
Matt Mackall
|
r12969 | $ hg debugpushkey http://localhost:$HGPORT/ bookmarks | ||
David M. Carr
|
r17770 | @ 9b140be1080824d768c5a4691a564088eede71f9 | ||
Mads Kiilerich <mads at kiilerich.com>
|
r18255 | X 9b140be1080824d768c5a4691a564088eede71f9 | ||
Y c922c0139ca03858f655e4a2af4dd02796a63969 | ||||
Kevin Bullock
|
r18495 | Z 9b140be1080824d768c5a4691a564088eede71f9 | ||
David M. Carr
|
r17770 | foo 0000000000000000000000000000000000000000 | ||
foobar 9b140be1080824d768c5a4691a564088eede71f9 | ||||
Matt Mackall
|
r12969 | $ hg out -B http://localhost:$HGPORT/ | ||
comparing with http://localhost:$HGPORT/ | ||||
searching for changed bookmarks | ||||
FUJIWARA Katsunori
|
r24658 | @ 0d2164f0ce0d | ||
X 0d2164f0ce0d | ||||
Z 0d2164f0ce0d | ||||
foo | ||||
foobar | ||||
Matt Mackall
|
r12969 | $ hg push -B Z http://localhost:$HGPORT/ | ||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
no changes found | ||||
Pierre-Yves David
|
r22651 | updating bookmark Z | ||
Matt Mackall
|
r16038 | [1] | ||
Matt Mackall
|
r12969 | $ hg book -d Z | ||
$ hg in -B http://localhost:$HGPORT/ | ||||
comparing with http://localhost:$HGPORT/ | ||||
searching for changed bookmarks | ||||
FUJIWARA Katsunori
|
r24657 | @ 9b140be10808 | ||
X 9b140be10808 | ||||
Matt Mackall
|
r12969 | Z 0d2164f0ce0d | ||
foo 000000000000 | ||||
Matt Mackall
|
r15935 | foobar 9b140be10808 | ||
Matt Mackall
|
r12969 | $ hg pull -B Z http://localhost:$HGPORT/ | ||
pulling from http://localhost:$HGPORT/ | ||||
no changes found | ||||
David M. Carr
|
r17770 | divergent bookmark @ stored as @1 | ||
Mads Kiilerich
|
r18363 | divergent bookmark X stored as X@1 | ||
adding remote bookmark Z | ||||
David M. Carr
|
r17770 | adding remote bookmark foo | ||
Levi Bard
|
r16697 | adding remote bookmark foobar | ||
David Soria Parra
|
r13604 | $ hg clone http://localhost:$HGPORT/ cloned-bookmarks | ||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
Pierre-Yves David
|
r17864 | added 5 changesets with 5 changes to 3 files (+2 heads) | ||
Pierre-Yves David
|
r25352 | 2 new obsolescence markers | ||
Denis Laxalde
|
r34662 | new changesets 4e3505fd9583:c922c0139ca0 | ||
Adrian Buehlmann
|
r17882 | updating to bookmark @ | ||
David Soria Parra
|
r13604 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
$ hg -R cloned-bookmarks bookmarks | ||||
Thomas Arendsen Hein
|
r17870 | * @ 1:9b140be10808 | ||
David Soria Parra
|
r13604 | X 1:9b140be10808 | ||
Pierre-Yves David
|
r17864 | Y 4:c922c0139ca0 | ||
David Soria Parra
|
r13604 | Z 2:0d2164f0ce0d | ||
foo -1:000000000000 | ||||
Matt Mackall
|
r15935 | foobar 1:9b140be10808 | ||
Mads Kiilerich
|
r17346 | |||
Augie Fackler
|
r17189 | $ cd .. | ||
Mads Kiilerich
|
r30332 | Test to show result of bookmarks comparison | ||
FUJIWARA Katsunori
|
r24659 | |||
$ mkdir bmcomparison | ||||
$ cd bmcomparison | ||||
$ hg init source | ||||
$ hg -R source debugbuilddag '+2*2*3*4' | ||||
$ hg -R source log -G --template '{rev}:{node|short}' | ||||
o 4:e7bd5218ca15 | ||||
| | ||||
| o 3:6100d3090acf | ||||
|/ | ||||
| o 2:fa942426a6fd | ||||
|/ | ||||
| o 1:66f7d451a68b | ||||
|/ | ||||
o 0:1ea73414a91b | ||||
$ hg -R source bookmarks -r 0 SAME | ||||
$ hg -R source bookmarks -r 0 ADV_ON_REPO1 | ||||
$ hg -R source bookmarks -r 0 ADV_ON_REPO2 | ||||
$ hg -R source bookmarks -r 0 DIFF_ADV_ON_REPO1 | ||||
$ hg -R source bookmarks -r 0 DIFF_ADV_ON_REPO2 | ||||
$ hg -R source bookmarks -r 1 DIVERGED | ||||
$ hg clone -U source repo1 | ||||
(test that incoming/outgoing exit with 1, if there is no bookmark to | ||||
Mads Kiilerich
|
r26781 | be exchanged) | ||
FUJIWARA Katsunori
|
r24659 | |||
$ hg -R repo1 incoming -B | ||||
Matt Harbison
|
r35394 | comparing with $TESTTMP/bmcomparison/source | ||
FUJIWARA Katsunori
|
r24659 | searching for changed bookmarks | ||
no changed bookmarks found | ||||
[1] | ||||
$ hg -R repo1 outgoing -B | ||||
Matt Harbison
|
r35394 | comparing with $TESTTMP/bmcomparison/source | ||
FUJIWARA Katsunori
|
r24659 | searching for changed bookmarks | ||
no changed bookmarks found | ||||
[1] | ||||
$ hg -R repo1 bookmarks -f -r 1 ADD_ON_REPO1 | ||||
$ hg -R repo1 bookmarks -f -r 2 ADV_ON_REPO1 | ||||
$ hg -R repo1 bookmarks -f -r 3 DIFF_ADV_ON_REPO1 | ||||
$ hg -R repo1 bookmarks -f -r 3 DIFF_DIVERGED | ||||
$ hg -R repo1 -q --config extensions.mq= strip 4 | ||||
$ hg -R repo1 log -G --template '{node|short} ({bookmarks})' | ||||
o 6100d3090acf (DIFF_ADV_ON_REPO1 DIFF_DIVERGED) | ||||
| | ||||
| o fa942426a6fd (ADV_ON_REPO1) | ||||
|/ | ||||
| o 66f7d451a68b (ADD_ON_REPO1 DIVERGED) | ||||
|/ | ||||
o 1ea73414a91b (ADV_ON_REPO2 DIFF_ADV_ON_REPO2 SAME) | ||||
$ hg clone -U source repo2 | ||||
$ hg -R repo2 bookmarks -f -r 1 ADD_ON_REPO2 | ||||
$ hg -R repo2 bookmarks -f -r 1 ADV_ON_REPO2 | ||||
$ hg -R repo2 bookmarks -f -r 2 DIVERGED | ||||
$ hg -R repo2 bookmarks -f -r 4 DIFF_ADV_ON_REPO2 | ||||
$ hg -R repo2 bookmarks -f -r 4 DIFF_DIVERGED | ||||
$ hg -R repo2 -q --config extensions.mq= strip 3 | ||||
$ hg -R repo2 log -G --template '{node|short} ({bookmarks})' | ||||
o e7bd5218ca15 (DIFF_ADV_ON_REPO2 DIFF_DIVERGED) | ||||
| | ||||
| o fa942426a6fd (DIVERGED) | ||||
|/ | ||||
| o 66f7d451a68b (ADD_ON_REPO2 ADV_ON_REPO2) | ||||
|/ | ||||
o 1ea73414a91b (ADV_ON_REPO1 DIFF_ADV_ON_REPO1 SAME) | ||||
(test that difference of bookmarks between repositories are fully shown) | ||||
$ hg -R repo1 incoming -B repo2 -v | ||||
comparing with repo2 | ||||
searching for changed bookmarks | ||||
FUJIWARA Katsunori
|
r24660 | ADD_ON_REPO2 66f7d451a68b added | ||
ADV_ON_REPO2 66f7d451a68b advanced | ||||
DIFF_ADV_ON_REPO2 e7bd5218ca15 changed | ||||
DIFF_DIVERGED e7bd5218ca15 changed | ||||
DIVERGED fa942426a6fd diverged | ||||
FUJIWARA Katsunori
|
r24659 | $ hg -R repo1 outgoing -B repo2 -v | ||
comparing with repo2 | ||||
searching for changed bookmarks | ||||
FUJIWARA Katsunori
|
r24661 | ADD_ON_REPO1 66f7d451a68b added | ||
ADD_ON_REPO2 deleted | ||||
ADV_ON_REPO1 fa942426a6fd advanced | ||||
DIFF_ADV_ON_REPO1 6100d3090acf advanced | ||||
DIFF_ADV_ON_REPO2 1ea73414a91b changed | ||||
DIFF_DIVERGED 6100d3090acf changed | ||||
DIVERGED 66f7d451a68b diverged | ||||
FUJIWARA Katsunori
|
r24659 | |||
$ hg -R repo2 incoming -B repo1 -v | ||||
comparing with repo1 | ||||
searching for changed bookmarks | ||||
FUJIWARA Katsunori
|
r24660 | ADD_ON_REPO1 66f7d451a68b added | ||
ADV_ON_REPO1 fa942426a6fd advanced | ||||
DIFF_ADV_ON_REPO1 6100d3090acf changed | ||||
DIFF_DIVERGED 6100d3090acf changed | ||||
DIVERGED 66f7d451a68b diverged | ||||
FUJIWARA Katsunori
|
r24659 | $ hg -R repo2 outgoing -B repo1 -v | ||
comparing with repo1 | ||||
searching for changed bookmarks | ||||
FUJIWARA Katsunori
|
r24661 | ADD_ON_REPO1 deleted | ||
ADD_ON_REPO2 66f7d451a68b added | ||||
ADV_ON_REPO2 66f7d451a68b advanced | ||||
DIFF_ADV_ON_REPO1 1ea73414a91b changed | ||||
DIFF_ADV_ON_REPO2 e7bd5218ca15 advanced | ||||
DIFF_DIVERGED e7bd5218ca15 changed | ||||
DIVERGED fa942426a6fd diverged | ||||
FUJIWARA Katsunori
|
r24659 | |||
$ cd .. | ||||
Augie Fackler
|
r17189 | Pushing a bookmark should only push the changes required by that | ||
bookmark, not all outgoing changes: | ||||
$ hg clone http://localhost:$HGPORT/ addmarks | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
Pierre-Yves David
|
r17864 | added 5 changesets with 5 changes to 3 files (+2 heads) | ||
Pierre-Yves David
|
r25352 | 2 new obsolescence markers | ||
Denis Laxalde
|
r34662 | new changesets 4e3505fd9583:c922c0139ca0 | ||
Adrian Buehlmann
|
r17882 | updating to bookmark @ | ||
Augie Fackler
|
r17189 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
$ cd addmarks | ||||
$ echo foo > foo | ||||
$ hg add foo | ||||
$ hg commit -m 'add foo' | ||||
$ echo bar > bar | ||||
$ hg add bar | ||||
$ hg commit -m 'add bar' | ||||
$ hg co "tip^" | ||||
0 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Siddharth Agarwal
|
r21404 | (leaving bookmark @) | ||
Augie Fackler
|
r17189 | $ hg book add-foo | ||
$ hg book -r tip add-bar | ||||
Note: this push *must* push only a single changeset, as that's the point | ||||
of this test. | ||||
Pierre-Yves David
|
r17548 | $ hg push -B add-foo --traceback | ||
Augie Fackler
|
r17189 | pushing to http://localhost:$HGPORT/ | ||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files | ||||
exporting bookmark add-foo | ||||
Matt Mackall
|
r12969 | |||
Stephen Lee
|
r20184 | pushing a new bookmark on a new head does not require -f if -B is specified | ||
$ hg up -q X | ||||
$ hg book W | ||||
$ echo c5 > f2 | ||||
$ hg ci -Am5 | ||||
created new head | ||||
liscju
|
r29229 | $ hg push -B . | ||
Stephen Lee
|
r20184 | pushing to http://localhost:$HGPORT/ | ||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files (+1 heads) | ||||
exporting bookmark W | ||||
$ hg -R ../b id -r W | ||||
cc978a373a53 tip W | ||||
Matt Mackall
|
r26819 | pushing an existing but divergent bookmark with -B still requires -f | ||
Martijn Pieters
|
r28082 | $ hg clone -q . ../r | ||
Matt Mackall
|
r26819 | $ hg up -q X | ||
$ echo 1 > f2 | ||||
$ hg ci -qAml | ||||
Martijn Pieters
|
r28082 | $ cd ../r | ||
Matt Mackall
|
r26819 | $ hg up -q X | ||
$ echo 2 > f2 | ||||
$ hg ci -qAmr | ||||
$ hg push -B X | ||||
Matt Harbison
|
r35394 | pushing to $TESTTMP/addmarks | ||
Matt Mackall
|
r26819 | searching for changes | ||
remote has heads on branch 'default' that are not known locally: a2a606d9ff1b | ||||
abort: push creates new remote head 54694f811df9 with bookmark 'X'! | ||||
timeless
|
r29973 | (pull and merge or see 'hg help push' for details about pushing new heads) | ||
Matt Mackall
|
r26819 | [255] | ||
Martijn Pieters
|
r28082 | $ cd ../addmarks | ||
Matt Mackall
|
r26819 | |||
FUJIWARA Katsunori
|
r24400 | Check summary output for incoming/outgoing bookmarks | ||
$ hg bookmarks -d X | ||||
$ hg bookmarks -d Y | ||||
$ hg summary --remote | grep '^remote:' | ||||
remote: *, 2 incoming bookmarks, 1 outgoing bookmarks (glob) | ||||
Mads Kiilerich
|
r16913 | $ cd .. | ||
Gregory Szorc
|
r23082 | |||
pushing an unchanged bookmark should result in no changes | ||||
$ hg init unchanged-a | ||||
$ hg init unchanged-b | ||||
$ cd unchanged-a | ||||
$ echo initial > foo | ||||
$ hg commit -A -m initial | ||||
adding foo | ||||
$ hg bookmark @ | ||||
$ hg push -B @ ../unchanged-b | ||||
pushing to ../unchanged-b | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
exporting bookmark @ | ||||
$ hg push -B @ ../unchanged-b | ||||
pushing to ../unchanged-b | ||||
searching for changes | ||||
no changes found | ||||
[1] | ||||
Augie Fackler
|
r36807 | Pushing a really long bookmark should work fine (issue5165) | ||
=============================================== | ||||
#if b2-binary | ||||
Yuya Nishihara
|
r38625 | >>> with open('longname', 'w') as f: | ||
... f.write('wat' * 100) and None | ||||
Augie Fackler
|
r36807 | $ hg book `cat longname` | ||
$ hg push -B `cat longname` ../unchanged-b | ||||
pushing to ../unchanged-b | ||||
searching for changes | ||||
no changes found | ||||
exporting bookmark (wat){100} (re) | ||||
[1] | ||||
$ hg -R ../unchanged-b book --delete `cat longname` | ||||
Test again but forcing bundle2 exchange to make sure that doesn't regress. | ||||
$ hg push -B `cat longname` ../unchanged-b --config devel.legacy.exchange=bundle1 | ||||
pushing to ../unchanged-b | ||||
searching for changes | ||||
no changes found | ||||
exporting bookmark (wat){100} (re) | ||||
[1] | ||||
$ hg -R ../unchanged-b book --delete `cat longname` | ||||
$ hg book --delete `cat longname` | ||||
$ hg co @ | ||||
0 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(activating bookmark @) | ||||
#endif | ||||
Pierre-Yves David
|
r23416 | |||
Check hook preventing push (issue4455) | ||||
====================================== | ||||
$ hg bookmarks | ||||
* @ 0:55482a6fb4b1 | ||||
$ hg log -G | ||||
@ 0:55482a6fb4b1 initial | ||||
$ hg init ../issue4455-dest | ||||
$ hg push ../issue4455-dest # changesets only | ||||
pushing to ../issue4455-dest | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
$ cat >> .hg/hgrc << EOF | ||||
> [paths] | ||||
> local=../issue4455-dest/ | ||||
> ssh=ssh://user@dummy/issue4455-dest | ||||
> http=http://localhost:$HGPORT/ | ||||
> [ui] | ||||
Augie Fackler
|
r33286 | > ssh=$PYTHON "$TESTDIR/dummyssh" | ||
Pierre-Yves David
|
r23416 | > EOF | ||
$ cat >> ../issue4455-dest/.hg/hgrc << EOF | ||||
> [hooks] | ||||
> prepushkey=false | ||||
> [web] | ||||
> push_ssl = false | ||||
> allow_push = * | ||||
> EOF | ||||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Jun Wu
|
r28549 | $ hg serve -R ../issue4455-dest -p $HGPORT -d --pid-file=../issue4455.pid -E ../issue4455-error.log | ||
Pierre-Yves David
|
r23416 | $ cat ../issue4455.pid >> $DAEMON_PIDS | ||
Local push | ||||
---------- | ||||
Boris Feld
|
r35264 | #if b2-pushkey | ||
Pierre-Yves David
|
r23416 | $ hg push -B @ local | ||
Matt Harbison
|
r35394 | pushing to $TESTTMP/issue4455-dest | ||
Pierre-Yves David
|
r23416 | searching for changes | ||
no changes found | ||||
pushkey-abort: prepushkey hook exited with status 1 | ||||
Pierre-Yves David
|
r25501 | abort: exporting bookmark @ failed! | ||
[255] | ||||
Boris Feld
|
r35264 | |||
#endif | ||||
#if b2-binary | ||||
$ hg push -B @ local | ||||
Matt Harbison
|
r35394 | pushing to $TESTTMP/issue4455-dest | ||
Boris Feld
|
r35264 | searching for changes | ||
no changes found | ||||
Boris Feld
|
r35265 | abort: prepushkey hook exited with status 1 | ||
Boris Feld
|
r35264 | [255] | ||
#endif | ||||
Pierre-Yves David
|
r23416 | $ hg -R ../issue4455-dest/ bookmarks | ||
no bookmarks set | ||||
Using ssh | ||||
--------- | ||||
Boris Feld
|
r35264 | #if b2-pushkey | ||
Pierre-Yves David
|
r29688 | $ hg push -B @ ssh # bundle2+ | ||
Pierre-Yves David
|
r25357 | pushing to ssh://user@dummy/issue4455-dest | ||
searching for changes | ||||
no changes found | ||||
remote: pushkey-abort: prepushkey hook exited with status 1 | ||||
Pierre-Yves David
|
r25501 | abort: exporting bookmark @ failed! | ||
[255] | ||||
Boris Feld
|
r35264 | |||
Pierre-Yves David
|
r25357 | $ hg -R ../issue4455-dest/ bookmarks | ||
no bookmarks set | ||||
Pierre-Yves David
|
r29687 | $ hg push -B @ ssh --config devel.legacy.exchange=bundle1 | ||
Pierre-Yves David
|
r23416 | pushing to ssh://user@dummy/issue4455-dest | ||
searching for changes | ||||
no changes found | ||||
remote: pushkey-abort: prepushkey hook exited with status 1 | ||||
exporting bookmark @ failed! | ||||
[1] | ||||
Boris Feld
|
r35264 | |||
#endif | ||||
#if b2-binary | ||||
$ hg push -B @ ssh # bundle2+ | ||||
pushing to ssh://user@dummy/issue4455-dest | ||||
searching for changes | ||||
no changes found | ||||
Boris Feld
|
r35265 | remote: prepushkey hook exited with status 1 | ||
abort: push failed on remote | ||||
Boris Feld
|
r35264 | [255] | ||
#endif | ||||
Pierre-Yves David
|
r23416 | $ hg -R ../issue4455-dest/ bookmarks | ||
no bookmarks set | ||||
Using http | ||||
---------- | ||||
Boris Feld
|
r35264 | #if b2-pushkey | ||
Pierre-Yves David
|
r29688 | $ hg push -B @ http # bundle2+ | ||
Pierre-Yves David
|
r23416 | pushing to http://localhost:$HGPORT/ | ||
searching for changes | ||||
no changes found | ||||
remote: pushkey-abort: prepushkey hook exited with status 1 | ||||
Pierre-Yves David
|
r25501 | abort: exporting bookmark @ failed! | ||
[255] | ||||
Boris Feld
|
r35264 | |||
Pierre-Yves David
|
r23416 | $ hg -R ../issue4455-dest/ bookmarks | ||
no bookmarks set | ||||
Pierre-Yves David
|
r25357 | |||
Pierre-Yves David
|
r29687 | $ hg push -B @ http --config devel.legacy.exchange=bundle1 | ||
Pierre-Yves David
|
r25357 | pushing to http://localhost:$HGPORT/ | ||
searching for changes | ||||
no changes found | ||||
remote: pushkey-abort: prepushkey hook exited with status 1 | ||||
exporting bookmark @ failed! | ||||
[1] | ||||
Boris Feld
|
r35264 | |||
#endif | ||||
#if b2-binary | ||||
$ hg push -B @ ssh # bundle2+ | ||||
pushing to ssh://user@dummy/issue4455-dest | ||||
searching for changes | ||||
no changes found | ||||
Boris Feld
|
r35265 | remote: prepushkey hook exited with status 1 | ||
abort: push failed on remote | ||||
Boris Feld
|
r35264 | [255] | ||
#endif | ||||
Pierre-Yves David
|
r25357 | $ hg -R ../issue4455-dest/ bookmarks | ||
no bookmarks set | ||||
Boris Feld
|
r35829 | |||
$ cd .. | ||||
Test that pre-pushkey compat for bookmark works as expected (issue5777) | ||||
$ cat << EOF >> $HGRCPATH | ||||
> [ui] | ||||
> ssh="$PYTHON" "$TESTDIR/dummyssh" | ||||
> [server] | ||||
> bookmarks-pushkey-compat = yes | ||||
> EOF | ||||
$ hg init server | ||||
$ echo foo > server/a | ||||
$ hg -R server book foo | ||||
$ hg -R server commit -Am a | ||||
adding a | ||||
$ hg clone ssh://user@dummy/server client | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
new changesets 79513d0d7716 | ||||
updating to branch default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Forbid bookmark move on the server | ||||
Matt Harbison
|
r35834 | $ cat << EOF >> $TESTDIR/no-bm-move.sh | ||
> #!/bin/sh | ||||
> echo \$HG_NAMESPACE | grep -v bookmarks | ||||
> EOF | ||||
Boris Feld
|
r35829 | $ cat << EOF >> server/.hg/hgrc | ||
> [hooks] | ||||
Matt Harbison
|
r35834 | > prepushkey.no-bm-move= sh $TESTDIR/no-bm-move.sh | ||
Boris Feld
|
r35829 | > EOF | ||
pushing changeset is okay | ||||
$ echo bar >> client/a | ||||
$ hg -R client commit -m b | ||||
$ hg -R client push | ||||
pushing to ssh://user@dummy/server | ||||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files | ||||
attempt to move the bookmark is rejected | ||||
$ hg -R client book foo -r . | ||||
moving bookmark 'foo' forward from 79513d0d7716 | ||||
#if b2-pushkey | ||||
$ hg -R client push | ||||
pushing to ssh://user@dummy/server | ||||
searching for changes | ||||
no changes found | ||||
remote: pushkey-abort: prepushkey.no-bm-move hook exited with status 1 | ||||
abort: updating bookmark foo failed! | ||||
[255] | ||||
#endif | ||||
#if b2-binary | ||||
$ hg -R client push | ||||
pushing to ssh://user@dummy/server | ||||
searching for changes | ||||
no changes found | ||||
remote: prepushkey.no-bm-move hook exited with status 1 | ||||
abort: push failed on remote | ||||
[255] | ||||
#endif | ||||