test-clone-uncompressed.t
868 lines
| 29.2 KiB
| text/troff
|
Tads3Lexer
/ tests / test-clone-uncompressed.t
Kyle Lippincott
|
r38041 | #require serve no-reposimplestore no-chg | ||
Gregory Szorc
|
r27897 | |||
Boris Feld
|
r35781 | #testcases stream-legacy stream-bundle2 | ||
r39758 | #if stream-legacy | |||
Boris Feld
|
r35781 | $ cat << EOF >> $HGRCPATH | ||
r39757 | > [server] | |||
r39758 | > bundle2.stream = no | |||
Boris Feld
|
r35781 | > EOF | ||
#endif | ||||
timeless
|
r28389 | Initialize repository | ||
the status call is to check for issue5130 | ||||
Gregory Szorc
|
r27897 | $ hg init server | ||
$ cd server | ||||
$ touch foo | ||||
$ hg -q commit -A -m initial | ||||
>>> for i in range(1024): | ||||
... with open(str(i), 'wb') as fh: | ||||
Pulkit Goyal
|
r37685 | ... fh.write(b"%d" % i) and None | ||
Gregory Szorc
|
r27897 | $ hg -q commit -A -m 'add a lot of files' | ||
timeless
|
r28389 | $ hg st | ||
r48459 | ||||
add files with "tricky" name: | ||||
$ echo foo > 00changelog.i | ||||
$ echo foo > 00changelog.d | ||||
$ echo foo > 00changelog.n | ||||
$ echo foo > 00changelog-ab349180a0405010.nd | ||||
$ echo foo > 00manifest.i | ||||
$ echo foo > 00manifest.d | ||||
$ echo foo > foo.i | ||||
$ echo foo > foo.d | ||||
$ echo foo > foo.n | ||||
$ echo foo > undo.py | ||||
$ echo foo > undo.i | ||||
$ echo foo > undo.d | ||||
$ echo foo > undo.n | ||||
$ echo foo > undo.foo.i | ||||
$ echo foo > undo.foo.d | ||||
$ echo foo > undo.foo.n | ||||
$ echo foo > undo.babar | ||||
$ mkdir savanah | ||||
$ echo foo > savanah/foo.i | ||||
$ echo foo > savanah/foo.d | ||||
$ echo foo > savanah/foo.n | ||||
$ echo foo > savanah/undo.py | ||||
$ echo foo > savanah/undo.i | ||||
$ echo foo > savanah/undo.d | ||||
$ echo foo > savanah/undo.n | ||||
$ echo foo > savanah/undo.foo.i | ||||
$ echo foo > savanah/undo.foo.d | ||||
$ echo foo > savanah/undo.foo.n | ||||
$ echo foo > savanah/undo.babar | ||||
$ mkdir data | ||||
$ echo foo > data/foo.i | ||||
$ echo foo > data/foo.d | ||||
$ echo foo > data/foo.n | ||||
$ echo foo > data/undo.py | ||||
$ echo foo > data/undo.i | ||||
$ echo foo > data/undo.d | ||||
$ echo foo > data/undo.n | ||||
$ echo foo > data/undo.foo.i | ||||
$ echo foo > data/undo.foo.d | ||||
$ echo foo > data/undo.foo.n | ||||
$ echo foo > data/undo.babar | ||||
$ mkdir meta | ||||
$ echo foo > meta/foo.i | ||||
$ echo foo > meta/foo.d | ||||
$ echo foo > meta/foo.n | ||||
$ echo foo > meta/undo.py | ||||
$ echo foo > meta/undo.i | ||||
$ echo foo > meta/undo.d | ||||
$ echo foo > meta/undo.n | ||||
$ echo foo > meta/undo.foo.i | ||||
$ echo foo > meta/undo.foo.d | ||||
$ echo foo > meta/undo.foo.n | ||||
$ echo foo > meta/undo.babar | ||||
$ mkdir store | ||||
$ echo foo > store/foo.i | ||||
$ echo foo > store/foo.d | ||||
$ echo foo > store/foo.n | ||||
$ echo foo > store/undo.py | ||||
$ echo foo > store/undo.i | ||||
$ echo foo > store/undo.d | ||||
$ echo foo > store/undo.n | ||||
$ echo foo > store/undo.foo.i | ||||
$ echo foo > store/undo.foo.d | ||||
$ echo foo > store/undo.foo.n | ||||
$ echo foo > store/undo.babar | ||||
$ hg add . | ||||
adding 00changelog-ab349180a0405010.nd | ||||
adding 00changelog.d | ||||
adding 00changelog.i | ||||
adding 00changelog.n | ||||
adding 00manifest.d | ||||
adding 00manifest.i | ||||
adding data/foo.d | ||||
adding data/foo.i | ||||
adding data/foo.n | ||||
adding data/undo.babar | ||||
adding data/undo.d | ||||
adding data/undo.foo.d | ||||
adding data/undo.foo.i | ||||
adding data/undo.foo.n | ||||
adding data/undo.i | ||||
adding data/undo.n | ||||
adding data/undo.py | ||||
adding foo.d | ||||
adding foo.i | ||||
adding foo.n | ||||
adding meta/foo.d | ||||
adding meta/foo.i | ||||
adding meta/foo.n | ||||
adding meta/undo.babar | ||||
adding meta/undo.d | ||||
adding meta/undo.foo.d | ||||
adding meta/undo.foo.i | ||||
adding meta/undo.foo.n | ||||
adding meta/undo.i | ||||
adding meta/undo.n | ||||
adding meta/undo.py | ||||
adding savanah/foo.d | ||||
adding savanah/foo.i | ||||
adding savanah/foo.n | ||||
adding savanah/undo.babar | ||||
adding savanah/undo.d | ||||
adding savanah/undo.foo.d | ||||
adding savanah/undo.foo.i | ||||
adding savanah/undo.foo.n | ||||
adding savanah/undo.i | ||||
adding savanah/undo.n | ||||
adding savanah/undo.py | ||||
adding store/foo.d | ||||
adding store/foo.i | ||||
adding store/foo.n | ||||
adding store/undo.babar | ||||
adding store/undo.d | ||||
adding store/undo.foo.d | ||||
adding store/undo.foo.i | ||||
adding store/undo.foo.n | ||||
adding store/undo.i | ||||
adding store/undo.n | ||||
adding store/undo.py | ||||
adding undo.babar | ||||
adding undo.d | ||||
adding undo.foo.d | ||||
adding undo.foo.i | ||||
adding undo.foo.n | ||||
adding undo.i | ||||
adding undo.n | ||||
adding undo.py | ||||
$ hg ci -m 'add files with "tricky" name' | ||||
Gregory Szorc
|
r35807 | $ hg --config server.uncompressed=false serve -p $HGPORT -d --pid-file=hg.pid | ||
$ cat hg.pid > $DAEMON_PIDS | ||||
$ cd .. | ||||
Cannot stream clone when server.uncompressed is set | ||||
$ get-with-headers.py $LOCALIP:$HGPORT '?cmd=stream_out' | ||||
200 Script output follows | ||||
1 | ||||
#if stream-legacy | ||||
$ hg debugcapabilities http://localhost:$HGPORT | ||||
Main capabilities: | ||||
batch | ||||
branchmap | ||||
Gregory Szorc
|
r35810 | $USUAL_BUNDLE2_CAPS_SERVER$ | ||
Gregory Szorc
|
r35807 | changegroupsubset | ||
Augie Fackler
|
r35824 | compression=$BUNDLE2_COMPRESSIONS$ | ||
Gregory Szorc
|
r35807 | getbundle | ||
httpheader=1024 | ||||
httpmediatype=0.1rx,0.1tx,0.2tx | ||||
known | ||||
lookup | ||||
pushkey | ||||
unbundle=HG10GZ,HG10BZ,HG10UN | ||||
unbundlehash | ||||
Bundle2 capabilities: | ||||
HG20 | ||||
bookmarks | ||||
changegroup | ||||
01 | ||||
02 | ||||
Valentin Gatien-Baron
|
r44896 | checkheads | ||
related | ||||
Gregory Szorc
|
r35807 | digests | ||
md5 | ||||
sha1 | ||||
sha512 | ||||
error | ||||
abort | ||||
unsupportedcontent | ||||
pushraced | ||||
pushkey | ||||
hgtagsfnodes | ||||
listkeys | ||||
phases | ||||
heads | ||||
pushkey | ||||
remote-changegroup | ||||
http | ||||
https | ||||
$ hg clone --stream -U http://localhost:$HGPORT server-disabled | ||||
warning: stream clone requested but server has them disabled | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
r48459 | added 3 changesets with 1086 changes to 1086 files | |||
new changesets 96ee1d7354c4:7406a3463c3d | ||||
Gregory Szorc
|
r35807 | |||
$ get-with-headers.py $LOCALIP:$HGPORT '?cmd=getbundle' content-type --bodyfile body --hgproto 0.2 --requestheader "x-hgarg-1=bundlecaps=HG20%2Cbundle2%3DHG20%250Abookmarks%250Achangegroup%253D01%252C02%250Adigests%253Dmd5%252Csha1%252Csha512%250Aerror%253Dabort%252Cunsupportedcontent%252Cpushraced%252Cpushkey%250Ahgtagsfnodes%250Alistkeys%250Aphases%253Dheads%250Apushkey%250Aremote-changegroup%253Dhttp%252Chttps&cg=0&common=0000000000000000000000000000000000000000&heads=c17445101a72edac06facd130d14808dfbd5c7c2&stream=1" | ||||
200 Script output follows | ||||
content-type: application/mercurial-0.2 | ||||
$ f --size body --hexdump --bytes 100 | ||||
Gregory Szorc
|
r35809 | body: size=232 | ||
Gregory Szorc
|
r35807 | 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......| | ||
Gregory Szorc
|
r35809 | 0010: cf 0b 45 52 52 4f 52 3a 41 42 4f 52 54 00 00 00 |..ERROR:ABORT...| | ||
0020: 00 01 01 07 3c 04 72 6d 65 73 73 61 67 65 73 74 |....<.rmessagest| | ||||
0030: 72 65 61 6d 20 64 61 74 61 20 72 65 71 75 65 73 |ream data reques| | ||||
0040: 74 65 64 20 62 75 74 20 73 65 72 76 65 72 20 64 |ted but server d| | ||||
0050: 6f 65 73 20 6e 6f 74 20 61 6c 6c 6f 77 20 74 68 |oes not allow th| | ||||
0060: 69 73 20 66 |is f| | ||||
Gregory Szorc
|
r35807 | |||
#endif | ||||
#if stream-bundle2 | ||||
$ hg debugcapabilities http://localhost:$HGPORT | ||||
Main capabilities: | ||||
batch | ||||
branchmap | ||||
Gregory Szorc
|
r35810 | $USUAL_BUNDLE2_CAPS_SERVER$ | ||
Gregory Szorc
|
r35807 | changegroupsubset | ||
Augie Fackler
|
r35824 | compression=$BUNDLE2_COMPRESSIONS$ | ||
Gregory Szorc
|
r35807 | getbundle | ||
httpheader=1024 | ||||
httpmediatype=0.1rx,0.1tx,0.2tx | ||||
known | ||||
lookup | ||||
pushkey | ||||
unbundle=HG10GZ,HG10BZ,HG10UN | ||||
unbundlehash | ||||
Bundle2 capabilities: | ||||
HG20 | ||||
bookmarks | ||||
changegroup | ||||
01 | ||||
02 | ||||
Valentin Gatien-Baron
|
r44896 | checkheads | ||
related | ||||
Gregory Szorc
|
r35807 | digests | ||
md5 | ||||
sha1 | ||||
sha512 | ||||
error | ||||
abort | ||||
unsupportedcontent | ||||
pushraced | ||||
pushkey | ||||
hgtagsfnodes | ||||
listkeys | ||||
phases | ||||
heads | ||||
pushkey | ||||
remote-changegroup | ||||
http | ||||
https | ||||
$ hg clone --stream -U http://localhost:$HGPORT server-disabled | ||||
warning: stream clone requested but server has them disabled | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
r48459 | added 3 changesets with 1086 changes to 1086 files | |||
new changesets 96ee1d7354c4:7406a3463c3d | ||||
Gregory Szorc
|
r35807 | |||
$ get-with-headers.py $LOCALIP:$HGPORT '?cmd=getbundle' content-type --bodyfile body --hgproto 0.2 --requestheader "x-hgarg-1=bundlecaps=HG20%2Cbundle2%3DHG20%250Abookmarks%250Achangegroup%253D01%252C02%250Adigests%253Dmd5%252Csha1%252Csha512%250Aerror%253Dabort%252Cunsupportedcontent%252Cpushraced%252Cpushkey%250Ahgtagsfnodes%250Alistkeys%250Aphases%253Dheads%250Apushkey%250Aremote-changegroup%253Dhttp%252Chttps&cg=0&common=0000000000000000000000000000000000000000&heads=c17445101a72edac06facd130d14808dfbd5c7c2&stream=1" | ||||
200 Script output follows | ||||
content-type: application/mercurial-0.2 | ||||
$ f --size body --hexdump --bytes 100 | ||||
Gregory Szorc
|
r35809 | body: size=232 | ||
Gregory Szorc
|
r35807 | 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......| | ||
Gregory Szorc
|
r35809 | 0010: cf 0b 45 52 52 4f 52 3a 41 42 4f 52 54 00 00 00 |..ERROR:ABORT...| | ||
0020: 00 01 01 07 3c 04 72 6d 65 73 73 61 67 65 73 74 |....<.rmessagest| | ||||
0030: 72 65 61 6d 20 64 61 74 61 20 72 65 71 75 65 73 |ream data reques| | ||||
0040: 74 65 64 20 62 75 74 20 73 65 72 76 65 72 20 64 |ted but server d| | ||||
0050: 6f 65 73 20 6e 6f 74 20 61 6c 6c 6f 77 20 74 68 |oes not allow th| | ||||
0060: 69 73 20 66 |is f| | ||||
Gregory Szorc
|
r35807 | |||
#endif | ||||
$ killdaemons.py | ||||
$ cd server | ||||
r47745 | $ hg serve -p $HGPORT -d --pid-file=hg.pid --error errors.txt | |||
Gregory Szorc
|
r35807 | $ cat hg.pid > $DAEMON_PIDS | ||
Gregory Szorc
|
r27897 | $ cd .. | ||
Basic clone | ||||
Boris Feld
|
r35781 | #if stream-legacy | ||
Gregory Szorc
|
r34394 | $ hg clone --stream -U http://localhost:$HGPORT clone1 | ||
streaming all changes | ||||
r48459 | 1088 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (*/sec) (glob) (no-zstd !) | ||||
1088 files to transfer, 98.4 KB of data (zstd !) | ||||
transferred 98.4 KB in * seconds (*/sec) (glob) (zstd !) | ||||
Gregory Szorc
|
r34394 | searching for changes | ||
no changes found | ||||
r47745 | $ cat server/errors.txt | |||
Boris Feld
|
r35781 | #endif | ||
#if stream-bundle2 | ||||
$ hg clone --stream -U http://localhost:$HGPORT clone1 | ||||
streaming all changes | ||||
r48459 | 1091 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (*/sec) (glob) (no-zstd !) | ||||
1091 files to transfer, 98.5 KB of data (zstd !) | ||||
transferred 98.5 KB in * seconds (* */sec) (glob) (zstd !) | ||||
Boris Feld
|
r35785 | |||
$ ls -1 clone1/.hg/cache | ||||
r47032 | branch2-base | |||
branch2-immutable | ||||
Boris Feld
|
r35785 | branch2-served | ||
r47032 | branch2-served.hidden | |||
branch2-visible | ||||
branch2-visible-hidden | ||||
Boris Feld
|
r35785 | rbc-names-v1 | ||
rbc-revs-v1 | ||||
r47032 | tags2 | |||
tags2-served | ||||
r47745 | $ cat server/errors.txt | |||
Boris Feld
|
r35781 | #endif | ||
Gregory Szorc
|
r34394 | |||
Gregory Szorc
|
r35805 | getbundle requests with stream=1 are uncompressed | ||
$ get-with-headers.py $LOCALIP:$HGPORT '?cmd=getbundle' content-type --bodyfile body --hgproto '0.1 0.2 comp=zlib,none' --requestheader "x-hgarg-1=bundlecaps=HG20%2Cbundle2%3DHG20%250Abookmarks%250Achangegroup%253D01%252C02%250Adigests%253Dmd5%252Csha1%252Csha512%250Aerror%253Dabort%252Cunsupportedcontent%252Cpushraced%252Cpushkey%250Ahgtagsfnodes%250Alistkeys%250Aphases%253Dheads%250Apushkey%250Aremote-changegroup%253Dhttp%252Chttps&cg=0&common=0000000000000000000000000000000000000000&heads=c17445101a72edac06facd130d14808dfbd5c7c2&stream=1" | ||||
200 Script output follows | ||||
content-type: application/mercurial-0.2 | ||||
Simon Sapin
|
r48053 | #if no-zstd no-rust | ||
Gregory Szorc
|
r35805 | $ f --size --hex --bytes 256 body | ||
r48459 | body: size=118551 | |||
Gregory Szorc
|
r35805 | 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......| | ||
r48459 | 0010: 80 07 53 54 52 45 41 4d 32 00 00 00 00 03 00 09 |..STREAM2.......| | |||
0020: 06 09 04 0c 44 62 79 74 65 63 6f 75 6e 74 31 30 |....Dbytecount10| | ||||
0030: 33 36 39 35 66 69 6c 65 63 6f 75 6e 74 31 30 39 |3695filecount109| | ||||
0040: 31 72 65 71 75 69 72 65 6d 65 6e 74 73 64 6f 74 |1requirementsdot| | ||||
0050: 65 6e 63 6f 64 65 25 32 43 66 6e 63 61 63 68 65 |encode%2Cfncache| | ||||
0060: 25 32 43 67 65 6e 65 72 61 6c 64 65 6c 74 61 25 |%2Cgeneraldelta%| | ||||
0070: 32 43 72 65 76 6c 6f 67 76 31 25 32 43 73 70 61 |2Crevlogv1%2Cspa| | ||||
0080: 72 73 65 72 65 76 6c 6f 67 25 32 43 73 74 6f 72 |rserevlog%2Cstor| | ||||
0090: 65 00 00 80 00 73 08 42 64 61 74 61 2f 30 2e 69 |e....s.Bdata/0.i| | ||||
00a0: 00 03 00 01 00 00 00 00 00 00 00 02 00 00 00 01 |................| | ||||
00b0: 00 00 00 00 00 00 00 01 ff ff ff ff ff ff ff ff |................| | ||||
00c0: 80 29 63 a0 49 d3 23 87 bf ce fe 56 67 92 67 2c |.)c.I.#....Vg.g,| | ||||
00d0: 69 d1 ec 39 00 00 00 00 00 00 00 00 00 00 00 00 |i..9............| | ||||
00e0: 75 30 73 26 45 64 61 74 61 2f 30 30 63 68 61 6e |u0s&Edata/00chan| | ||||
00f0: 67 65 6c 6f 67 2d 61 62 33 34 39 31 38 30 61 30 |gelog-ab349180a0| | ||||
Simon Sapin
|
r48053 | #endif | ||
#if zstd no-rust | ||||
$ f --size --hex --bytes 256 body | ||||
r48459 | body: size=115738 | |||
Simon Sapin
|
r48053 | 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......| | ||
r48459 | 0010: 9a 07 53 54 52 45 41 4d 32 00 00 00 00 03 00 09 |..STREAM2.......| | |||
0020: 06 09 04 0c 5e 62 79 74 65 63 6f 75 6e 74 31 30 |....^bytecount10| | ||||
0030: 30 38 35 36 66 69 6c 65 63 6f 75 6e 74 31 30 39 |0856filecount109| | ||||
0040: 31 72 65 71 75 69 72 65 6d 65 6e 74 73 64 6f 74 |1requirementsdot| | ||||
0050: 65 6e 63 6f 64 65 25 32 43 66 6e 63 61 63 68 65 |encode%2Cfncache| | ||||
0060: 25 32 43 67 65 6e 65 72 61 6c 64 65 6c 74 61 25 |%2Cgeneraldelta%| | ||||
0070: 32 43 72 65 76 6c 6f 67 2d 63 6f 6d 70 72 65 73 |2Crevlog-compres| | ||||
0080: 73 69 6f 6e 2d 7a 73 74 64 25 32 43 72 65 76 6c |sion-zstd%2Crevl| | ||||
0090: 6f 67 76 31 25 32 43 73 70 61 72 73 65 72 65 76 |ogv1%2Csparserev| | ||||
00a0: 6c 6f 67 25 32 43 73 74 6f 72 65 00 00 80 00 73 |log%2Cstore....s| | ||||
00b0: 08 42 64 61 74 61 2f 30 2e 69 00 03 00 01 00 00 |.Bdata/0.i......| | ||||
00c0: 00 00 00 00 00 02 00 00 00 01 00 00 00 00 00 00 |................| | ||||
00d0: 00 01 ff ff ff ff ff ff ff ff 80 29 63 a0 49 d3 |...........)c.I.| | ||||
00e0: 23 87 bf ce fe 56 67 92 67 2c 69 d1 ec 39 00 00 |#....Vg.g,i..9..| | ||||
00f0: 00 00 00 00 00 00 00 00 00 00 75 30 73 26 45 64 |..........u0s&Ed| | ||||
Simon Sapin
|
r48053 | #endif | ||
Simon Sapin
|
r48054 | #if zstd rust no-dirstate-v2 | ||
Simon Sapin
|
r48053 | $ f --size --hex --bytes 256 body | ||
r48459 | body: size=115759 | |||
Simon Sapin
|
r48053 | 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......| | ||
r48459 | 0010: af 07 53 54 52 45 41 4d 32 00 00 00 00 03 00 09 |..STREAM2.......| | |||
0020: 06 09 04 0c 73 62 79 74 65 63 6f 75 6e 74 31 30 |....sbytecount10| | ||||
0030: 30 38 35 36 66 69 6c 65 63 6f 75 6e 74 31 30 39 |0856filecount109| | ||||
0040: 31 72 65 71 75 69 72 65 6d 65 6e 74 73 64 6f 74 |1requirementsdot| | ||||
0050: 65 6e 63 6f 64 65 25 32 43 66 6e 63 61 63 68 65 |encode%2Cfncache| | ||||
0060: 25 32 43 67 65 6e 65 72 61 6c 64 65 6c 74 61 25 |%2Cgeneraldelta%| | ||||
0070: 32 43 70 65 72 73 69 73 74 65 6e 74 2d 6e 6f 64 |2Cpersistent-nod| | ||||
0080: 65 6d 61 70 25 32 43 72 65 76 6c 6f 67 2d 63 6f |emap%2Crevlog-co| | ||||
0090: 6d 70 72 65 73 73 69 6f 6e 2d 7a 73 74 64 25 32 |mpression-zstd%2| | ||||
00a0: 43 72 65 76 6c 6f 67 76 31 25 32 43 73 70 61 72 |Crevlogv1%2Cspar| | ||||
00b0: 73 65 72 65 76 6c 6f 67 25 32 43 73 74 6f 72 65 |serevlog%2Cstore| | ||||
00c0: 00 00 80 00 73 08 42 64 61 74 61 2f 30 2e 69 00 |....s.Bdata/0.i.| | ||||
00d0: 03 00 01 00 00 00 00 00 00 00 02 00 00 00 01 00 |................| | ||||
00e0: 00 00 00 00 00 00 01 ff ff ff ff ff ff ff ff 80 |................| | ||||
00f0: 29 63 a0 49 d3 23 87 bf ce fe 56 67 92 67 2c 69 |)c.I.#....Vg.g,i| | ||||
Simon Sapin
|
r48053 | #endif | ||
Simon Sapin
|
r48054 | #if zstd dirstate-v2 | ||
$ f --size --hex --bytes 256 body | ||||
body: size=109449 | ||||
0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......| | ||||
0010: c0 07 53 54 52 45 41 4d 32 00 00 00 00 03 00 09 |..STREAM2.......| | ||||
0020: 05 09 04 0c 85 62 79 74 65 63 6f 75 6e 74 39 35 |.....bytecount95| | ||||
0030: 38 39 37 66 69 6c 65 63 6f 75 6e 74 31 30 33 30 |897filecount1030| | ||||
0040: 72 65 71 75 69 72 65 6d 65 6e 74 73 64 6f 74 65 |requirementsdote| | ||||
0050: 6e 63 6f 64 65 25 32 43 65 78 70 2d 64 69 72 73 |ncode%2Cexp-dirs| | ||||
0060: 74 61 74 65 2d 76 32 25 32 43 66 6e 63 61 63 68 |tate-v2%2Cfncach| | ||||
0070: 65 25 32 43 67 65 6e 65 72 61 6c 64 65 6c 74 61 |e%2Cgeneraldelta| | ||||
0080: 25 32 43 70 65 72 73 69 73 74 65 6e 74 2d 6e 6f |%2Cpersistent-no| | ||||
0090: 64 65 6d 61 70 25 32 43 72 65 76 6c 6f 67 2d 63 |demap%2Crevlog-c| | ||||
00a0: 6f 6d 70 72 65 73 73 69 6f 6e 2d 7a 73 74 64 25 |ompression-zstd%| | ||||
00b0: 32 43 72 65 76 6c 6f 67 76 31 25 32 43 73 70 61 |2Crevlogv1%2Cspa| | ||||
00c0: 72 73 65 72 65 76 6c 6f 67 25 32 43 73 74 6f 72 |rserevlog%2Cstor| | ||||
00d0: 65 00 00 80 00 73 08 42 64 61 74 61 2f 30 2e 69 |e....s.Bdata/0.i| | ||||
00e0: 00 03 00 01 00 00 00 00 00 00 00 02 00 00 00 01 |................| | ||||
00f0: 00 00 00 00 00 00 00 01 ff ff ff ff ff ff ff ff |................| | ||||
#endif | ||||
Gregory Szorc
|
r35805 | |||
Gregory Szorc
|
r34394 | --uncompressed is an alias to --stream | ||
Boris Feld
|
r35781 | #if stream-legacy | ||
Gregory Szorc
|
r34394 | $ hg clone --uncompressed -U http://localhost:$HGPORT clone1-uncompressed | ||
Gregory Szorc
|
r27897 | streaming all changes | ||
r48459 | 1088 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (*/sec) (glob) (no-zstd !) | ||||
1088 files to transfer, 98.4 KB of data (zstd !) | ||||
transferred 98.4 KB in * seconds (*/sec) (glob) (zstd !) | ||||
Gregory Szorc
|
r27897 | searching for changes | ||
no changes found | ||||
Boris Feld
|
r35781 | #endif | ||
#if stream-bundle2 | ||||
$ hg clone --uncompressed -U http://localhost:$HGPORT clone1-uncompressed | ||||
streaming all changes | ||||
r48459 | 1091 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (* */sec) (glob) (no-zstd !) | ||||
1091 files to transfer, 98.5 KB of data (zstd !) | ||||
transferred 98.5 KB in * seconds (* */sec) (glob) (zstd !) | ||||
Boris Feld
|
r35781 | #endif | ||
Gregory Szorc
|
r27897 | |||
Clone with background file closing enabled | ||||
Boris Feld
|
r35781 | #if stream-legacy | ||
Gregory Szorc
|
r34394 | $ hg --debug --config worker.backgroundclose=true --config worker.backgroundcloseminfilecount=1 clone --stream -U http://localhost:$HGPORT clone-background | grep -v adding | ||
Gregory Szorc
|
r27897 | using http://localhost:$HGPORT/ | ||
sending capabilities command | ||||
sending branchmap command | ||||
streaming all changes | ||||
sending stream_out command | ||||
r48459 | 1088 files to transfer, 101 KB of data (no-zstd !) | |||
1088 files to transfer, 98.4 KB of data (zstd !) | ||||
Gregory Szorc
|
r27897 | starting 4 threads for background file closing | ||
Yuya Nishihara
|
r39337 | updating the branch cache | ||
r48459 | transferred 101 KB in * seconds (*/sec) (glob) (no-zstd !) | |||
transferred 98.4 KB in * seconds (*/sec) (glob) (zstd !) | ||||
Gregory Szorc
|
r27897 | query 1; heads | ||
sending batch command | ||||
searching for changes | ||||
all remote heads known locally | ||||
no changes found | ||||
sending getbundle command | ||||
bundle2-input-bundle: with-transaction | ||||
bundle2-input-part: "listkeys" (params: 1 mandatory) supported | ||||
Boris Feld
|
r34323 | bundle2-input-part: "phase-heads" supported | ||
bundle2-input-part: total payload size 24 | ||||
Martin von Zweigbergk
|
r43201 | bundle2-input-bundle: 2 parts total | ||
Gregory Szorc
|
r27897 | checking for updated bookmarks | ||
r47032 | updating the branch cache | |||
Gregory Szorc
|
r40070 | (sent 5 HTTP requests and * bytes; received * bytes in responses) (glob) | ||
Boris Feld
|
r35781 | #endif | ||
#if stream-bundle2 | ||||
$ hg --debug --config worker.backgroundclose=true --config worker.backgroundcloseminfilecount=1 clone --stream -U http://localhost:$HGPORT clone-background | grep -v adding | ||||
using http://localhost:$HGPORT/ | ||||
sending capabilities command | ||||
query 1; heads | ||||
sending batch command | ||||
streaming all changes | ||||
sending getbundle command | ||||
bundle2-input-bundle: with-transaction | ||||
Gregory Szorc
|
r35806 | bundle2-input-part: "stream2" (params: 3 mandatory) supported | ||
Boris Feld
|
r35781 | applying stream bundle | ||
r48459 | 1091 files to transfer, 101 KB of data (no-zstd !) | |||
1091 files to transfer, 98.5 KB of data (zstd !) | ||||
Boris Feld
|
r35785 | starting 4 threads for background file closing | ||
Boris Feld
|
r35781 | starting 4 threads for background file closing | ||
Yuya Nishihara
|
r39337 | updating the branch cache | ||
r48459 | transferred 101 KB in * seconds (* */sec) (glob) (no-zstd !) | |||
bundle2-input-part: total payload size 118382 (no-zstd !) | ||||
transferred 98.5 KB in * seconds (* */sec) (glob) (zstd !) | ||||
bundle2-input-part: total payload size 115543 (zstd !) | ||||
Boris Feld
|
r35781 | bundle2-input-part: "listkeys" (params: 1 mandatory) supported | ||
Martin von Zweigbergk
|
r43201 | bundle2-input-bundle: 2 parts total | ||
Boris Feld
|
r35781 | checking for updated bookmarks | ||
r47032 | updating the branch cache | |||
Gregory Szorc
|
r40070 | (sent 3 HTTP requests and * bytes; received * bytes in responses) (glob) | ||
Boris Feld
|
r35781 | #endif | ||
Mads Kiilerich
|
r28517 | |||
Gregory Szorc
|
r32744 | Cannot stream clone when there are secret changesets | ||
$ hg -R server phase --force --secret -r tip | ||||
Gregory Szorc
|
r34394 | $ hg clone --stream -U http://localhost:$HGPORT secret-denied | ||
Gregory Szorc
|
r32744 | warning: stream clone requested but server has them disabled | ||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
r48459 | added 2 changesets with 1025 changes to 1025 files | |||
new changesets 96ee1d7354c4:c17445101a72 | ||||
Gregory Szorc
|
r32744 | |||
$ killdaemons.py | ||||
Streaming of secrets can be overridden by server config | ||||
$ cd server | ||||
Saurabh Singh
|
r34484 | $ hg serve --config server.uncompressedallowsecret=true -p $HGPORT -d --pid-file=hg.pid | ||
Gregory Szorc
|
r32744 | $ cat hg.pid > $DAEMON_PIDS | ||
$ cd .. | ||||
Boris Feld
|
r35781 | #if stream-legacy | ||
Gregory Szorc
|
r34394 | $ hg clone --stream -U http://localhost:$HGPORT secret-allowed | ||
Gregory Szorc
|
r32744 | streaming all changes | ||
r48459 | 1088 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (*/sec) (glob) (no-zstd !) | ||||
1088 files to transfer, 98.4 KB of data (zstd !) | ||||
transferred 98.4 KB in * seconds (*/sec) (glob) (zstd !) | ||||
Gregory Szorc
|
r32744 | searching for changes | ||
no changes found | ||||
Boris Feld
|
r35781 | #endif | ||
#if stream-bundle2 | ||||
$ hg clone --stream -U http://localhost:$HGPORT secret-allowed | ||||
streaming all changes | ||||
r48459 | 1091 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (* */sec) (glob) (no-zstd !) | ||||
1091 files to transfer, 98.5 KB of data (zstd !) | ||||
transferred 98.5 KB in * seconds (* */sec) (glob) (zstd !) | ||||
Boris Feld
|
r35781 | #endif | ||
Gregory Szorc
|
r32744 | |||
$ killdaemons.py | ||||
Verify interaction between preferuncompressed and secret presence | ||||
$ cd server | ||||
Saurabh Singh
|
r34484 | $ hg serve --config server.preferuncompressed=true -p $HGPORT -d --pid-file=hg.pid | ||
Gregory Szorc
|
r32744 | $ cat hg.pid > $DAEMON_PIDS | ||
$ cd .. | ||||
$ hg clone -U http://localhost:$HGPORT preferuncompressed-secret | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
r48459 | added 2 changesets with 1025 changes to 1025 files | |||
new changesets 96ee1d7354c4:c17445101a72 | ||||
Gregory Szorc
|
r32744 | |||
$ killdaemons.py | ||||
Clone not allowed when full bundles disabled and can't serve secrets | ||||
$ cd server | ||||
Saurabh Singh
|
r34484 | $ hg serve --config server.disablefullbundle=true -p $HGPORT -d --pid-file=hg.pid | ||
Gregory Szorc
|
r32744 | $ cat hg.pid > $DAEMON_PIDS | ||
$ cd .. | ||||
Gregory Szorc
|
r34394 | $ hg clone --stream http://localhost:$HGPORT secret-full-disabled | ||
Gregory Szorc
|
r32744 | warning: stream clone requested but server has them disabled | ||
requesting all changes | ||||
remote: abort: server has pull-based clones disabled | ||||
abort: pull failed on remote | ||||
(remove --pull if specified or upgrade Mercurial) | ||||
Martin von Zweigbergk
|
r47739 | [100] | ||
Gregory Szorc
|
r32744 | |||
Local stream clone with secrets involved | ||||
(This is just a test over behavior: if you have access to the repo's files, | ||||
there is no security so it isn't important to prevent a clone here.) | ||||
Gregory Szorc
|
r34394 | $ hg clone -U --stream server local-secret | ||
Gregory Szorc
|
r32744 | warning: stream clone requested but server has them disabled | ||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
r48459 | added 2 changesets with 1025 changes to 1025 files | |||
new changesets 96ee1d7354c4:c17445101a72 | ||||
Mads Kiilerich
|
r28517 | |||
Stream clone while repo is changing: | ||||
$ mkdir changing | ||||
$ cd changing | ||||
extension for delaying the server process so we reliably can modify the repo | ||||
while cloning | ||||
r47748 | $ cat > stream_steps.py <<EOF | |||
> import os | ||||
> import sys | ||||
> from mercurial import ( | ||||
> encoding, | ||||
> extensions, | ||||
> streamclone, | ||||
> testing, | ||||
> ) | ||||
> WALKED_FILE_1 = encoding.environ[b'HG_TEST_STREAM_WALKED_FILE_1'] | ||||
> WALKED_FILE_2 = encoding.environ[b'HG_TEST_STREAM_WALKED_FILE_2'] | ||||
> | ||||
> def _test_sync_point_walk_1(orig, repo): | ||||
> testing.write_file(WALKED_FILE_1) | ||||
> | ||||
> def _test_sync_point_walk_2(orig, repo): | ||||
> assert repo._currentlock(repo._lockref) is None | ||||
> testing.wait_file(WALKED_FILE_2) | ||||
> | ||||
> extensions.wrapfunction( | ||||
> streamclone, | ||||
> '_test_sync_point_walk_1', | ||||
> _test_sync_point_walk_1 | ||||
> ) | ||||
> extensions.wrapfunction( | ||||
> streamclone, | ||||
> '_test_sync_point_walk_2', | ||||
> _test_sync_point_walk_2 | ||||
> ) | ||||
Mads Kiilerich
|
r28517 | > EOF | ||
prepare repo with small and big file to cover both code paths in emitrevlogdata | ||||
$ hg init repo | ||||
$ touch repo/f1 | ||||
$ $TESTDIR/seq.py 50000 > repo/f2 | ||||
$ hg -R repo ci -Aqm "0" | ||||
r47748 | $ HG_TEST_STREAM_WALKED_FILE_1="$TESTTMP/sync_file_walked_1" | |||
$ export HG_TEST_STREAM_WALKED_FILE_1 | ||||
$ HG_TEST_STREAM_WALKED_FILE_2="$TESTTMP/sync_file_walked_2" | ||||
$ export HG_TEST_STREAM_WALKED_FILE_2 | ||||
$ HG_TEST_STREAM_WALKED_FILE_3="$TESTTMP/sync_file_walked_3" | ||||
$ export HG_TEST_STREAM_WALKED_FILE_3 | ||||
# $ cat << EOF >> $HGRCPATH | ||||
# > [hooks] | ||||
# > pre-clone=rm -f "$TESTTMP/sync_file_walked_*" | ||||
# > EOF | ||||
$ hg serve -R repo -p $HGPORT1 -d --error errors.log --pid-file=hg.pid --config extensions.stream_steps="$RUNTESTDIR/testlib/ext-stream-clone-steps.py" | ||||
Mads Kiilerich
|
r28517 | $ cat hg.pid >> $DAEMON_PIDS | ||
clone while modifying the repo between stating file with write lock and | ||||
actually serving file content | ||||
r47748 | $ (hg clone -q --stream -U http://localhost:$HGPORT1 clone; touch "$HG_TEST_STREAM_WALKED_FILE_3") & | |||
$ $RUNTESTDIR/testlib/wait-on-file 10 $HG_TEST_STREAM_WALKED_FILE_1 | ||||
Mads Kiilerich
|
r28517 | $ echo >> repo/f1 | ||
$ echo >> repo/f2 | ||||
r45636 | $ hg -R repo ci -m "1" --config ui.timeout.warn=-1 | |||
r47748 | $ touch $HG_TEST_STREAM_WALKED_FILE_2 | |||
$ $RUNTESTDIR/testlib/wait-on-file 10 $HG_TEST_STREAM_WALKED_FILE_3 | ||||
Mads Kiilerich
|
r28517 | $ hg -R clone id | ||
Mads Kiilerich
|
r28518 | 000000000000 | ||
r47748 | $ cat errors.log | |||
Boris Feld
|
r35765 | $ cd .. | ||
Stream repository with bookmarks | ||||
-------------------------------- | ||||
(revert introduction of secret changeset) | ||||
$ hg -R server phase --draft 'secret()' | ||||
add a bookmark | ||||
$ hg -R server bookmark -r tip some-bookmark | ||||
clone it | ||||
Boris Feld
|
r35781 | #if stream-legacy | ||
Boris Feld
|
r35765 | $ hg clone --stream http://localhost:$HGPORT with-bookmarks | ||
streaming all changes | ||||
r48459 | 1088 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (*) (glob) (no-zstd !) | ||||
1088 files to transfer, 98.4 KB of data (zstd !) | ||||
transferred 98.4 KB in * seconds (*/sec) (glob) (zstd !) | ||||
Boris Feld
|
r35765 | searching for changes | ||
no changes found | ||||
updating to branch default | ||||
r48459 | 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved | |||
Boris Feld
|
r35781 | #endif | ||
#if stream-bundle2 | ||||
$ hg clone --stream http://localhost:$HGPORT with-bookmarks | ||||
streaming all changes | ||||
r48459 | 1094 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (* */sec) (glob) (no-zstd !) | ||||
1094 files to transfer, 98.7 KB of data (zstd !) | ||||
transferred 98.7 KB in * seconds (* */sec) (glob) (zstd !) | ||||
Boris Feld
|
r35781 | updating to branch default | ||
r48459 | 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved | |||
Boris Feld
|
r35781 | #endif | ||
r48459 | $ hg verify -R with-bookmarks | |||
checking changesets | ||||
checking manifests | ||||
crosschecking files in changesets and manifests | ||||
checking files | ||||
checked 3 changesets with 1086 changes to 1086 files | ||||
Boris Feld
|
r35765 | $ hg -R with-bookmarks bookmarks | ||
r48459 | some-bookmark 2:7406a3463c3d | |||
Boris Feld
|
r35782 | |||
Stream repository with phases | ||||
----------------------------- | ||||
Clone as publishing | ||||
$ hg -R server phase -r 'all()' | ||||
0: draft | ||||
1: draft | ||||
r48459 | 2: draft | |||
Boris Feld
|
r35782 | |||
#if stream-legacy | ||||
$ hg clone --stream http://localhost:$HGPORT phase-publish | ||||
streaming all changes | ||||
r48459 | 1088 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (*) (glob) (no-zstd !) | ||||
1088 files to transfer, 98.4 KB of data (zstd !) | ||||
transferred 98.4 KB in * seconds (*/sec) (glob) (zstd !) | ||||
Boris Feld
|
r35782 | searching for changes | ||
no changes found | ||||
updating to branch default | ||||
r48459 | 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved | |||
Boris Feld
|
r35782 | #endif | ||
#if stream-bundle2 | ||||
$ hg clone --stream http://localhost:$HGPORT phase-publish | ||||
streaming all changes | ||||
r48459 | 1094 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (* */sec) (glob) (no-zstd !) | ||||
1094 files to transfer, 98.7 KB of data (zstd !) | ||||
transferred 98.7 KB in * seconds (* */sec) (glob) (zstd !) | ||||
Boris Feld
|
r35782 | updating to branch default | ||
r48459 | 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved | |||
Boris Feld
|
r35782 | #endif | ||
r48459 | $ hg verify -R phase-publish | |||
checking changesets | ||||
checking manifests | ||||
crosschecking files in changesets and manifests | ||||
checking files | ||||
checked 3 changesets with 1086 changes to 1086 files | ||||
Boris Feld
|
r35782 | $ hg -R phase-publish phase -r 'all()' | ||
0: public | ||||
1: public | ||||
r48459 | 2: public | |||
Boris Feld
|
r35782 | |||
Clone as non publishing | ||||
$ cat << EOF >> server/.hg/hgrc | ||||
> [phases] | ||||
> publish = False | ||||
> EOF | ||||
$ killdaemons.py | ||||
$ hg -R server serve -p $HGPORT -d --pid-file=hg.pid | ||||
Gregory Szorc
|
r35807 | $ cat hg.pid > $DAEMON_PIDS | ||
Boris Feld
|
r35782 | |||
#if stream-legacy | ||||
Boris Feld
|
r35823 | |||
With v1 of the stream protocol, changeset are always cloned as public. It make | ||||
stream v1 unsuitable for non-publishing repository. | ||||
Boris Feld
|
r35782 | $ hg clone --stream http://localhost:$HGPORT phase-no-publish | ||
streaming all changes | ||||
r48459 | 1088 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (* */sec) (glob) (no-zstd !) | ||||
1088 files to transfer, 98.4 KB of data (zstd !) | ||||
transferred 98.4 KB in * seconds (*/sec) (glob) (zstd !) | ||||
Boris Feld
|
r35782 | searching for changes | ||
no changes found | ||||
updating to branch default | ||||
r48459 | 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved | |||
Boris Feld
|
r35782 | $ hg -R phase-no-publish phase -r 'all()' | ||
0: public | ||||
1: public | ||||
r48459 | 2: public | |||
Boris Feld
|
r35782 | #endif | ||
#if stream-bundle2 | ||||
$ hg clone --stream http://localhost:$HGPORT phase-no-publish | ||||
streaming all changes | ||||
r48459 | 1095 files to transfer, 101 KB of data (no-zstd !) | |||
transferred 101 KB in * seconds (* */sec) (glob) (no-zstd !) | ||||
1095 files to transfer, 98.7 KB of data (zstd !) | ||||
transferred 98.7 KB in * seconds (* */sec) (glob) (zstd !) | ||||
Boris Feld
|
r35782 | updating to branch default | ||
r48459 | 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved | |||
Boris Feld
|
r35782 | $ hg -R phase-no-publish phase -r 'all()' | ||
Boris Feld
|
r35783 | 0: draft | ||
1: draft | ||||
r48459 | 2: draft | |||
Boris Feld
|
r35782 | #endif | ||
r48459 | $ hg verify -R phase-no-publish | |||
checking changesets | ||||
checking manifests | ||||
crosschecking files in changesets and manifests | ||||
checking files | ||||
checked 3 changesets with 1086 changes to 1086 files | ||||
Boris Feld
|
r35782 | |||
$ killdaemons.py | ||||
r40434 | ||||
#if stream-legacy | ||||
With v1 of the stream protocol, changeset are always cloned as public. There's | ||||
no obsolescence markers exchange in stream v1. | ||||
#endif | ||||
#if stream-bundle2 | ||||
Stream repository with obsolescence | ||||
----------------------------------- | ||||
Clone non-publishing with obsolescence | ||||
$ cat >> $HGRCPATH << EOF | ||||
> [experimental] | ||||
> evolution=all | ||||
> EOF | ||||
$ cd server | ||||
$ echo foo > foo | ||||
$ hg -q commit -m 'about to be pruned' | ||||
$ hg debugobsolete `hg log -r . -T '{node}'` -d '0 0' -u test --record-parents | ||||
r43163 | 1 new obsolescence markers | |||
r40434 | obsoleted 1 changesets | |||
$ hg up null -q | ||||
$ hg log -T '{rev}: {phase}\n' | ||||
r48459 | 2: draft | |||
r40434 | 1: draft | |||
0: draft | ||||
$ hg serve -p $HGPORT -d --pid-file=hg.pid | ||||
$ cat hg.pid > $DAEMON_PIDS | ||||
$ cd .. | ||||
$ hg clone -U --stream http://localhost:$HGPORT with-obsolescence | ||||
streaming all changes | ||||
r48459 | 1096 files to transfer, 102 KB of data (no-zstd !) | |||
transferred 102 KB in * seconds (* */sec) (glob) (no-zstd !) | ||||
1096 files to transfer, 99.1 KB of data (zstd !) | ||||
transferred 99.1 KB in * seconds (* */sec) (glob) (zstd !) | ||||
r40434 | $ hg -R with-obsolescence log -T '{rev}: {phase}\n' | |||
r48459 | 2: draft | |||
r40434 | 1: draft | |||
0: draft | ||||
$ hg debugobsolete -R with-obsolescence | ||||
r48459 | aa82d3f59e13f41649d8ba3324e1ac8849ba78e7 0 {7406a3463c3de22c4288b4306d199705369a285a} (Thu Jan 01 00:00:00 1970 +0000) {'user': 'test'} | |||
$ hg verify -R with-obsolescence | ||||
checking changesets | ||||
checking manifests | ||||
crosschecking files in changesets and manifests | ||||
checking files | ||||
checked 4 changesets with 1087 changes to 1086 files | ||||
r40434 | ||||
r40435 | $ hg clone -U --stream --config experimental.evolution=0 http://localhost:$HGPORT with-obsolescence-no-evolution | |||
streaming all changes | ||||
remote: abort: server has obsolescence markers, but client cannot receive them via stream clone | ||||
abort: pull failed on remote | ||||
Martin von Zweigbergk
|
r47739 | [100] | ||
r40435 | ||||
r40434 | $ killdaemons.py | |||
#endif | ||||