X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=dgit.git;a=blobdiff_plain;f=tests%2Ftests%2Fdrs-push-rejects;h=640aeae6914cbe8630488b21d3e4be68ad7b3de0;hp=438ba78729e1b15eee8c91b0b095d87719a55e57;hb=9f377842120dd8d6206a3f3f2eb297b3e4907fa8;hpb=af71b895a72a841eb15527f011395981c82ccad1 diff --git a/tests/tests/drs-push-rejects b/tests/tests/drs-push-rejects index 438ba787..640aeae6 100755 --- a/tests/tests/drs-push-rejects +++ b/tests/tests/drs-push-rejects @@ -10,4 +10,187 @@ t-worktree drs cd $p -git push origin HEAD:refs/dgit/sid refs/tags/debian/3-2_dummy1 +mustfail () { + local wantmsg="$1"; shift + t-reporefs pre-push + set +o pipefail + git push origin "$@" 2>&1 |tee $tmp/mustfail.txt + ps="${PIPESTATUS[*]}" + set -o pipefail + case $ps in + "0 0") fail "push unexpectedly succeeded (instead of: $wantmsg)" ;; + *" 0") ;; + *) fail "tee failed" ;; + esac + if ! fgrep "$wantmsg" $tmp/mustfail.txt >/dev/null; then + fail "error message not found" + fi + t-reporefs post-push + diff $tmp/show-refs.{pre,post}-push +} + +mustsucceed () { + t-reporefs pre-push + git push origin "$@" + t-reporefs post-push + if diff $tmp/show-refs.{pre,post}-push >$tmp/show-refs.diff; then + fail "no refs updated" + fi +} + +prep () { + local suite=$1 + local csuite=$2 + cp $tmp/masters/* $tmp/. + tag_signer='-u Senatus' + tag_message="$p release $version for $suite ($csuite) [dgit]" + tag_name=debian/$version + push_spec1="HEAD:refs/dgit/$csuite" + push_spec2="refs/tags/$tag_name" + push_spec="$push_spec1 $push_spec2" +} +mktag () { + git tag -f $tag_signer -m "$tag_message" $tag_name "$@" +} + +mkdir $tmp/masters +cp $tmp/d[dm].* $tmp/masters + +version=3-2_dummy1 + +prep unstable sid +tag_signer='-a' +mktag +mustfail 'missing signature' $push_spec + +git cat-file tag $tag_name >goodtag + +for h in object type tag; do + for how in missing dupe; do + + case $how in + missing) perl -pe 's/^tag /wombat$&/ if 1..m/^$/' badtag ;; + dupe) perl -pe 'print if 1..m/^$/ and m/^'$h' /' badtag ;; + esac + + rm -f badtag.asc + gpg --detach-sign --armor -u Senatus badtag + cat badtag.asc >>badtag + + set +e + LC_MESSAGES=C git hash-object -w -t tag badtag >badtag.hash 2>badtag.err + rc=$? + set -e + + if [ $rc = 128 ] && grep 'fatal: corrupt tag' badtag.err; then + continue + elif [ $rc != 0 ]; then + cat badtag.err + fail "could not make tag" + fi + + read $tmp/suites +mustfail 'unknown suite' $push_spec +cp $root/tests/suites $tmp/. + +# fixme: +# or reject "command string not understood"; +# reject "unknown method" unless $mainfunc; + + +prep unstable sid +mktag +cp $tmp/dm.gpg $tmp/dd.gpg +mustfail 'key not found in keyrings' $push_spec + +prep unstable sid +mktag HEAD~ +mustfail 'tag refers to wrong commit' $push_spec + +prep unstable sid +mktag HEAD~: +mustfail 'tag refers to wrong kind of object' $push_spec + +prep unstable sid +tag_name=debian/wombat +mktag +#git update-ref debian/$version debian/wombat +mustfail 'tag name in tag is wrong' \ + refs/tags/debian/wombat:refs/tags/debian/$version $push_spec1 + +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 + perl -i.bak -pe ' + next unless m/^fingerprint: 3A82860837A0CD32/i../^$/; + ' -e "$1" $tmp/dm.txt + tag_signer='-u Populus' + mktag +} + +git commit --amend --message 'Make it not a fast forward' +version=3-2_dummy2 +prep unstable sid +mktag +mustfail 'not fast forward on dgit branch' +$push_spec1 +$push_spec2 + +git checkout v2 +version=3-2_dummy2 + +prep_dm_mangle '' +perl -i.bak -ne 'print if 1..s/(pari-extra).*\n/$1/' $tmp/dm.txt +mustfail '' $push_spec # malformed (truncated) dm.txt; don't care about msg + +prep_dm_mangle 's/allow:/asponge:/i' +mustfail 'missing Allow section in permission' $push_spec + +prep_dm_mangle 's/\bpari-extra\b/sponge/i' +mustfail "package $p not allowed for key" $push_spec + +prep_dm_mangle 'y/0-9/5-90-4/ if m/^fingerprint:/i' +mustfail "not in permissions list although in keyring" $push_spec + +prep_dm_mangle '' +mustsucceed $push_spec # succeeds + +echo ok.