X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=tests%2Ftests%2Fdebpolicy-newreject;h=4da568c3199bbec03b76bee202cfaa8a20ae0227;hb=441cf15ffbafea7aa6be4cc04bb0085c8d79063e;hp=10af31fcb81f0ab59293d8be024baca7a1c6f776;hpb=26b8f62b600642b1a469a305c3ed8bc0a165a255;p=dgit.git diff --git a/tests/tests/debpolicy-newreject b/tests/tests/debpolicy-newreject index 10af31fc..4da568c3 100755 --- a/tests/tests/debpolicy-newreject +++ b/tests/tests/debpolicy-newreject @@ -10,6 +10,7 @@ t-prep-newpackage example 1.0 cd $p revision=1 git tag start +t-dgit setup-mergechangelogs echo FORBIDDEN >debian/some-file git add debian/some-file @@ -17,6 +18,7 @@ t-commit 'Commit a forbidden thing' bad=`git rev-parse HEAD:debian/some-file` t-policy-admin taint --global "$bad" "forbidden for testing" +t-policy-admin taint --global "$bad" "forbidden for testing - again" t_expect_push_fail_hook+=' t-git-objects-not-present "" $bad @@ -49,10 +51,12 @@ t-git-dir-check enoent t-commit 'should require --deliberately...questionable' t-dgit build -t-expect-push-fail E:"tag debian/${vanished//./\\.} referred to this object.*all previously pushed versions were found to have been removed" \ +t-expect-push-fail E:"tag $tagpfx/${vanished//./\\.} referred to this object.*all previously pushed versions were found to have been removed" \ t-dgit push --new t-git-dir-check enoent +vanished=$v + t-dgit push --new --deliberately-include-questionable-history t-git-dir-check secret @@ -73,16 +77,45 @@ t-dgit build t-expect-push-fail "HEAD is not a descendant of the archive's version" \ t-dgit push -t-expect-push-fail "Package is in NEW and has not been accepted or rejected yet" \ +t-expect-push-fail \ + "Package is in NEW and has not been accepted or rejected yet" \ t-dgit --deliberately-TEST-dgit-only-not-fast-forward push t-dgit --deliberately-not-fast-forward push -cd $tmp/git/$p.git +cd $dgitrepo t-expect-push-fail "Not a valid object name" \ git cat-file -p $oldobj cd $tmp/$p -echo xxx up to here -echo xxx want to test database lock retry thing on push-and-taint -echo xxx want to t-expect-push-fail leaves HEAD object not dest repo +t-commit 'Still not accepted, will override taint' +t-dgit build +t-expect-push-fail \ + "Package is in NEW and has not been accepted or rejected yet" \ +t-dgit push + +t-dgit push --deliberately-include-questionable-history + +t-archive-process-incoming sid + +t-commit 'Check taint is no longer there' +t-dgit build +t-dgit push + +git checkout -b stoats $tagpfx/$vanished +t-commit 'Simulate accidentally building on rejected version' +t-dgit build +t-expect-push-fail "HEAD is not a descendant of the archive's version" \ +t-dgit push + +: "check that uploader can't force it now" +t-expect-push-fail "not fast forward on dgit branch" \ +t-dgit --deliberately-not-fast-forward push + +t-dgit pull +t-dgit build +t-expect-push-fail \ + 'Reason: rewound suite sid; --deliberately-not-fast-forward specified' \ +t-dgit push + +echo ok.