##// END OF EJS Templates
test-transaction-safety: glog out irrelevant flag...
test-transaction-safety: glog out irrelevant flag The test is focussing on the inline flag, so we glob out the other to highlight that fact and prevent noise in the future.

File last commit:

r51596:af60de30 default
r52073:2e0b2a38 default
Show More
test-clonebundles.t
852 lines | 30.0 KiB | text/troff | Tads3Lexer
/ tests / test-clonebundles.t
Kyle Lippincott
tests: mark tests that fail when using chg as #require no-chg...
r38041 #require no-reposimplestore no-chg
Gregory Szorc
tests: disable tests for advanced clone features with simple store...
r37367
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 Set up a server
$ hg init server
$ cd server
$ cat >> .hg/hgrc << EOF
> [extensions]
> clonebundles =
> EOF
$ touch foo
$ hg -q commit -A -m 'add foo'
$ touch bar
$ hg -q commit -A -m 'add bar'
$ hg serve -d -p $HGPORT --pid-file hg.pid --accesslog access.log
$ cat hg.pid >> $DAEMON_PIDS
$ cd ..
Missing manifest should not result in server lookup
$ hg --verbose clone -U http://localhost:$HGPORT no-manifest
requesting all changes
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 53245c60e682:aaff8d2ffbbf
Gregory Szorc
httppeer: report http statistics...
r40070 (sent 3 HTTP requests and * bytes; received * bytes in responses) (glob)
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623
Gregory Szorc
exchange: make clone bundles non-experimental and enabled by default...
r27738 $ cat server/access.log
Gregory Szorc
httppeer: only advertise partial-pull if capabilities are known...
r37574 * - - [*] "GET /?cmd=capabilities HTTP/1.1" 200 - (glob)
Joerg Sonnenberger
wireproto: support for pullbundles...
r37516 $LOCALIP - - [$LOGDATE$] "GET /?cmd=batch HTTP/1.1" 200 - x-hgarg-1:cmds=heads+%3Bknown+nodes%3D x-hgproto-1:0.1 0.2 comp=$USUAL_COMPRESSIONS$ partial-pull (glob)
$LOCALIP - - [$LOGDATE$] "GET /?cmd=getbundle HTTP/1.1" 200 - x-hgarg-1:bookmarks=1&$USUAL_BUNDLE_CAPS$&cg=1&common=0000000000000000000000000000000000000000&heads=aaff8d2ffbbf07a46dd1f05d8ae7877e3f56e2a2&listkeys=bookmarks&phases=1 x-hgproto-1:0.1 0.2 comp=$USUAL_COMPRESSIONS$ partial-pull (glob)
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623
Empty manifest file results in retrieval
(the extension only checks if the manifest file exists)
$ touch server/.hg/clonebundles.manifest
$ hg --verbose clone -U http://localhost:$HGPORT empty-manifest
no clone bundles available on remote; falling back to regular clone
requesting all changes
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 53245c60e682:aaff8d2ffbbf
Gregory Szorc
httppeer: report http statistics...
r40070 (sent 4 HTTP requests and * bytes; received * bytes in responses) (glob)
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623
Manifest file with invalid URL aborts
$ echo 'http://does.not.exist/bundle.hg' > server/.hg/clonebundles.manifest
$ hg clone http://localhost:$HGPORT 404-url
applying clone bundle from http://does.not.exist/bundle.hg
Augie Fackler
tests: handle new error string from FreeBSD for dns entry not resolving...
r45118 error fetching bundle: (.* not known|(\[Errno -?\d+] )?([Nn]o address associated with (host)?name|Temporary failure in name resolution|Name does not resolve)) (re) (no-windows !)
Matt Harbison
tests: glob over a difference between Windows 7 and Window 10...
r40407 error fetching bundle: [Errno 1100*] getaddrinfo failed (glob) (windows !)
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 abort: error applying bundle
Gregory Szorc
exchange: make clone bundles non-experimental and enabled by default...
r27738 (if this error persists, consider contacting the server operator or disable clone bundles via "--config ui.clonebundles=false")
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 [255]
Mathias De Mare
clonebundles: demonstrate bad behaviour when unknown scheme is present
r51434 Manifest file with URL with unknown scheme skips the URL
$ echo 'weirdscheme://does.not.exist/bundle.hg' > server/.hg/clonebundles.manifest
$ hg clone http://localhost:$HGPORT unknown-scheme
Mathias De Mare
clonebundles: filter out invalid schemes instead of failing on them...
r51435 no compatible clone bundles available on server; falling back to regular clone
(you may want to report this to the server operator)
requesting all changes
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
new changesets 53245c60e682:aaff8d2ffbbf
updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Mathias De Mare
clonebundles: demonstrate bad behaviour when unknown scheme is present
r51434
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 Server is not running aborts
$ echo "http://localhost:$HGPORT1/bundle.hg" > server/.hg/clonebundles.manifest
$ hg clone http://localhost:$HGPORT server-not-runner
applying clone bundle from http://localhost:$HGPORT1/bundle.hg
Mathias De Mare
tests: fix regression tests failing on CentOS 7...
r41760 error fetching bundle: (.* refused.*|Protocol not supported|(.* )?\$EADDRNOTAVAIL\$|.* No route to host) (re)
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 abort: error applying bundle
Gregory Szorc
exchange: make clone bundles non-experimental and enabled by default...
r27738 (if this error persists, consider contacting the server operator or disable clone bundles via "--config ui.clonebundles=false")
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 [255]
Server returns 404
Matt Harbison
tests: quote $PYTHON for Windows...
r33335 $ "$PYTHON" $TESTDIR/dumbhttp.py -p $HGPORT1 --pid http.pid
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 $ cat http.pid >> $DAEMON_PIDS
$ hg clone http://localhost:$HGPORT running-404
applying clone bundle from http://localhost:$HGPORT1/bundle.hg
HTTP error fetching bundle: HTTP Error 404: File not found
abort: error applying bundle
Gregory Szorc
exchange: make clone bundles non-experimental and enabled by default...
r27738 (if this error persists, consider contacting the server operator or disable clone bundles via "--config ui.clonebundles=false")
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 [255]
We can override failure to fall back to regular clone
$ hg --config ui.clonebundlefallback=true clone -U http://localhost:$HGPORT 404-fallback
applying clone bundle from http://localhost:$HGPORT1/bundle.hg
HTTP error fetching bundle: HTTP Error 404: File not found
falling back to normal clone
requesting all changes
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 53245c60e682:aaff8d2ffbbf
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623
Bundle with partial content works
Gregory Szorc
clonebundles: filter on bundle specification...
r26644 $ hg -R server bundle --type gzip-v1 --base null -r 53245c60e682 partial.hg
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 1 changesets found
Gregory Szorc
clonebundles: filter on bundle specification...
r26644 We verify exact bundle content as an extra check against accidental future
changes. If this output changes, we could break old clients.
$ f --size --hexdump partial.hg
Mike Hommey
mdiff: don't emit a diff header for empty trivial deltas...
r27711 partial.hg: size=207
Gregory Szorc
clonebundles: filter on bundle specification...
r26644 0000: 48 47 31 30 47 5a 78 9c 63 60 60 98 17 ac 12 93 |HG10GZx.c``.....|
0010: f0 ac a9 23 45 70 cb bf 0d 5f 59 4e 4a 7f 79 21 |...#Ep..._YNJ.y!|
0020: 9b cc 40 24 20 a0 d7 ce 2c d1 38 25 cd 24 25 d5 |..@$ ...,.8%.$%.|
0030: d8 c2 22 cd 38 d9 24 cd 22 d5 c8 22 cd 24 cd 32 |..".8.$."..".$.2|
0040: d1 c2 d0 c4 c8 d2 32 d1 38 39 29 c9 34 cd d4 80 |......2.89).4...|
0050: ab 24 b5 b8 84 cb 40 c1 80 2b 2d 3f 9f 8b 2b 31 |.$....@..+-?..+1|
0060: 25 45 01 c8 80 9a d2 9b 65 fb e5 9e 45 bf 8d 7f |%E......e...E...|
0070: 9f c6 97 9f 2b 44 34 67 d9 ec 8e 0f a0 92 0b 75 |....+D4g.......u|
0080: 41 d6 24 59 18 a4 a4 9a a6 18 1a 5b 98 9b 5a 98 |A.$Y.......[..Z.|
0090: 9a 18 26 9b a6 19 98 1a 99 99 26 a6 18 9a 98 24 |..&.......&....$|
00a0: 26 59 a6 25 5a 98 a5 18 a6 24 71 41 35 b1 43 dc |&Y.%Z....$qA5.C.|
Mike Hommey
mdiff: don't emit a diff header for empty trivial deltas...
r27711 00b0: 16 b2 83 f7 e9 45 8b d2 56 c7 a3 1f 82 52 d7 8a |.....E..V....R..|
00c0: 78 ed fc d5 76 f1 36 35 dc 05 00 36 ed 5e c7 |x...v.65...6.^.|
Gregory Szorc
clonebundles: filter on bundle specification...
r26644
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 $ echo "http://localhost:$HGPORT1/partial.hg" > server/.hg/clonebundles.manifest
$ hg clone -U http://localhost:$HGPORT partial-bundle
applying clone bundle from http://localhost:$HGPORT1/partial.hg
adding changesets
adding manifests
adding file changes
added 1 changesets with 1 changes to 1 files
finished applying clone bundle
searching for changes
adding changesets
adding manifests
adding file changes
added 1 changesets with 1 changes to 1 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets aaff8d2ffbbf
Boris Feld
phases: use "published" in the phase movement message...
r38268 1 local changesets published
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623
Gregory Szorc
test-clonebundles.t: add test for incremental pull...
r26854 Incremental pull doesn't fetch bundle
$ hg clone -r 53245c60e682 -U http://localhost:$HGPORT partial-clone
adding changesets
adding manifests
adding file changes
added 1 changesets with 1 changes to 1 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 53245c60e682
Gregory Szorc
test-clonebundles.t: add test for incremental pull...
r26854
$ cd partial-clone
$ hg pull
pulling from http://localhost:$HGPORT/
searching for changes
adding changesets
adding manifests
adding file changes
added 1 changesets with 1 changes to 1 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets aaff8d2ffbbf
Gregory Szorc
test-clonebundles.t: add test for incremental pull...
r26854 (run 'hg update' to get a working copy)
$ cd ..
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 Bundle with full content works
Gregory Szorc
clonebundle: support bundle2...
r26643 $ hg -R server bundle --type gzip-v2 --base null -r tip full.hg
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 2 changesets found
Gregory Szorc
clonebundles: filter on bundle specification...
r26644 Again, we perform an extra check against bundle content changes. If this content
changes, clone bundles produced by new Mercurial versions may not be readable
by old clients.
$ f --size --hexdump full.hg
Boris Feld
bundle: include advisory rev branch cache part in bundle2 bundle...
r36983 full.hg: size=442
Gregory Szorc
clonebundles: filter on bundle specification...
r26644 0000: 48 47 32 30 00 00 00 0e 43 6f 6d 70 72 65 73 73 |HG20....Compress|
Gregory Szorc
bundle2: store changeset count when creating file bundles...
r29593 0010: 69 6f 6e 3d 47 5a 78 9c 63 60 60 d0 e4 76 f6 70 |ion=GZx.c``..v.p|
0020: f4 73 77 75 0f f2 0f 0d 60 00 02 46 46 76 26 4e |.swu....`..FFv&N|
0030: c6 b2 d4 a2 e2 cc fc 3c 03 a3 bc a4 e4 8c c4 bc |.......<........|
Pierre-Yves David
changegroup: skip delta when the underlying revlog do not use them...
r30211 0040: f4 d4 62 23 06 06 e6 19 40 f9 4d c1 2a 31 09 cf |..b#....@.M.*1..|
Gregory Szorc
bundle2: store changeset count when creating file bundles...
r29593 0050: 9a 3a 52 04 b7 fc db f0 95 e5 a4 f4 97 17 b2 c9 |.:R.............|
0060: 0c 14 00 02 e6 d9 99 25 1a a7 a4 99 a4 a4 1a 5b |.......%.......[|
0070: 58 a4 19 27 9b a4 59 a4 1a 59 a4 99 a4 59 26 5a |X..'..Y..Y...Y&Z|
0080: 18 9a 18 59 5a 26 1a 27 27 25 99 a6 99 1a 70 95 |...YZ&.''%....p.|
0090: a4 16 97 70 19 28 18 70 a5 e5 e7 73 71 25 a6 a4 |...p.(.p...sq%..|
Pierre-Yves David
changegroup: skip delta when the underlying revlog do not use them...
r30211 00a0: 28 00 19 20 17 af fa df ab ff 7b 3f fb 92 dc 8b |(.. ......{?....|
00b0: 1f 62 bb 9e b7 d7 d9 87 3d 5a 44 89 2f b0 99 87 |.b......=ZD./...|
00c0: ec e2 54 63 43 e3 b4 64 43 73 23 33 43 53 0b 63 |..TcC..dCs#3CS.c|
00d0: d3 14 23 03 a0 fb 2c 2c 0c d3 80 1e 30 49 49 b1 |..#...,,....0II.|
00e0: 4c 4a 32 48 33 30 b0 34 42 b8 38 29 b1 08 e2 62 |LJ2H30.4B.8)...b|
00f0: 20 03 6a ca c2 2c db 2f f7 2c fa 6d fc fb 34 be | .j..,./.,.m..4.|
0100: fc 5c 21 a2 39 cb 66 77 7c 00 0d c3 59 17 14 58 |.\!.9.fw|...Y..X|
0110: 49 16 06 29 a9 a6 29 86 c6 16 e6 a6 16 a6 26 86 |I..)..).......&.|
0120: c9 a6 69 06 a6 46 66 a6 89 29 86 26 26 89 49 96 |..i..Ff..).&&.I.|
0130: 69 89 16 66 29 86 29 49 5c 20 07 3e 16 fe 23 ae |i..f).)I\ .>..#.|
0140: 26 da 1c ab 10 1f d1 f8 e3 b3 ef cd dd fc 0c 93 |&...............|
0150: 88 75 34 36 75 04 82 55 17 14 36 a4 38 10 04 d8 |.u46u..U..6.8...|
0160: 21 01 9a b1 83 f7 e9 45 8b d2 56 c7 a3 1f 82 52 |!......E..V....R|
0170: d7 8a 78 ed fc d5 76 f1 36 25 81 89 c7 ad ec 90 |..x...v.6%......|
Boris Feld
bundle2: mark the bundle2 part as advisory (issue5872)...
r37920 0180: 54 47 75 2b 89 48 b1 b2 62 c9 89 c9 19 a9 56 45 |TGu+.H..b.....VE|
0190: a9 65 ba 49 45 89 79 c9 19 ba 60 01 a0 14 23 58 |.e.IE.y...`...#X|
Boris Feld
bundle: include advisory rev branch cache part in bundle2 bundle...
r36983 01a0: 81 35 c8 7d 40 cc 04 e2 a4 a4 a6 25 96 e6 94 60 |.5.}@......%...`|
Boris Feld
bundle2: mark the bundle2 part as advisory (issue5872)...
r37920 01b0: 33 17 5f 54 00 00 d3 1b 0d 4c |3._T.....L|
Gregory Szorc
clonebundles: filter on bundle specification...
r26644
Gregory Szorc
clonebundles: support for seeding clones from pre-generated bundles...
r26623 $ echo "http://localhost:$HGPORT1/full.hg" > server/.hg/clonebundles.manifest
$ hg clone -U http://localhost:$HGPORT full-bundle
applying clone bundle from http://localhost:$HGPORT1/full.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
clonebundles: filter on bundle specification...
r26644
Gregory Szorc
wireproto: move clonebundles command from extension (issue4931)...
r26857 Feature works over SSH
Valentin Gatien-Baron
tests: rely on dummyssh being the default...
r48732 $ hg clone -U ssh://user@dummy/server ssh-full-clone
Gregory Szorc
wireproto: move clonebundles command from extension (issue4931)...
r26857 applying clone bundle from http://localhost:$HGPORT1/full.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
wireproto: move clonebundles command from extension (issue4931)...
r26857
clone-bundles: reorder some test section and add titles...
r51593 Inline bundle
=============
Checking bundle retrieved over the wireprotocol
branching: merge with stable
r51579 Feature works over SSH with inline bundle
clone-bundles: reorder some test section and add titles...
r51593 -----------------------------------------
branching: merge with stable
r51579 $ mkdir server/.hg/bundle-cache/
$ cp full.hg server/.hg/bundle-cache/
$ echo "peer-bundle-cache://full.hg" > server/.hg/clonebundles.manifest
$ hg clone -U ssh://user@dummy/server ssh-inline-clone
applying clone bundle from peer-bundle-cache://full.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
2 local changesets published
clone-bundles: reorder some test section and add titles...
r51593 HTTP Supports
-------------
$ hg clone -U http://localhost:$HGPORT http-inline-clone
clonebundles: introduce a new write protocol command...
r51594 applying clone bundle from peer-bundle-cache://full.hg
clone-bundles: reorder some test section and add titles...
r51593 adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
clonebundles: introduce a new write protocol command...
r51594 finished applying clone bundle
searching for changes
no changes found
2 local changesets published
clone-bundles: reorder some test section and add titles...
r51593
clone-bundle: double check that inline clone bundle does not break local case...
r51596
Check local behavior
--------------------
We don't use the clone bundle, but we do not crash either.
$ hg clone -U ./server local-inline-clone-default
$ hg clone -U ./server local-inline-clone-pull --pull
requesting all changes
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
new changesets 53245c60e682:aaff8d2ffbbf
clone-bundles: reorder some test section and add titles...
r51593 Pre-transmit Hook
-----------------
branching: merge with stable
r51579 Hooks work with inline bundle
clone-bundles: reorder some test section and add titles...
r51593
branching: merge with stable
r51579 $ cp server/.hg/hgrc server/.hg/hgrc-beforeinlinehooks
$ echo "[hooks]" >> server/.hg/hgrc
$ echo "pretransmit-inline-clone-bundle=echo foo" >> server/.hg/hgrc
$ hg clone -U ssh://user@dummy/server ssh-inline-clone-hook
applying clone bundle from peer-bundle-cache://full.hg
remote: foo
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
2 local changesets published
Hooks can make an inline bundle fail
clone-bundles: reorder some test section and add titles...
r51593
branching: merge with stable
r51579 $ cp server/.hg/hgrc-beforeinlinehooks server/.hg/hgrc
$ echo "[hooks]" >> server/.hg/hgrc
$ echo "pretransmit-inline-clone-bundle=echo bar && false" >> server/.hg/hgrc
$ hg clone -U ssh://user@dummy/server ssh-inline-clone-hook-fail
applying clone bundle from peer-bundle-cache://full.hg
remote: bar
remote: abort: pretransmit-inline-clone-bundle hook exited with status 1
abort: stream ended unexpectedly (got 0 bytes, expected 1)
[255]
$ cp server/.hg/hgrc-beforeinlinehooks server/.hg/hgrc
clone-bundles: reorder some test section and add titles...
r51593 Other tests
===========
branching: merge with stable
r51579
Gregory Szorc
clonebundles: filter on bundle specification...
r26644 Entry with unknown BUNDLESPEC is filtered and not used
$ cat > server/.hg/clonebundles.manifest << EOF
> http://bad.entry1 BUNDLESPEC=UNKNOWN
> http://bad.entry2 BUNDLESPEC=xz-v1
> http://bad.entry3 BUNDLESPEC=none-v100
> http://localhost:$HGPORT1/full.hg BUNDLESPEC=gzip-v2
> EOF
$ hg clone -U http://localhost:$HGPORT filter-unknown-type
applying clone bundle from http://localhost:$HGPORT1/full.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
clonebundles: filter on bundle specification...
r26644
Automatic fallback when all entries are filtered
$ cat > server/.hg/clonebundles.manifest << EOF
> http://bad.entry BUNDLESPEC=UNKNOWN
> EOF
$ hg clone -U http://localhost:$HGPORT filter-all
no compatible clone bundles available on server; falling back to regular clone
(you may want to report this to the server operator)
requesting all changes
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 53245c60e682:aaff8d2ffbbf
Gregory Szorc
clonebundles: filter on SNI requirement...
r26645
Manuel Jacob
tests: remove "sslcontext" check...
r45417 We require a Python version that supports SNI. Therefore, URLs requiring SNI
are not filtered.
Gregory Szorc
clonebundles: filter on SNI requirement...
r26645
$ cp full.hg sni.hg
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/sni.hg REQUIRESNI=true
> http://localhost:$HGPORT1/full.hg
> EOF
$ hg clone -U http://localhost:$HGPORT sni-supported
applying clone bundle from http://localhost:$HGPORT1/sni.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648
Gregory Szorc
exchange: support streaming clone bundles in clone bundles...
r26761 Stream clone bundles are supported
$ hg -R server debugcreatestreamclonebundle packed.hg
writing 613 bytes for 4 files
requirements: add an official `REVLOG_COMPRESSION_ZSTD` const...
r49498 bundle requirements: generaldelta, revlogv1, sparserevlog (no-rust no-zstd !)
bundle requirements: generaldelta, revlog-compression-zstd, revlogv1, sparserevlog (no-rust zstd !)
stream-clone: allow to change persistent-nodemap format during stream clone...
r49542 bundle requirements: generaldelta, revlog-compression-zstd, revlogv1, sparserevlog (rust !)
Gregory Szorc
exchange: support streaming clone bundles in clone bundles...
r26761
No bundle spec should work
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/packed.hg
> EOF
$ hg clone -U http://localhost:$HGPORT stream-clone-no-spec
applying clone bundle from http://localhost:$HGPORT1/packed.hg
4 files to transfer, 613 bytes of data
transferred 613 bytes in *.* seconds (*) (glob)
finished applying clone bundle
searching for changes
no changes found
Bundle spec without parameters should work
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/packed.hg BUNDLESPEC=none-packed1
> EOF
$ hg clone -U http://localhost:$HGPORT stream-clone-vanilla-spec
applying clone bundle from http://localhost:$HGPORT1/packed.hg
4 files to transfer, 613 bytes of data
transferred 613 bytes in *.* seconds (*) (glob)
finished applying clone bundle
searching for changes
no changes found
Bundle spec with format requirements should work
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/packed.hg BUNDLESPEC=none-packed1;requirements%3Drevlogv1
> EOF
$ hg clone -U http://localhost:$HGPORT stream-clone-supported-requirements
applying clone bundle from http://localhost:$HGPORT1/packed.hg
4 files to transfer, 613 bytes of data
transferred 613 bytes in *.* seconds (*) (glob)
finished applying clone bundle
searching for changes
no changes found
Stream bundle spec with unknown requirements should be filtered out
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/packed.hg BUNDLESPEC=none-packed1;requirements%3Drevlogv42
> EOF
$ hg clone -U http://localhost:$HGPORT stream-clone-unsupported-requirements
no compatible clone bundles available on server; falling back to regular clone
(you may want to report this to the server operator)
requesting all changes
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 53245c60e682:aaff8d2ffbbf
Gregory Szorc
exchange: support streaming clone bundles in clone bundles...
r26761
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648 Set up manifest for testing preferences
(Remember, the TYPE does not have to match reality - the URL is
important)
$ cp full.hg gz-a.hg
$ cp full.hg gz-b.hg
$ cp full.hg bz2-a.hg
$ cp full.hg bz2-b.hg
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/gz-a.hg BUNDLESPEC=gzip-v2 extra=a
> http://localhost:$HGPORT1/bz2-a.hg BUNDLESPEC=bzip2-v2 extra=a
> http://localhost:$HGPORT1/gz-b.hg BUNDLESPEC=gzip-v2 extra=b
> http://localhost:$HGPORT1/bz2-b.hg BUNDLESPEC=bzip2-v2 extra=b
> EOF
Preferring an undefined attribute will take first entry
Gregory Szorc
exchange: make clonebundleprefers non-experimental...
r27737 $ hg --config ui.clonebundleprefers=foo=bar clone -U http://localhost:$HGPORT prefer-foo
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648 applying clone bundle from http://localhost:$HGPORT1/gz-a.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648
Preferring bz2 type will download first entry of that type
Gregory Szorc
exchange: make clonebundleprefers non-experimental...
r27737 $ hg --config ui.clonebundleprefers=COMPRESSION=bzip2 clone -U http://localhost:$HGPORT prefer-bz
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648 applying clone bundle from http://localhost:$HGPORT1/bz2-a.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648
Preferring multiple values of an option works
Gregory Szorc
exchange: make clonebundleprefers non-experimental...
r27737 $ hg --config ui.clonebundleprefers=COMPRESSION=unknown,COMPRESSION=bzip2 clone -U http://localhost:$HGPORT prefer-multiple-bz
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648 applying clone bundle from http://localhost:$HGPORT1/bz2-a.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648
Sorting multiple values should get us back to original first entry
Gregory Szorc
exchange: make clonebundleprefers non-experimental...
r27737 $ hg --config ui.clonebundleprefers=BUNDLESPEC=unknown,BUNDLESPEC=gzip-v2,BUNDLESPEC=bzip2-v2 clone -U http://localhost:$HGPORT prefer-multiple-gz
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648 applying clone bundle from http://localhost:$HGPORT1/gz-a.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648
Preferring multiple attributes has correct order
Gregory Szorc
exchange: make clonebundleprefers non-experimental...
r27737 $ hg --config ui.clonebundleprefers=extra=b,BUNDLESPEC=bzip2-v2 clone -U http://localhost:$HGPORT prefer-separate-attributes
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648 applying clone bundle from http://localhost:$HGPORT1/bz2-b.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648
Test where attribute is missing from some entries
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/gz-a.hg BUNDLESPEC=gzip-v2
> http://localhost:$HGPORT1/bz2-a.hg BUNDLESPEC=bzip2-v2
> http://localhost:$HGPORT1/gz-b.hg BUNDLESPEC=gzip-v2 extra=b
> http://localhost:$HGPORT1/bz2-b.hg BUNDLESPEC=bzip2-v2 extra=b
> EOF
Gregory Szorc
exchange: make clonebundleprefers non-experimental...
r27737 $ hg --config ui.clonebundleprefers=extra=b clone -U http://localhost:$HGPORT prefer-partially-defined-attribute
Gregory Szorc
exchange: support sorting URLs by client-side preferences...
r26648 applying clone bundle from http://localhost:$HGPORT1/gz-b.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359
Matt Harbison
exchange: check the `ui.clonebundleprefers` form while processing (issue6257)...
r44763 Test a bad attribute list
$ hg --config ui.clonebundleprefers=bad clone -U http://localhost:$HGPORT bad-input
abort: invalid ui.clonebundleprefers item: bad
(each comma separated item should be key=value pairs)
[255]
$ hg --config ui.clonebundleprefers=key=val,bad,key2=val2 clone \
> -U http://localhost:$HGPORT bad-input
abort: invalid ui.clonebundleprefers item: bad
(each comma separated item should be key=value pairs)
[255]
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 Test interaction between clone bundles and --stream
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359
A manifest with just a gzip bundle
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/gz-a.hg BUNDLESPEC=gzip-v2
> EOF
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone -U --stream http://localhost:$HGPORT uncompressed-gzip
Gregory Szorc
exchange: perform stream clone with clone bundle with --uncompressed...
r34360 no compatible clone bundles available on server; falling back to regular clone
(you may want to report this to the server operator)
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359 streaming all changes
av6
bundle2: make server.bundle2.stream default to True...
r39758 9 files to transfer, 816 bytes of data
transferred 816 bytes in * seconds (*) (glob)
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359
A manifest with a stream clone but no BUNDLESPEC
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/packed.hg
> EOF
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone -U --stream http://localhost:$HGPORT uncompressed-no-bundlespec
Gregory Szorc
exchange: perform stream clone with clone bundle with --uncompressed...
r34360 no compatible clone bundles available on server; falling back to regular clone
(you may want to report this to the server operator)
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359 streaming all changes
av6
bundle2: make server.bundle2.stream default to True...
r39758 9 files to transfer, 816 bytes of data
transferred 816 bytes in * seconds (*) (glob)
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359
A manifest with a gzip bundle and a stream clone
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/gz-a.hg BUNDLESPEC=gzip-v2
> http://localhost:$HGPORT1/packed.hg BUNDLESPEC=none-packed1
> EOF
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone -U --stream http://localhost:$HGPORT uncompressed-gzip-packed
Gregory Szorc
exchange: perform stream clone with clone bundle with --uncompressed...
r34360 applying clone bundle from http://localhost:$HGPORT1/packed.hg
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359 4 files to transfer, 613 bytes of data
transferred 613 bytes in * seconds (*) (glob)
Gregory Szorc
exchange: perform stream clone with clone bundle with --uncompressed...
r34360 finished applying clone bundle
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359 searching for changes
no changes found
A manifest with a gzip bundle and stream clone with supported requirements
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/gz-a.hg BUNDLESPEC=gzip-v2
> http://localhost:$HGPORT1/packed.hg BUNDLESPEC=none-packed1;requirements%3Drevlogv1
> EOF
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone -U --stream http://localhost:$HGPORT uncompressed-gzip-packed-requirements
Gregory Szorc
exchange: perform stream clone with clone bundle with --uncompressed...
r34360 applying clone bundle from http://localhost:$HGPORT1/packed.hg
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359 4 files to transfer, 613 bytes of data
transferred 613 bytes in * seconds (*) (glob)
Gregory Szorc
exchange: perform stream clone with clone bundle with --uncompressed...
r34360 finished applying clone bundle
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359 searching for changes
no changes found
A manifest with a gzip bundle and a stream clone with unsupported requirements
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/gz-a.hg BUNDLESPEC=gzip-v2
> http://localhost:$HGPORT1/packed.hg BUNDLESPEC=none-packed1;requirements%3Drevlogv42
> EOF
Gregory Szorc
commands: rename clone --uncompressed to --stream and document...
r34394 $ hg clone -U --stream http://localhost:$HGPORT uncompressed-gzip-packed-unsupported-requirements
Gregory Szorc
exchange: perform stream clone with clone bundle with --uncompressed...
r34360 no compatible clone bundles available on server; falling back to regular clone
(you may want to report this to the server operator)
Gregory Szorc
tests: add tests for clone bundles with --uncompressed...
r34359 streaming all changes
av6
bundle2: make server.bundle2.stream default to True...
r39758 9 files to transfer, 816 bytes of data
transferred 816 bytes in * seconds (*) (glob)
Boris Feld
clonebundle: make it possible to retrieve the initial bundle through largefile...
r35581
Test clone bundle retrieved through bundle2
$ cat << EOF >> $HGRCPATH
> [extensions]
> largefiles=
> EOF
$ killdaemons.py
$ hg -R server serve -d -p $HGPORT --pid-file hg.pid --accesslog access.log
$ cat hg.pid >> $DAEMON_PIDS
$ hg -R server debuglfput gz-a.hg
Boris Feld
bundle2: mark the bundle2 part as advisory (issue5872)...
r37920 1f74b3d08286b9b3a16fb3fa185dd29219cbc6ae
Boris Feld
clonebundle: make it possible to retrieve the initial bundle through largefile...
r35581
$ cat > server/.hg/clonebundles.manifest << EOF
Boris Feld
bundle2: mark the bundle2 part as advisory (issue5872)...
r37920 > largefile://1f74b3d08286b9b3a16fb3fa185dd29219cbc6ae BUNDLESPEC=gzip-v2
Boris Feld
clonebundle: make it possible to retrieve the initial bundle through largefile...
r35581 > EOF
$ hg clone -U http://localhost:$HGPORT largefile-provided --traceback
Boris Feld
bundle2: mark the bundle2 part as advisory (issue5872)...
r37920 applying clone bundle from largefile://1f74b3d08286b9b3a16fb3fa185dd29219cbc6ae
Boris Feld
clonebundle: make it possible to retrieve the initial bundle through largefile...
r35581 adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
searching for changes
no changes found
Boris Feld
phases: use "published" in the phase movement message...
r38268 2 local changesets published
Joerg Sonnenberger
clonebundles: optional memory-requirement attribution...
r45622 $ killdaemons.py
A manifest with a gzip bundle requiring too much memory for a 16MB system and working
on a 32MB system.
$ "$PYTHON" $TESTDIR/dumbhttp.py -p $HGPORT1 --pid http.pid
$ cat http.pid >> $DAEMON_PIDS
$ hg -R server serve -d -p $HGPORT --pid-file hg.pid --accesslog access.log
$ cat hg.pid >> $DAEMON_PIDS
$ cat > server/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/gz-a.hg BUNDLESPEC=gzip-v2 REQUIREDRAM=12MB
> EOF
$ hg clone -U --debug --config ui.available-memory=16MB http://localhost:$HGPORT gzip-too-large
using http://localhost:$HGPORT/
sending capabilities command
clonebundles: introduce a new write protocol command...
r51594 sending clonebundles_manifest command
Joerg Sonnenberger
clonebundles: optional memory-requirement attribution...
r45622 filtering http://localhost:$HGPORT1/gz-a.hg as it needs more than 2/3 of system memory
no compatible clone bundles available on server; falling back to regular clone
(you may want to report this to the server operator)
query 1; heads
sending batch command
requesting all changes
sending getbundle command
bundle2-input-bundle: with-transaction
bundle2-input-part: "changegroup" (params: 1 mandatory 1 advisory) supported
adding changesets
add changeset 53245c60e682
add changeset aaff8d2ffbbf
adding manifests
adding file changes
adding bar revisions
adding foo revisions
branching: merge with stable
r51579 bundle2-input-part: total payload size 936
Joerg Sonnenberger
clonebundles: optional memory-requirement attribution...
r45622 bundle2-input-part: "listkeys" (params: 1 mandatory) supported
bundle2-input-part: "phase-heads" supported
bundle2-input-part: total payload size 24
Joerg Sonnenberger
exchange: stop advertising rev-branch-cache bundle capability...
r47378 bundle2-input-bundle: 3 parts total
Joerg Sonnenberger
clonebundles: optional memory-requirement attribution...
r45622 checking for updated bookmarks
updating the branch cache
added 2 changesets with 2 changes to 2 files
new changesets 53245c60e682:aaff8d2ffbbf
calling hook changegroup.lfiles: hgext.largefiles.reposetup.checkrequireslfiles
clone: make sure we warm the cache after a clone...
r47032 updating the branch cache
Joerg Sonnenberger
clonebundles: optional memory-requirement attribution...
r45622 (sent 4 HTTP requests and * bytes; received * bytes in responses) (glob)
$ hg clone -U --debug --config ui.available-memory=32MB http://localhost:$HGPORT gzip-too-large2
using http://localhost:$HGPORT/
sending capabilities command
clonebundles: introduce a new write protocol command...
r51594 sending clonebundles_manifest command
Joerg Sonnenberger
clonebundles: optional memory-requirement attribution...
r45622 applying clone bundle from http://localhost:$HGPORT1/gz-a.hg
bundle2-input-bundle: 1 params with-transaction
bundle2-input-part: "changegroup" (params: 1 mandatory 1 advisory) supported
adding changesets
add changeset 53245c60e682
add changeset aaff8d2ffbbf
adding manifests
adding file changes
adding bar revisions
adding foo revisions
bundle2-input-part: total payload size 920
bundle2-input-part: "cache:rev-branch-cache" (advisory) supported
bundle2-input-part: total payload size 59
bundle2-input-bundle: 2 parts total
updating the branch cache
added 2 changesets with 2 changes to 2 files
finished applying clone bundle
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
bundle2-input-part: "phase-heads" supported
bundle2-input-part: total payload size 24
bundle2-input-bundle: 2 parts total
checking for updated bookmarks
2 local changesets published
calling hook changegroup.lfiles: hgext.largefiles.reposetup.checkrequireslfiles
clone: make sure we warm the cache after a clone...
r47032 updating the branch cache
Joerg Sonnenberger
clonebundles: optional memory-requirement attribution...
r45622 (sent 4 HTTP requests and * bytes; received * bytes in responses) (glob)
$ killdaemons.py
revlog-split: show manifest data loss situation when using clonebundle...
r51318
Testing a clone bundles that involves revlog splitting (issue6811)
==================================================================
$ cat >> $HGRCPATH << EOF
> [format]
> revlog-compression=none
> use-persistent-nodemap=no
> EOF
$ hg init server-revlog-split/
$ cd server-revlog-split
$ cat >> .hg/hgrc << EOF
> [extensions]
> clonebundles =
> EOF
$ echo foo > A
$ hg add A
$ hg commit -m 'initial commit'
IMPORTANT: the revlogs must not be split
$ ls -1 .hg/store/00manifest.*
.hg/store/00manifest.i
$ ls -1 .hg/store/data/_a.*
.hg/store/data/_a.i
do big enough update to split the revlogs
$ $TESTDIR/seq.py 100000 > A
$ mkdir foo
$ cd foo
$ touch `$TESTDIR/seq.py 10000`
$ cd ..
$ hg add -q foo
$ hg commit -m 'split the manifest and one filelog'
IMPORTANT: now the revlogs must be split
$ ls -1 .hg/store/00manifest.*
.hg/store/00manifest.d
.hg/store/00manifest.i
$ ls -1 .hg/store/data/_a.*
.hg/store/data/_a.d
.hg/store/data/_a.i
Add an extra commit on top of that
$ echo foo >> A
$ hg commit -m 'one extra commit'
$ cd ..
Do a bundle that contains the split, but not the update
$ hg bundle --exact --rev '::(default~1)' -R server-revlog-split/ --type gzip-v2 split-test.hg
2 changesets found
$ cat > server-revlog-split/.hg/clonebundles.manifest << EOF
> http://localhost:$HGPORT1/split-test.hg BUNDLESPEC=gzip-v2
> EOF
start the necessary server
$ "$PYTHON" $TESTDIR/dumbhttp.py -p $HGPORT1 --pid http.pid
$ cat http.pid >> $DAEMON_PIDS
$ hg -R server-revlog-split serve -d -p $HGPORT --pid-file hg.pid --accesslog access.log
$ cat hg.pid >> $DAEMON_PIDS
Check that clone works fine
===========================
Here, the initial clone will trigger a revlog split (which is a bit clowny it
itself, but whatever). The split revlogs will see additionnal data added to
them in the subsequent pull. This should not be a problem
$ hg clone http://localhost:$HGPORT revlog-split-in-the-bundle
applying clone bundle from http://localhost:$HGPORT1/split-test.hg
adding changesets
adding manifests
adding file changes
added 2 changesets with 10002 changes to 10001 files
finished applying clone bundle
searching for changes
adding changesets
adding manifests
adding file changes
added 1 changesets with 1 changes to 1 files
new changesets e3879eaa1db7
2 local changesets published
updating to branch default
10001 files updated, 0 files merged, 0 files removed, 0 files unresolved
check the results
$ cd revlog-split-in-the-bundle
$ f --size .hg/store/00manifest.*
.hg/store/00manifest.d: size=499037
revlog-split: make sure the self._indexfile attribut is reset (issue6811)...
r51320 .hg/store/00manifest.i: size=192
revlog-split: show manifest data loss situation when using clonebundle...
r51318 $ f --size .hg/store/data/_a.*
.hg/store/data/_a.d: size=588917
.hg/store/data/_a.i: size=192
manifest should work
$ hg files -r tip | wc -l
revlog-split: make sure the self._indexfile attribut is reset (issue6811)...
r51320 \s*10001 (re)
revlog-split: show manifest data loss situation when using clonebundle...
r51318
file content should work
$ hg cat -r tip A | wc -l
revlog-split: make sure the self._indexfile attribut is reset (issue6811)...
r51320 \s*100001 (re)
revlog-split: show manifest data loss situation when using clonebundle...
r51318