test-push-http-bundle1.t
169 lines
| 4.4 KiB
| text/troff
|
Tads3Lexer
/ tests / test-push-http-bundle1.t
Pierre-Yves David
|
r25389 | #require killdaemons | ||
This test checks behavior related to bundle1 that changed or is likely | ||||
to change with bundle2. Feel free to factor out any part of the test | ||||
which does not need to exist to keep bundle1 working. | ||||
$ cat << EOF >> $HGRCPATH | ||||
> [experimental] | ||||
> # This test is dedicated to interaction through old bundle | ||||
> bundle2-exp = False | ||||
> EOF | ||||
$ hg init test | ||||
$ cd test | ||||
$ echo a > a | ||||
$ hg ci -Ama | ||||
adding a | ||||
$ cd .. | ||||
$ hg clone test test2 | ||||
updating to branch default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd test2 | ||||
$ echo a >> a | ||||
$ hg ci -mb | ||||
$ req() { | ||||
> hg serve -p $HGPORT -d --pid-file=hg.pid -E errors.log | ||||
> cat hg.pid >> $DAEMON_PIDS | ||||
> hg --cwd ../test2 push http://localhost:$HGPORT/ | ||||
> exitstatus=$? | ||||
Matt Mackall
|
r25474 | > killdaemons.py | ||
Pierre-Yves David
|
r25389 | > echo % serve errors | ||
> cat errors.log | ||||
> return $exitstatus | ||||
> } | ||||
$ cd ../test | ||||
expect ssl error | ||||
$ req | ||||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
abort: HTTP Error 403: ssl required | ||||
% serve errors | ||||
[255] | ||||
expect authorization error | ||||
$ echo '[web]' > .hg/hgrc | ||||
$ echo 'push_ssl = false' >> .hg/hgrc | ||||
$ req | ||||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
abort: authorization failed | ||||
% serve errors | ||||
[255] | ||||
expect authorization error: must have authorized user | ||||
$ echo 'allow_push = unperson' >> .hg/hgrc | ||||
$ req | ||||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
abort: authorization failed | ||||
% serve errors | ||||
[255] | ||||
expect success | ||||
$ echo 'allow_push = *' >> .hg/hgrc | ||||
$ echo '[hooks]' >> .hg/hgrc | ||||
Matt Mackall
|
r25478 | $ echo "changegroup = printenv.py changegroup 0" >> .hg/hgrc | ||
$ echo "pushkey = printenv.py pushkey 0" >> .hg/hgrc | ||||
Pierre-Yves David
|
r25389 | $ req | ||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files | ||||
remote: changegroup hook: HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_TXNID=TXN:* HG_URL=remote:http:127.0.0.1: (glob) | ||||
% serve errors | ||||
$ hg rollback | ||||
repository tip rolled back to revision 0 (undo serve) | ||||
expect success, server lacks the httpheader capability | ||||
$ CAP=httpheader | ||||
$ . "$TESTDIR/notcapable" | ||||
$ req | ||||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files | ||||
remote: changegroup hook: HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_TXNID=TXN:* HG_URL=remote:http:127.0.0.1: (glob) | ||||
% serve errors | ||||
$ hg rollback | ||||
repository tip rolled back to revision 0 (undo serve) | ||||
expect success, server lacks the unbundlehash capability | ||||
$ CAP=unbundlehash | ||||
$ . "$TESTDIR/notcapable" | ||||
$ req | ||||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files | ||||
remote: changegroup hook: HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_TXNID=TXN:* HG_URL=remote:http:127.0.0.1: (glob) | ||||
% serve errors | ||||
$ hg rollback | ||||
repository tip rolled back to revision 0 (undo serve) | ||||
expect push success, phase change failure | ||||
$ cat > .hg/hgrc <<EOF | ||||
> [web] | ||||
> push_ssl = false | ||||
> allow_push = * | ||||
> [hooks] | ||||
Matt Mackall
|
r25478 | > prepushkey = printenv.py prepushkey 1 | ||
Pierre-Yves David
|
r25389 | > EOF | ||
$ req | ||||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files | ||||
% serve errors | ||||
expect phase change success | ||||
Matt Mackall
|
r25478 | $ echo "prepushkey = printenv.py prepushkey 0" >> .hg/hgrc | ||
Pierre-Yves David
|
r25389 | $ req | ||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
no changes found | ||||
% serve errors | ||||
[1] | ||||
$ hg rollback | ||||
repository tip rolled back to revision 0 (undo serve) | ||||
expect authorization error: all users denied | ||||
$ echo '[web]' > .hg/hgrc | ||||
$ echo 'push_ssl = false' >> .hg/hgrc | ||||
$ echo 'deny_push = *' >> .hg/hgrc | ||||
$ req | ||||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
abort: authorization failed | ||||
% serve errors | ||||
[255] | ||||
expect authorization error: some users denied, users must be authenticated | ||||
$ echo 'deny_push = unperson' >> .hg/hgrc | ||||
$ req | ||||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
abort: authorization failed | ||||
% serve errors | ||||
[255] | ||||
$ cd .. | ||||