X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=dgit.git;a=blobdiff_plain;f=tests%2Ftests%2Fdebpolicy-newreject;h=1fa6751782df0adc8b5d996d6701da8f76ea9e65;hp=de01a53b329cbb7d89a75fd3f295e37e093e3cf1;hb=5ad9edffc1e0658f287b45feccbd7c97e0bfd412;hpb=8c6bf5e74ef133792ac87ccfa2a57041b7dbfe49 diff --git a/tests/tests/debpolicy-newreject b/tests/tests/debpolicy-newreject index de01a53b..1fa67517 100755 --- a/tests/tests/debpolicy-newreject +++ b/tests/tests/debpolicy-newreject @@ -2,23 +2,120 @@ set -e . tests/lib -export DGIT_DRS_DEBUG=1 +t-tstunt-parsechangelog t-debpolicy -t-prep-newpackage pari-extra 3.1 +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 -git commit -m 'Commit a forbidden thing' +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 +' + +t-dgit build +t-expect-push-fail 'forbidden for testing' \ +t-dgit push --new +t-git-dir-check enoent + +git reset --hard start +t-commit 'will vanish from NEW' +vanished=$v +t-dgit build +t-dgit push --new +t-git-dir-check secret + +t-policy-periodic +t-git-dir-check secret +# pretend it vanished from new: +rm $tmp/incoming/* +t-archive-none example + +t-git-dir-time-passes + +t-policy-periodic +t-git-dir-check enoent + +t-commit 'should require --deliberately...questionable' t-dgit build -t-expect-fail 'forbidden for testing' \ + +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 + +t-policy-periodic +t-git-dir-check secret + +t-archive-process-incoming new +t-git-dir-time-passes + +t-policy-periodic +t-git-dir-check secret + +oldobj=`git rev-parse HEAD` +git reset --hard start +t-commit 'should require --deliberately..not-ff' +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-dgit --deliberately-TEST-dgit-only-not-fast-forward push + +t-dgit --deliberately-not-fast-forward push + +cd $dgitrepo +t-expect-push-fail "Not a valid object name" \ +git cat-file -p $oldobj +cd $tmp/$p + +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 xxx up to here +t-ok