chiark / gitweb /
Test suite: Make t-expect-fail flexible wrt which grep to run
[dgit.git] / tests / tests / debpolicy-newreject
index 1574669a618868f950bc9c2cc993ce852c9dc8c4..82762bb4a2ec7aee479046e9a9b5c4d6fb4fd3a1 100755 (executable)
@@ -2,15 +2,18 @@
 set -e
 . tests/lib
 
+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
 
 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"
@@ -18,5 +21,65 @@ t-policy-admin taint --global "$bad" "forbidden for testing"
 t-dgit build
 t-expect-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 E:"tag debian/${vanished//./\\.} referred to this object.*all previously pushed versions were found to have been removed" \
+t-dgit push --new
+t-git-dir-check enoent
+
+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-fail "HEAD is not a descendant of the archive's version" \
+t-dgit push
+
+t-expect-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
+t-expect-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 test forbidden objects not present
+echo xxx want to check expect fail did not push "(everywhere)"