X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=tests%2Ftests%2Fdrs-push-rejects;h=640aeae6914cbe8630488b21d3e4be68ad7b3de0;hb=9f377842120dd8d6206a3f3f2eb297b3e4907fa8;hp=36d4dab94602cbc87ae0c4d12c040b50635e99be;hpb=3fde94933fce6b3b0bfefda8d7dab486a6d22bc8;p=dgit.git diff --git a/tests/tests/drs-push-rejects b/tests/tests/drs-push-rejects index 36d4dab9..640aeae6 100755 --- a/tests/tests/drs-push-rejects +++ b/tests/tests/drs-push-rejects @@ -10,21 +10,13 @@ t-worktree drs cd $p -reporefs () { - (set -e - if test -d $tmp/git/$p.git; then - cd $tmp/git/$p.git - git show-ref - fi) -} - mustfail () { local wantmsg="$1"; shift - reporefs >$tmp/show-refs.pre-push - set +e + t-reporefs pre-push + set +o pipefail git push origin "$@" 2>&1 |tee $tmp/mustfail.txt ps="${PIPESTATUS[*]}" - set -e + set -o pipefail case $ps in "0 0") fail "push unexpectedly succeeded (instead of: $wantmsg)" ;; *" 0") ;; @@ -33,14 +25,14 @@ mustfail () { if ! fgrep "$wantmsg" $tmp/mustfail.txt >/dev/null; then fail "error message not found" fi - reporefs >$tmp/show-refs.post-push + t-reporefs post-push diff $tmp/show-refs.{pre,post}-push } mustsucceed () { - reporefs >$tmp/show-refs.pre-push + t-reporefs pre-push git push origin "$@" - reporefs >$tmp/show-refs.post-push + t-reporefs post-push if diff $tmp/show-refs.{pre,post}-push >$tmp/show-refs.diff; then fail "no refs updated" fi @@ -86,7 +78,7 @@ for h in object type tag; do cat badtag.asc >>badtag set +e - LC_ALL=C git hash-object -w -t tag badtag >badtag.hash 2>badtag.err + LC_MESSAGES=C git hash-object -w -t tag badtag >badtag.hash 2>badtag.err rc=$? set -e @@ -124,8 +116,13 @@ mustfail 'pushing unexpected ref' $push_spec HEAD:refs/wombat mustfail 'pushing multiple heads' $push_spec HEAD:refs/dgit/wombat mustfail 'pushing multiple tags' $push_spec HEAD:refs/tags/debian/wombat +prep unstable sid +mktag +echo woody >$tmp/suites +mustfail 'unknown suite' $push_spec +cp $root/tests/suites $tmp/. + # fixme: -# reject "unknown suite"; # or reject "command string not understood"; # reject "unknown method" unless $mainfunc; @@ -154,8 +151,13 @@ prep unstable sid mktag mustsucceed $push_spec # succeeds +mktag +mustfail 'push is missing head ref update' $push_spec + +git commit --allow-empty -m 'Dummy update' mktag mustfail 'not replacing previously-pushed version' $push_spec +git reset --hard HEAD~ prep_dm_mangle () { prep unstable sid