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=afaed4cf248cb0c76f4f2bd6166379159655d089;hp=1a573748f0ccccf1d71649e65e7f128cbfe7f937;hb=6a5bd9349a52be72e3344c02e5337a3bd205939c;hpb=ae6f73de56d388b235980c765acbdb2e205c332e diff --git a/tests/tests/drs-push-rejects b/tests/tests/drs-push-rejects index 1a573748..afaed4cf 100755 --- a/tests/tests/drs-push-rejects +++ b/tests/tests/drs-push-rejects @@ -10,6 +10,9 @@ t-worktree drs cd $p +git remote set-url origin \ + "ext::$troot/drs-git-ext %S /pari-extra.git" + mustfail () { local mpat="$1"; shift t-expect-push-fail "$mpat" \ @@ -27,11 +30,14 @@ mustsucceed () { prep () { local suite=$1 - local csuite=$2 + csuite=$2 cp $tmp/masters/* $tmp/. tag_signer='-u Senatus' tag_message="$p release $version for $suite ($csuite) [dgit]" - tag_name=test-dummy/$version + re-prep +} +re-prep () { + tag_name=$tagpfx/$version push_spec1="HEAD:refs/dgit/$csuite" push_spec2="refs/tags/$tag_name" push_spec="$push_spec1 $push_spec2" @@ -81,6 +87,8 @@ for h in object type tag; do git update-ref refs/tags/$tag_name $badtag mustfail 'multiple headers '$h' in signed tag object' $push_spec + + t-expect-fsck-fail $badtag done done @@ -102,7 +110,8 @@ mustfail 'push is missing tag ref update' $push_spec1 mustfail 'push is missing head ref update' +$push_spec2 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/test-dummy/wombat +mustfail E:'pushing multiple tags|pushing too many similar tags' \ + $push_spec HEAD:refs/tags/$tagpfx/wombat prep unstable sid mktag @@ -129,12 +138,19 @@ mktag HEAD~: mustfail 'tag refers to wrong kind of object' $push_spec prep unstable sid -tag_name=test-dummy/wombat +tag_name=$tagpfx/wombat mktag -#git update-ref test-dummy/$version test-dummy/wombat +#git update-ref $tagpfx/$version $tagpfx/wombat mustfail 'tag name in tag is wrong' \ - refs/tags/test-dummy/wombat:refs/tags/test-dummy/$version $push_spec1 + refs/tags/$tagpfx/wombat:refs/tags/$tagpfx/$version $push_spec1 + +t-make-badcommit +git checkout -b broken $badcommit +prep unstable sid +mktag +mustfail "corrupted object $badcommit" $push_spec +git checkout dgit/sid prep unstable sid mktag mustsucceed $push_spec # succeeds @@ -145,6 +161,12 @@ mustfail 'push is missing head ref update' $push_spec1 +$push_spec2 git commit --allow-empty -m 'Dummy update' mktag mustfail 'not replacing previously-pushed version' +$push_spec1 +$push_spec2 + +t-newtag +re-prep +mktag +mustfail 'not replacing previously-pushed version' +$push_spec1 +$push_spec2 + git reset --hard HEAD~ prep_dm_mangle () { @@ -181,4 +203,4 @@ mustfail "not in permissions list although in keyring" $push_spec prep_dm_mangle '' mustsucceed $push_spec # succeeds -echo ok. +t-ok