test-clone-uncompressed.t
161 lines
| 4.8 KiB
| text/troff
|
Tads3Lexer
/ tests / test-clone-uncompressed.t
Gregory Szorc
|
r27897 | #require serve | ||
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: | ||||
... fh.write(str(i)) | ||||
$ hg -q commit -A -m 'add a lot of files' | ||||
timeless
|
r28389 | $ hg st | ||
Gregory Szorc
|
r27897 | $ hg serve -p $HGPORT -d --pid-file=hg.pid | ||
$ cat hg.pid >> $DAEMON_PIDS | ||||
$ cd .. | ||||
Basic clone | ||||
$ hg clone --uncompressed -U http://localhost:$HGPORT clone1 | ||||
streaming all changes | ||||
1027 files to transfer, 96.3 KB of data | ||||
transferred 96.3 KB in * seconds (*/sec) (glob) | ||||
searching for changes | ||||
no changes found | ||||
Clone with background file closing enabled | ||||
$ hg --debug --config worker.backgroundclose=true --config worker.backgroundcloseminfilecount=1 clone --uncompressed -U http://localhost:$HGPORT clone-background | grep -v adding | ||||
using http://localhost:$HGPORT/ | ||||
sending capabilities command | ||||
sending branchmap command | ||||
streaming all changes | ||||
sending stream_out command | ||||
1027 files to transfer, 96.3 KB of data | ||||
starting 4 threads for background file closing | ||||
transferred 96.3 KB in * seconds (*/sec) (glob) | ||||
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 | ||||
Mike Hommey
|
r29064 | bundle2-input-part: total payload size 58 | ||
Gregory Szorc
|
r27897 | bundle2-input-part: "listkeys" (params: 1 mandatory) supported | ||
bundle2-input-bundle: 1 parts total | ||||
checking for updated bookmarks | ||||
Mads Kiilerich
|
r28517 | |||
Gregory Szorc
|
r32744 | Cannot stream clone when there are secret changesets | ||
$ hg -R server phase --force --secret -r tip | ||||
$ hg clone --uncompressed -U http://localhost:$HGPORT secret-denied | ||||
warning: stream clone requested but server has them disabled | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
$ killdaemons.py | ||||
Streaming of secrets can be overridden by server config | ||||
$ cd server | ||||
$ hg --config server.uncompressedallowsecret=true serve -p $HGPORT -d --pid-file=hg.pid | ||||
$ cat hg.pid > $DAEMON_PIDS | ||||
$ cd .. | ||||
$ hg clone --uncompressed -U http://localhost:$HGPORT secret-allowed | ||||
streaming all changes | ||||
1027 files to transfer, 96.3 KB of data | ||||
transferred 96.3 KB in * seconds (*/sec) (glob) | ||||
searching for changes | ||||
no changes found | ||||
$ killdaemons.py | ||||
Verify interaction between preferuncompressed and secret presence | ||||
$ cd server | ||||
$ hg --config server.preferuncompressed=true serve -p $HGPORT -d --pid-file=hg.pid | ||||
$ cat hg.pid > $DAEMON_PIDS | ||||
$ cd .. | ||||
$ hg clone -U http://localhost:$HGPORT preferuncompressed-secret | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
$ killdaemons.py | ||||
Clone not allowed when full bundles disabled and can't serve secrets | ||||
$ cd server | ||||
$ hg --config server.disablefullbundle=true serve -p $HGPORT -d --pid-file=hg.pid | ||||
$ cat hg.pid > $DAEMON_PIDS | ||||
$ cd .. | ||||
$ hg clone --uncompressed http://localhost:$HGPORT secret-full-disabled | ||||
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) | ||||
[255] | ||||
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.) | ||||
$ hg clone -U --uncompressed server local-secret | ||||
warning: stream clone requested but server has them disabled | ||||
requesting all changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
added 1 changesets with 1 changes to 1 files | ||||
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 | ||||
$ cat > delayer.py <<EOF | ||||
> import time | ||||
Pierre-Yves David
|
r31252 | > from mercurial import extensions, vfs | ||
Mads Kiilerich
|
r28517 | > def __call__(orig, self, path, *args, **kwargs): | ||
> if path == 'data/f1.i': | ||||
> time.sleep(2) | ||||
> return orig(self, path, *args, **kwargs) | ||||
Pierre-Yves David
|
r31252 | > extensions.wrapfunction(vfs.vfs, '__call__', __call__) | ||
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" | ||||
$ hg -R repo serve -p $HGPORT1 -d --pid-file=hg.pid --config extensions.delayer=delayer.py | ||||
$ cat hg.pid >> $DAEMON_PIDS | ||||
clone while modifying the repo between stating file with write lock and | ||||
actually serving file content | ||||
$ hg clone -q --uncompressed -U http://localhost:$HGPORT1 clone & | ||||
$ sleep 1 | ||||
$ echo >> repo/f1 | ||||
$ echo >> repo/f2 | ||||
$ hg -R repo ci -m "1" | ||||
$ wait | ||||
$ hg -R clone id | ||||
Mads Kiilerich
|
r28518 | 000000000000 | ||