summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Jackson <ijackson@chiark.greenend.org.uk>2014-03-05 18:06:53 +0000
committerIan Jackson <ijackson@chiark.greenend.org.uk>2014-03-05 18:29:08 +0000
commitd2ec3ce54547bb810ca19e17049e6148dbbf0801 (patch)
tree7ba279d5b92b49f83bb398eaa86d2dea2805373e
parentc499f617a23518d7eead81e580b313ba1bbede02 (diff)
dgit-repos-server: fix dm parsing, more tests
-rwxr-xr-xdgit-repos-server12
-rwxr-xr-xtests/tests/drs-push-rejects28
2 files changed, 32 insertions, 8 deletions
diff --git a/dgit-repos-server b/dgit-repos-server
index 897e414..33c18f1 100755
--- a/dgit-repos-server
+++ b/dgit-repos-server
@@ -391,12 +391,14 @@ sub dm_txt_check ($$) {
while (<DT>) {
m/^fingerprint:\s+$keyid$/oi
..0 or next;
- m/^./
- or reject "key $keyid missing Allow section in permissions!";
+ if (s/^allow:/ /i..0) {
+ } else {
+ m/^./
+ or reject "key $keyid missing Allow section in permissions!";
+ next;
+ }
# in right stanza...
- s/^allow:/ /i
- ..0 or next;
- s/^\s+//
+ s/^[ \t]+//
or reject "package $package not allowed for key $keyid";
# in allow field...
s/\([^()]+\)//;
diff --git a/tests/tests/drs-push-rejects b/tests/tests/drs-push-rejects
index 6bc9bff..e3b5c7d 100755
--- a/tests/tests/drs-push-rejects
+++ b/tests/tests/drs-push-rejects
@@ -64,15 +64,37 @@ mustfail 'sid != sponge' HEAD:refs/dgit/sponge $push_spec2
# fixme cannot test reject "signature is not of type 00!";
prep unstable sid
+mktag
+cp $tmp/dm.gpg $tmp/dd.gpg
+mustfail 'key not found in keyrings'
+
+prep unstable sid
git push origin $push_spec # succeeds
mktag
mustfail 'not replacing previously-pushed version' $push_spec
+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 checkout v2
version=3-2_dummy2
-prep unstable sid
-tag_signer='-u Populus'
-mktag
+
+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 ''
git push origin $push_spec # succeeds
echo ok.