test-push-http.t
165 lines
| 4.7 KiB
| text/troff
|
Tads3Lexer
/ tests / test-push-http.t
Patrick Mezard
|
r17565 | $ "$TESTDIR/hghave" killdaemons || exit 80 | ||
Matt Mackall
|
r12483 | |||
$ 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() { | ||||
Adrian Buehlmann
|
r12743 | > hg serve -p $HGPORT -d --pid-file=hg.pid -E errors.log | ||
> cat hg.pid >> $DAEMON_PIDS | ||||
> hg --cwd ../test2 push http://localhost:$HGPORT/ | ||||
Yuya Nishihara
|
r17455 | > exitstatus=$? | ||
Patrick Mezard
|
r17466 | > "$TESTDIR/killdaemons.py" $DAEMON_PIDS | ||
Adrian Buehlmann
|
r12743 | > echo % serve errors | ||
> cat errors.log | ||||
Yuya Nishihara
|
r17455 | > return $exitstatus | ||
Matt Mackall
|
r12483 | > } | ||
$ cd ../test | ||||
expect ssl error | ||||
$ req | ||||
Mads Kiilerich
|
r12643 | pushing to http://localhost:$HGPORT/ | ||
Matt Mackall
|
r12483 | searching for changes | ||
Yuya Nishihara
|
r17456 | abort: HTTP Error 403: ssl required | ||
Matt Mackall
|
r12483 | % serve errors | ||
Yuya Nishihara
|
r17456 | [255] | ||
Matt Mackall
|
r12483 | |||
expect authorization error | ||||
$ echo '[web]' > .hg/hgrc | ||||
$ echo 'push_ssl = false' >> .hg/hgrc | ||||
$ req | ||||
Mads Kiilerich
|
r12643 | pushing to http://localhost:$HGPORT/ | ||
Matt Mackall
|
r12483 | searching for changes | ||
abort: authorization failed | ||||
% serve errors | ||||
Yuya Nishihara
|
r17455 | [255] | ||
Matt Mackall
|
r12483 | |||
expect authorization error: must have authorized user | ||||
$ echo 'allow_push = unperson' >> .hg/hgrc | ||||
$ req | ||||
Mads Kiilerich
|
r12643 | pushing to http://localhost:$HGPORT/ | ||
Matt Mackall
|
r12483 | searching for changes | ||
abort: authorization failed | ||||
% serve errors | ||||
Yuya Nishihara
|
r17455 | [255] | ||
Matt Mackall
|
r12483 | |||
expect success | ||||
$ echo 'allow_push = *' >> .hg/hgrc | ||||
$ echo '[hooks]' >> .hg/hgrc | ||||
Mads Kiilerich
|
r17018 | $ echo "changegroup = python \"$TESTDIR/printenv.py\" changegroup 0" >> .hg/hgrc | ||
Wagner Bruna
|
r17793 | $ echo "pushkey = python \"$TESTDIR/printenv.py\" pushkey 0" >> .hg/hgrc | ||
Matt Mackall
|
r12483 | $ req | ||
Mads Kiilerich
|
r12643 | pushing to http://localhost:$HGPORT/ | ||
Matt Mackall
|
r12483 | searching for changes | ||
remote: adding changesets | ||||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files | ||||
Adrian Buehlmann
|
r16982 | remote: changegroup hook: HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_URL=remote:http:*: (glob) | ||
Wagner Bruna
|
r17793 | remote: pushkey hook: HG_KEY=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NAMESPACE=phases HG_NEW=0 HG_OLD=1 HG_RET=1 | ||
Matt Mackall
|
r12483 | % serve errors | ||
$ hg rollback | ||||
Gilles Moris
|
r13446 | repository tip rolled back to revision 0 (undo serve) | ||
Matt Mackall
|
r12483 | |||
Steven Brown
|
r14093 | 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 | ||||
Adrian Buehlmann
|
r16982 | remote: changegroup hook: HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_URL=remote:http:*: (glob) | ||
Wagner Bruna
|
r17793 | remote: pushkey hook: HG_KEY=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NAMESPACE=phases HG_NEW=0 HG_OLD=1 HG_RET=1 | ||
Steven Brown
|
r14093 | % serve errors | ||
$ hg rollback | ||||
repository tip rolled back to revision 0 (undo serve) | ||||
Steven Brown
|
r13946 | expect success, server lacks the unbundlehash capability | ||
Steven Brown
|
r14011 | $ CAP=unbundlehash | ||
$ . "$TESTDIR/notcapable" | ||||
Steven Brown
|
r13946 | $ 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 | ||||
Adrian Buehlmann
|
r16982 | remote: changegroup hook: HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_URL=remote:http:*: (glob) | ||
Wagner Bruna
|
r17793 | remote: pushkey hook: HG_KEY=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NAMESPACE=phases HG_NEW=0 HG_OLD=1 HG_RET=1 | ||
Steven Brown
|
r13946 | % serve errors | ||
$ hg rollback | ||||
repository tip rolled back to revision 0 (undo serve) | ||||
Wagner Bruna
|
r17793 | expect push success, phase change failure | ||
Adrian Buehlmann
|
r17842 | $ cat > .hg/hgrc <<EOF | ||
> [web] | ||||
> push_ssl = false | ||||
> allow_push = * | ||||
> [hooks] | ||||
> prepushkey = python "$TESTDIR/printenv.py" prepushkey 1 | ||||
> EOF | ||||
Wagner Bruna
|
r17793 | $ 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: prepushkey hook: HG_KEY=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NAMESPACE=phases HG_NEW=0 HG_OLD=1 | ||||
updating ba677d0156c1 to public failed! | ||||
% serve errors | ||||
expect phase change success | ||||
Adrian Buehlmann
|
r17842 | $ echo "prepushkey = python \"$TESTDIR/printenv.py\" prepushkey 0" >> .hg/hgrc | ||
Wagner Bruna
|
r17793 | $ req | ||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
no changes found | ||||
remote: prepushkey hook: HG_KEY=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NAMESPACE=phases HG_NEW=0 HG_OLD=1 | ||||
% serve errors | ||||
[1] | ||||
$ hg rollback | ||||
repository tip rolled back to revision 0 (undo serve) | ||||
Matt Mackall
|
r12483 | expect authorization error: all users denied | ||
$ echo '[web]' > .hg/hgrc | ||||
$ echo 'push_ssl = false' >> .hg/hgrc | ||||
$ echo 'deny_push = *' >> .hg/hgrc | ||||
$ req | ||||
Mads Kiilerich
|
r12643 | pushing to http://localhost:$HGPORT/ | ||
Matt Mackall
|
r12483 | searching for changes | ||
abort: authorization failed | ||||
% serve errors | ||||
Yuya Nishihara
|
r17455 | [255] | ||
Matt Mackall
|
r12483 | |||
expect authorization error: some users denied, users must be authenticated | ||||
$ echo 'deny_push = unperson' >> .hg/hgrc | ||||
$ req | ||||
Mads Kiilerich
|
r12643 | pushing to http://localhost:$HGPORT/ | ||
Matt Mackall
|
r12483 | searching for changes | ||
abort: authorization failed | ||||
% serve errors | ||||
Yuya Nishihara
|
r17455 | [255] | ||
Mads Kiilerich
|
r16913 | |||
$ cd .. | ||||