##// END OF EJS Templates
branching: merge default into stable...
branching: merge default into stable This mark the start of the 5.9 freeze.

File last commit:

r48459:f030c7d2 default
r48559:d7515d29 merge 5.9rc0 stable
Show More
test-clone-uncompressed.t
868 lines | 29.2 KiB | text/troff | Tads3Lexer
/ tests / test-clone-uncompressed.t
Kyle Lippincott
tests: mark tests that fail when using chg as #require no-chg...
r38041 #require serve no-reposimplestore no-chg
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
r27897
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #testcases stream-legacy stream-bundle2
av6
bundle2: make server.bundle2.stream default to True...
r39758 #if stream-legacy
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 $ cat << EOF >> $HGRCPATH
av6
bundle2: graduate bundle2.stream option from experimental to server section...
r39757 > [server]
av6
bundle2: make server.bundle2.stream default to True...
r39758 > bundle2.stream = no
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 > EOF
#endif
timeless
bdiff: (pure) support array.array arrays (issue5130)
r28389 Initialize repository
the status call is to check for issue5130
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
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
py3: use b"%d" instead of str() to convert int to bytes...
r37685 ... fh.write(b"%d" % i) and None
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
r27897 $ hg -q commit -A -m 'add a lot of files'
timeless
bdiff: (pure) support array.array arrays (issue5130)
r28389 $ hg st
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
tests: add more testing around server.uncompressed...
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
bundle2: always advertise client support for stream parts...
r35810 $USUAL_BUNDLE2_CAPS_SERVER$
Gregory Szorc
tests: add more testing around server.uncompressed...
r35807 changegroupsubset
Augie Fackler
tests: add a pattern to fix --pure tests...
r35824 compression=$BUNDLE2_COMPRESSIONS$
Gregory Szorc
tests: add more testing around server.uncompressed...
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
exchange: turn on option that makes concurrent pushes work better...
r44896 checkheads
related
Gregory Szorc
tests: add more testing around server.uncompressed...
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
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 added 3 changesets with 1086 changes to 1086 files
new changesets 96ee1d7354c4:7406a3463c3d
Gregory Szorc
tests: add more testing around server.uncompressed...
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
exchange: don't send stream data when server.uncompressed is set...
r35809 body: size=232
Gregory Szorc
tests: add more testing around server.uncompressed...
r35807 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......|
Gregory Szorc
exchange: don't send stream data when server.uncompressed is set...
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
tests: add more testing around server.uncompressed...
r35807
#endif
#if stream-bundle2
$ hg debugcapabilities http://localhost:$HGPORT
Main capabilities:
batch
branchmap
Gregory Szorc
bundle2: always advertise client support for stream parts...
r35810 $USUAL_BUNDLE2_CAPS_SERVER$
Gregory Szorc
tests: add more testing around server.uncompressed...
r35807 changegroupsubset
Augie Fackler
tests: add a pattern to fix --pure tests...
r35824 compression=$BUNDLE2_COMPRESSIONS$
Gregory Szorc
tests: add more testing around server.uncompressed...
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
exchange: turn on option that makes concurrent pushes work better...
r44896 checkheads
related
Gregory Szorc
tests: add more testing around server.uncompressed...
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
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 added 3 changesets with 1086 changes to 1086 files
new changesets 96ee1d7354c4:7406a3463c3d
Gregory Szorc
tests: add more testing around server.uncompressed...
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
exchange: don't send stream data when server.uncompressed is set...
r35809 body: size=232
Gregory Szorc
tests: add more testing around server.uncompressed...
r35807 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......|
Gregory Szorc
exchange: don't send stream data when server.uncompressed is set...
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
tests: add more testing around server.uncompressed...
r35807
#endif
$ killdaemons.py
$ cd server
streamclone: check the errors log in tests...
r47745 $ hg serve -p $HGPORT -d --pid-file=hg.pid --error errors.txt
Gregory Szorc
tests: add more testing around server.uncompressed...
r35807 $ cat hg.pid > $DAEMON_PIDS
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
r27897 $ cd ..
Basic clone
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #if stream-legacy
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone --stream -U http://localhost:$HGPORT clone1
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
commands: rename clone --uncompressed to --stream and document...
r34394 searching for changes
no changes found
streamclone: check the errors log in tests...
r47745 $ cat server/errors.txt
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #endif
#if stream-bundle2
$ hg clone --stream -U http://localhost:$HGPORT clone1
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: also stream caches to the client...
r35785
$ ls -1 clone1/.hg/cache
clone: make sure we warm the cache after a clone...
r47032 branch2-base
branch2-immutable
Boris Feld
streamclone: also stream caches to the client...
r35785 branch2-served
clone: make sure we warm the cache after a clone...
r47032 branch2-served.hidden
branch2-visible
branch2-visible-hidden
Boris Feld
streamclone: also stream caches to the client...
r35785 rbc-names-v1
rbc-revs-v1
clone: make sure we warm the cache after a clone...
r47032 tags2
tags2-served
streamclone: check the errors log in tests...
r47745 $ cat server/errors.txt
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #endif
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394
Gregory Szorc
exchange: send bundle2 stream clones uncompressed...
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
tests: More cleanly separate expected hexdump output...
r48053 #if no-zstd no-rust
Gregory Szorc
exchange: send bundle2 stream clones uncompressed...
r35805 $ f --size --hex --bytes 256 body
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 body: size=118551
Gregory Szorc
exchange: send bundle2 stream clones uncompressed...
r35805 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......|
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
tests: More cleanly separate expected hexdump output...
r48053 #endif
#if zstd no-rust
$ f --size --hex --bytes 256 body
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 body: size=115738
Simon Sapin
tests: More cleanly separate expected hexdump output...
r48053 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......|
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
tests: More cleanly separate expected hexdump output...
r48053 #endif
Simon Sapin
dirstate-v2: Update the expected output of some tests for new requirement...
r48054 #if zstd rust no-dirstate-v2
Simon Sapin
tests: More cleanly separate expected hexdump output...
r48053 $ f --size --hex --bytes 256 body
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 body: size=115759
Simon Sapin
tests: More cleanly separate expected hexdump output...
r48053 0000: 04 6e 6f 6e 65 48 47 32 30 00 00 00 00 00 00 00 |.noneHG20.......|
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
tests: More cleanly separate expected hexdump output...
r48053 #endif
Simon Sapin
dirstate-v2: Update the expected output of some tests for new requirement...
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
exchange: send bundle2 stream clones uncompressed...
r35805
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 --uncompressed is an alias to --stream
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #if stream-legacy
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone --uncompressed -U http://localhost:$HGPORT clone1-uncompressed
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
r27897 streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: use backgroundfilecloser (issue4889)...
r27897 searching for changes
no changes found
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #endif
#if stream-bundle2
$ hg clone --uncompressed -U http://localhost:$HGPORT clone1-uncompressed
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: add support for bundle2 based stream clone...
r35781 #endif
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
r27897
Clone with background file closing enabled
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #if stream-legacy
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg --debug --config worker.backgroundclose=true --config worker.backgroundcloseminfilecount=1 clone --stream -U http://localhost:$HGPORT clone-background | grep -v adding
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
r27897 using http://localhost:$HGPORT/
sending capabilities command
sending branchmap command
streaming all changes
sending stream_out command
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 1088 files to transfer, 101 KB of data (no-zstd !)
1088 files to transfer, 98.4 KB of data (zstd !)
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
r27897 starting 4 threads for background file closing
Yuya Nishihara
transaction: remember original len(repo) instead of tracking added revs (API)...
r39337 updating the branch cache
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 transferred 101 KB in * seconds (*/sec) (glob) (no-zstd !)
transferred 98.4 KB in * seconds (*/sec) (glob) (zstd !)
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
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
pull: use 'phase-heads' to retrieve phase information...
r34323 bundle2-input-part: "phase-heads" supported
bundle2-input-part: total payload size 24
Martin von Zweigbergk
bundle2: fix an off-by-one in debug message of number of parts...
r43201 bundle2-input-bundle: 2 parts total
Gregory Szorc
streamclone: use backgroundfilecloser (issue4889)...
r27897 checking for updated bookmarks
clone: make sure we warm the cache after a clone...
r47032 updating the branch cache
Gregory Szorc
httppeer: report http statistics...
r40070 (sent 5 HTTP requests and * bytes; received * bytes in responses) (glob)
Boris Feld
streamclone: add support for bundle2 based stream clone...
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
bundle2: move version of stream clone into part name...
r35806 bundle2-input-part: "stream2" (params: 3 mandatory) supported
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 applying stream bundle
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 1091 files to transfer, 101 KB of data (no-zstd !)
1091 files to transfer, 98.5 KB of data (zstd !)
Boris Feld
streamclone: also stream caches to the client...
r35785 starting 4 threads for background file closing
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 starting 4 threads for background file closing
Yuya Nishihara
transaction: remember original len(repo) instead of tracking added revs (API)...
r39337 updating the branch cache
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: add support for bundle2 based stream clone...
r35781 bundle2-input-part: "listkeys" (params: 1 mandatory) supported
Martin von Zweigbergk
bundle2: fix an off-by-one in debug message of number of parts...
r43201 bundle2-input-bundle: 2 parts total
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 checking for updated bookmarks
clone: make sure we warm the cache after a clone...
r47032 updating the branch cache
Gregory Szorc
httppeer: report http statistics...
r40070 (sent 3 HTTP requests and * bytes; received * bytes in responses) (glob)
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #endif
Mads Kiilerich
tests: add test of stream clone of repo that is changing...
r28517
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744 Cannot stream clone when there are secret changesets
$ hg -R server phase --force --secret -r tip
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone --stream -U http://localhost:$HGPORT secret-denied
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744 warning: stream clone requested but server has them disabled
requesting all changes
adding changesets
adding manifests
adding file changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 added 2 changesets with 1025 changes to 1025 files
new changesets 96ee1d7354c4:c17445101a72
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744
$ killdaemons.py
Streaming of secrets can be overridden by server config
$ cd server
Saurabh Singh
serve: make tests compatible with chg...
r34484 $ hg serve --config server.uncompressedallowsecret=true -p $HGPORT -d --pid-file=hg.pid
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744 $ cat hg.pid > $DAEMON_PIDS
$ cd ..
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #if stream-legacy
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone --stream -U http://localhost:$HGPORT secret-allowed
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744 streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: consider secret changesets (BC) (issue5589)...
r32744 searching for changes
no changes found
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #endif
#if stream-bundle2
$ hg clone --stream -U http://localhost:$HGPORT secret-allowed
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: add support for bundle2 based stream clone...
r35781 #endif
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744
$ killdaemons.py
Verify interaction between preferuncompressed and secret presence
$ cd server
Saurabh Singh
serve: make tests compatible with chg...
r34484 $ hg serve --config server.preferuncompressed=true -p $HGPORT -d --pid-file=hg.pid
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
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
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 added 2 changesets with 1025 changes to 1025 files
new changesets 96ee1d7354c4:c17445101a72
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744
$ killdaemons.py
Clone not allowed when full bundles disabled and can't serve secrets
$ cd server
Saurabh Singh
serve: make tests compatible with chg...
r34484 $ hg serve --config server.disablefullbundle=true -p $HGPORT -d --pid-file=hg.pid
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744 $ cat hg.pid > $DAEMON_PIDS
$ cd ..
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone --stream http://localhost:$HGPORT secret-full-disabled
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
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
errors: raise RemoteError in some places in exchange.py...
r47739 [100]
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
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
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone -U --stream server local-secret
Gregory Szorc
streamclone: consider secret changesets (BC) (issue5589)...
r32744 warning: stream clone requested but server has them disabled
requesting all changes
adding changesets
adding manifests
adding file changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 added 2 changesets with 1025 changes to 1025 files
new changesets 96ee1d7354c4:c17445101a72
Mads Kiilerich
tests: add test of stream clone of repo that is changing...
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
streamclone: remove sleep based "synchronisation" in tests...
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
tests: add test of stream clone of repo that is changing...
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"
streamclone: remove sleep based "synchronisation" in tests...
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
tests: add test of stream clone of repo that is changing...
r28517 $ cat hg.pid >> $DAEMON_PIDS
clone while modifying the repo between stating file with write lock and
actually serving file content
streamclone: remove sleep based "synchronisation" in tests...
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
tests: add test of stream clone of repo that is changing...
r28517 $ echo >> repo/f1
$ echo >> repo/f2
test-clone-uncompressed: use config to silence the lock warning...
r45636 $ hg -R repo ci -m "1" --config ui.timeout.warn=-1
streamclone: remove sleep based "synchronisation" in tests...
r47748 $ touch $HG_TEST_STREAM_WALKED_FILE_2
$ $RUNTESTDIR/testlib/wait-on-file 10 $HG_TEST_STREAM_WALKED_FILE_3
Mads Kiilerich
tests: add test of stream clone of repo that is changing...
r28517 $ hg -R clone id
Mads Kiilerich
streamclone: fix error when store files grow while stream cloning...
r28518 000000000000
streamclone: remove sleep based "synchronisation" in tests...
r47748 $ cat errors.log
Boris Feld
stream: add a test showing we also clone bookmarks...
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
streamclone: add support for bundle2 based stream clone...
r35781 #if stream-legacy
Boris Feld
stream: add a test showing we also clone bookmarks...
r35765 $ hg clone --stream http://localhost:$HGPORT with-bookmarks
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
stream: add a test showing we also clone bookmarks...
r35765 searching for changes
no changes found
updating to branch default
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #endif
#if stream-bundle2
$ hg clone --stream http://localhost:$HGPORT with-bookmarks
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: add support for bundle2 based stream clone...
r35781 updating to branch default
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved
Boris Feld
streamclone: add support for bundle2 based stream clone...
r35781 #endif
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
stream: add a test showing we also clone bookmarks...
r35765 $ hg -R with-bookmarks bookmarks
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 some-bookmark 2:7406a3463c3d
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782
Stream repository with phases
-----------------------------
Clone as publishing
$ hg -R server phase -r 'all()'
0: draft
1: draft
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 2: draft
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782
#if stream-legacy
$ hg clone --stream http://localhost:$HGPORT phase-publish
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: tests phase exchange during stream clone...
r35782 searching for changes
no changes found
updating to branch default
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782 #endif
#if stream-bundle2
$ hg clone --stream http://localhost:$HGPORT phase-publish
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: tests phase exchange during stream clone...
r35782 updating to branch default
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782 #endif
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: tests phase exchange during stream clone...
r35782 $ hg -R phase-publish phase -r 'all()'
0: public
1: public
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 2: public
Boris Feld
streamclone: tests phase exchange during stream clone...
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
tests: add more testing around server.uncompressed...
r35807 $ cat hg.pid > $DAEMON_PIDS
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782
#if stream-legacy
Boris Feld
streamclone: add a comment about non-publishing being broken with v1...
r35823
With v1 of the stream protocol, changeset are always cloned as public. It make
stream v1 unsuitable for non-publishing repository.
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782 $ hg clone --stream http://localhost:$HGPORT phase-no-publish
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: tests phase exchange during stream clone...
r35782 searching for changes
no changes found
updating to branch default
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782 $ hg -R phase-no-publish phase -r 'all()'
0: public
1: public
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 2: public
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782 #endif
#if stream-bundle2
$ hg clone --stream http://localhost:$HGPORT phase-no-publish
streaming all changes
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: tests phase exchange during stream clone...
r35782 updating to branch default
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 1086 files updated, 0 files merged, 0 files removed, 0 files unresolved
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782 $ hg -R phase-no-publish phase -r 'all()'
Boris Feld
streamclone: add support for cloning non append-only file...
r35783 0: draft
1: draft
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 2: draft
Boris Feld
streamclone: tests phase exchange during stream clone...
r35782 #endif
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
streamclone: tests phase exchange during stream clone...
r35782
$ killdaemons.py
av6
streamclone: include obsstore file into stream bundle if client can read it
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
debugobsolete: also issue the "new obsmarkers" messsage...
r43163 1 new obsolescence markers
av6
streamclone: include obsstore file into stream bundle if client can read it
r40434 obsoleted 1 changesets
$ hg up null -q
$ hg log -T '{rev}: {phase}\n'
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 2: draft
av6
streamclone: include obsstore file into stream bundle if client can read it
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
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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 !)
av6
streamclone: include obsstore file into stream bundle if client can read it
r40434 $ hg -R with-obsolescence log -T '{rev}: {phase}\n'
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
r48459 2: draft
av6
streamclone: include obsstore file into stream bundle if client can read it
r40434 1: draft
0: draft
$ hg debugobsolete -R with-obsolescence
walk: no longer ignore revlogs of files starting with `undo.` (issue6542)...
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
av6
streamclone: include obsstore file into stream bundle if client can read it
r40434
av6
streamclone: abort when client needs to handle obsmarkers, but doesn't...
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
errors: raise RemoteError in some places in exchange.py...
r47739 [100]
av6
streamclone: abort when client needs to handle obsmarkers, but doesn't...
r40435
av6
streamclone: include obsstore file into stream bundle if client can read it
r40434 $ killdaemons.py
#endif