test-push-http.t
202 lines
| 6.1 KiB
| text/troff
|
Tads3Lexer
/ tests / test-push-http.t
Matt Mackall
|
r22046 | #require killdaemons | ||
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=$? | ||
Matt Mackall
|
r25474 | > killdaemons.py | ||
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 | ||||
Matt Harbison
|
r34939 | $ cat > $TESTTMP/hook.sh <<'EOF' | ||
> echo "phase-move: $HG_NODE: $HG_OLDPHASE -> $HG_PHASE" | ||||
> EOF | ||||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
> allow_push = * | ||||
> [hooks] | ||||
> changegroup = sh -c "printenv.py changegroup 0" | ||||
> pushkey = sh -c "printenv.py pushkey 0" | ||||
Matt Harbison
|
r34939 | > txnclose-phase.test = sh $TESTTMP/hook.sh | ||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
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 | ||||
Kevin Bullock
|
r34877 | remote: phase-move: cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b: draft -> public | ||
remote: phase-move: ba677d0156c1196c1a699fa53f390dcfc3ce3872: -> public | ||||
Augie Fackler
|
r31815 | remote: changegroup hook: HG_BUNDLE2=1 HG_HOOKNAME=changegroup HG_HOOKTYPE=changegroup HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NODE_LAST=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_TXNID=TXN:$ID$ HG_URL=remote:http:$LOCALIP: (glob) | ||
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 | ||||
Kevin Bullock
|
r34877 | remote: phase-move: cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b: draft -> public | ||
remote: phase-move: ba677d0156c1196c1a699fa53f390dcfc3ce3872: -> public | ||||
Augie Fackler
|
r31815 | remote: changegroup hook: HG_BUNDLE2=1 HG_HOOKNAME=changegroup HG_HOOKTYPE=changegroup HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NODE_LAST=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_TXNID=TXN:$ID$ HG_URL=remote:http:$LOCALIP: (glob) | ||
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 | ||||
Kevin Bullock
|
r34877 | remote: phase-move: cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b: draft -> public | ||
remote: phase-move: ba677d0156c1196c1a699fa53f390dcfc3ce3872: -> public | ||||
Augie Fackler
|
r31815 | remote: changegroup hook: HG_BUNDLE2=1 HG_HOOKNAME=changegroup HG_HOOKTYPE=changegroup HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NODE_LAST=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_SOURCE=serve HG_TXNID=TXN:$ID$ HG_URL=remote:http:$LOCALIP: (glob) | ||
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] | ||||
FUJIWARA Katsunori
|
r30234 | > prepushkey = sh -c "printenv.py prepushkey 1" | ||
Boris Feld
|
r34837 | > [devel] | ||
> legacy.exchange=phases | ||||
Adrian Buehlmann
|
r17842 | > 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 | ||||
Augie Fackler
|
r31815 | remote: prepushkey hook: HG_BUNDLE2=1 HG_HOOKNAME=prepushkey HG_HOOKTYPE=prepushkey HG_KEY=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NAMESPACE=phases HG_NEW=0 HG_NODE=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_NODE_LAST=ba677d0156c1196c1a699fa53f390dcfc3ce3872 HG_OLD=1 HG_PENDING=$TESTTMP/test HG_PHASES_MOVED=1 HG_SOURCE=serve HG_TXNID=TXN:$ID$ HG_URL=remote:http:$LOCALIP: (glob) | ||
Pierre-Yves David
|
r25390 | remote: pushkey-abort: prepushkey hook exited with status 1 | ||
Pierre-Yves David
|
r25502 | remote: transaction abort! | ||
remote: rollback completed | ||||
abort: updating ba677d0156c1 to public failed | ||||
Wagner Bruna
|
r17793 | % serve errors | ||
Pierre-Yves David
|
r25502 | [255] | ||
Wagner Bruna
|
r17793 | |||
expect phase change success | ||||
FUJIWARA Katsunori
|
r30234 | $ cat >> .hg/hgrc <<EOF | ||
> prepushkey = sh -c "printenv.py prepushkey 0" | ||||
Boris Feld
|
r34837 | > [devel] | ||
> legacy.exchange= | ||||
FUJIWARA Katsunori
|
r30234 | > EOF | ||
Wagner Bruna
|
r17793 | $ req | ||
pushing to http://localhost:$HGPORT/ | ||||
searching for changes | ||||
Pierre-Yves David
|
r25502 | remote: adding changesets | ||
remote: adding manifests | ||||
remote: adding file changes | ||||
remote: added 1 changesets with 1 changes to 1 files | ||||
Wagner Bruna
|
r17793 | % serve errors | ||
$ 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 | |||
Augie Fackler
|
r33664 | $ cat > .hg/hgrc <<EOF | ||
> [web] | ||||
> push_ssl = false | ||||
> allow_push = * | ||||
> [experimental] | ||||
> httppostargs=true | ||||
> 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 | ||||
Mads Kiilerich
|
r16913 | $ cd .. | ||