chiark / gitweb /
0ae9bbc281374fc4b1f23b92aa54f3799e48b712
[dgit.git] / tests / lib
1 #
2
3 exec 2>&1
4 set -x
5
6 . tests/lib-core
7
8 t-set-intree
9
10 : ${DGIT_TEST_DEBUG:=-D}
11 export DGIT_TEST_DEBUG
12
13 root=`pwd`
14 troot=$root/tests
15 testname="${DGIT_TEST_TESTNAME-${0##*/}}"
16
17 tmp=$ADTTMP
18 if [ x"$tmp" = x ]; then
19         mkdir -p tests/tmp
20         tmp=tests/tmp/$testname
21         rm -rf $tmp
22         mkdir $tmp
23 fi
24 cd $tmp
25
26 tmp=`pwd`
27
28 t-set-using-tmp
29
30 ln -f $troot/ssh ssh
31
32 mkdir -p $tmp/gnupg
33 cp $troot/gnupg/* $tmp/gnupg
34 chmod go-rw $tmp/gnupg/*
35
36 mkdir -p $tmp/incoming
37 cat <<END >$tmp/dput.cf
38 [test-dummy]
39 method                  = local
40 incoming                = $tmp/incoming
41 run_dinstall            = 0
42 END
43
44 t-expect-fail () {
45         local mpat="$1"; shift
46         LC_MESSAGES=C "$@" 2>&1 | tee $tmp/t.output
47         test ${PIPESTATUS[0]} != 0
48         egrep "$mpat" $tmp/t.output ||false
49 }
50
51 t-untar () {
52         local tarfile=$1.tar
53         local edittree=$1.edit
54         if test -d "$edittree"; then
55                 cp -al "$edittree"/* .
56         else
57                 tar xf "$tarfile"
58         fi
59 }
60
61 t-worktree () {
62         rm -rf $p
63         t-untar $troot/worktrees/${p}_$1
64 }
65
66 t-git () {
67         p=$1
68         v=$2
69         mkdir -p $tmp/git
70         local gs=$troot/git-srcs/${p}_$v.git
71         (set -e; cd $tmp/git; t-untar $gs)
72 }
73
74 t-git-none () {
75         mkdir -p $tmp/git
76         (set -e; cd $tmp/git; tar xf $troot/git-template.tar)
77 }
78
79 t-has-ancestor () {
80         local now=`git rev-parse HEAD`
81         local ancestor=`git rev-parse $1^{}`
82         local mbase=`git merge-base $ancestor $now`
83         if [ x$mbase != x$ancestor ]; then
84                 fail "not ff $ancestor..$now, $mbase != $ancestor"
85         fi
86 }
87
88 t-prep-newpackage () {
89         p=$1
90         v=$2
91         t-archive-none $p
92         t-git-none
93         t-worktree $v
94         cd $p
95         if ! git-show-ref --verify --quiet refs/heads/master; then
96                 git branch -m dgit/sid master
97                 git remote rm dgit
98         fi
99         cd ..
100 }
101
102 t-archive-none () {
103         p=$1
104         mkdir -p $tmp/aq $tmp/mirror/pool/main
105
106         local suite=sid
107
108         >$tmp/aq/package.$suite.$p
109         t-archive-updated $suite $p
110
111         >$tmp/aq/package.new.$p
112         t-archive-updated new $p
113
114         ln -s sid $tmp/aq/dsc_in_suite/unstable
115         cat <<'END' >$tmp/aq/suites
116 [
117    {
118       "archive" : "ftp-master",
119       "codename" : "sid",
120       "components" : [
121          "main",
122          "contrib",
123          "non-free"
124       ],
125       "name" : "unstable",
126       "dakname" : "unstable"
127    }
128 ]
129 END
130 }
131
132 t-archive-updated () {
133         local suite=$1
134         local p=$2
135         local suitedir=$tmp/aq/dsc_in_suite/$suite
136         mkdir -p $suitedir
137         perl <$tmp/aq/package.$suite.$p >$suitedir/$p -wne '
138                 use JSON;
139                 use strict;
140                 our @v;
141                 m{^(\S+) (\w+) ([^ \t/]+)/(\S+)} or die;
142                 push @v, {
143                         "version" => "$1",
144                         "sha256sum" => "$2",
145                         "component" => "$3",
146                         "filename" => "$4",
147                 };
148                 END {
149                         print to_json \@v or die $!;
150                 }
151         '
152 }
153
154 t-archive-process-incoming () {
155         local suite=$1
156         mv $tmp/incoming/${p}_${v}[._]* $tmp/mirror/pool/main/
157         t-archive-query "$suite"
158 }
159
160 t-archive-query () {
161         local suite=${1-sid}
162         local dscf=main/${p}_${v}.dsc
163         local sha=`sha256sum <$tmp/mirror/pool/$dscf`
164         echo "${v} ${sha%  -} $dscf" >>$tmp/aq/package.$suite.${p}
165         t-archive-updated $suite $p
166 }
167
168 t-archive () {
169         t-archive-none $1
170         v=$2
171         local dscf=${p}_$2.dsc
172         rm -f $tmp/mirror/pool/main/${p}_*
173         ln $troot/pkg-srcs/${p}_${2%-*}* $tmp/mirror/pool/main/
174         t-archive-query
175         rm -rf $tmp/extract
176         mkdir $tmp/extract
177         (set -e; cd $tmp/extract; dpkg-source -x ../mirror/pool/main/$dscf)
178 }
179
180 t-git-dir-time-passes () {
181         touch -d 'last year' $tmp/git/$p.git
182 }
183
184 t-git-dir-check () {
185         local gitdir=$tmp/git/$p.git
186         case "$1" in
187         enoent)
188                 if test -e "$gitdir"; then fail "$gitdir exists"; fi
189                 return
190                 ;;
191         public) wantstat='7[75]5' ;;
192         secret) wantstat='7[70]0' ;;
193         *)      fail "$1 t-git-dir-check ?" ;;
194         esac
195         gotstat=`stat -c%a $gitdir`
196         case "$gotstat" in
197         *$wantstat) return ;;
198         *)      fail "$gitdir has mode $gotstat, expected $wantstat" ;;
199         esac
200 }
201
202 t-rm-dput-dropping () {
203         rm -f $tmp/${p}_${v}_*.upload
204 }
205
206 t-dgit () {
207         local dgit=${DGIT_TEST-dgit}
208         : '
209 {{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{'
210         $dgit --dgit=$dgit --dget:-u --dput:--config=$tmp/dput.cf \
211                 -dtest-dummy $DGIT_TEST_OPTS $DGIT_TEST_DEBUG \
212                 -k39B13D8A "$@"
213         : '}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}
214 '
215 }
216
217 t-diff-nogit () {
218         diff --exclude=.git --exclude=.pc -ruN $*
219 }
220
221 t-cloned-fetched-good () {
222         t-diff-nogit ../extract/$p-${v%-*} .
223         t-clean-on-branch dgit/sid
224         t-refs-same-start
225         t-refs-same \
226                 refs/heads/dgit/sid \
227                 refs/remotes/dgit/dgit/sid
228         t-refs-notexist refs/dgit/unstable refs/remotes/dgit/dgit/unstable
229 }
230
231 t-output () {
232         printf "%s\n" "$1" >$tmp/t.want
233         shift
234         "$@" >$tmp/t.got
235         diff $tmp/t.want $tmp/t.got
236 }
237
238 t-clean-on-branch () {
239         t-output "## $1" git status -b --porcelain
240 }
241
242 t-git-get-ref () {
243         local ref=$1
244         case "$ref" in
245         refs/*) ;;
246         *) fail "t-git-get-ref bad $ref" ;;
247         esac
248         git show-ref -d $1 | perl -ne '
249                 $x = $1 if m#^(\w+) \Q'$1'\E(?:\^\{\})?$#;
250                 END { print "$x\n" if length $x; }
251         '
252 }
253
254 t-ref-same () {
255         local name="$1"
256         local val=`t-git-get-ref $name`
257         t-ref-same-val "$name" $val
258 }
259
260 t-ref-head () {
261         local val=`git rev-parse HEAD`
262         t-ref-same-val HEAD $val
263 }
264
265 t-ref-same-val () {
266         local name="$1"
267         local val=$2
268         case "$t_ref_val" in
269         '')             ;;
270         "$val")         ;;
271         *)              fail "ref varies: $name: $val != $t_ref_val" ;;
272         esac
273         t_ref_val="$val"
274 }
275
276 t-refs-same-start () {
277         t_ref_val=''
278 }
279
280 t-refs-same () {
281         local g
282         for g in $*; do
283                 t-ref-same $g
284         done
285 }
286
287 t-refs-notexist () {
288         local val
289         for g in $*; do
290                 val=`t-git-get-ref $g >$tmp/t.refx`
291                 if [ "x$val" != x ]; then
292                         fail "ref $g unexpectedly exists ($val)"
293                 fi
294         done
295 }
296
297 t-v-tag () {
298         echo refs/tags/debian/${v//\~/_}
299 }
300
301 t-pushed-good () {
302         local branch=$1
303         t-ref-dsc-dgit
304         t-refs-same \
305                 refs/heads/$branch \
306                 `t-v-tag` \
307                 refs/remotes/dgit/dgit/sid
308         t-refs-notexist \
309                 refs/heads/dgit/unstable \
310                 refs/remotes/dgit/dgit/unstable
311         (set -e; cd $tmp/git/$p.git
312          t-refs-same \
313                 refs/dgit/sid \
314                 `t-v-tag`
315          t-refs-notexist \
316                 refs/dgit/unstable
317         )
318         git verify-tag `t-v-tag`
319 }
320
321 t-822-field () {
322         local file=$1
323         local field=$2
324         perl -e '
325                 use Dpkg::Control::Hash;
326                 my $h = new Dpkg::Control::Hash allow_pgp=>1;
327                 $h->parse(\*STDIN,"'"$file"'");
328                 my $val = $h->{"'$field'"},"\n";
329                 die "'"$file $field"'" unless defined $val;
330                 print $val,"\n";
331         ' <$file
332 }
333
334 t-stunt-envvar () {
335         local var=$1
336         local tstunt=$2
337         eval '
338                 case "'$var'" in
339                 "$tstunt:"*)    ;;
340                 *":$tstunt:"*)  ;;
341                 *)              '$var'="$tstunt:$'$var'" ;;
342                 esac
343         '
344 }
345
346 t-tstunt () {
347         local tstunt=$tmp/tstunt
348         t-stunt-envvar PATH $tstunt
349         t-stunt-envvar PERLLIB $tstunt
350         local f
351         for f in "$@"; do
352                 f="./$f"
353                 local d="$tstunt/${f%/*}"
354                 mkdir -p $d
355                 ln -sf "$troot/tstunt/$f" "$d"/.
356         done
357 }
358
359 t-tstunt-parsechangelog () {
360         t-tstunt dpkg-parsechangelog Dpkg/Changelog/Parse.pm
361 }
362
363 t-ref-dsc-dgit () {
364         local dsc=${p}_${v}.dsc
365         local val=`t-822-field $tmp/incoming/$dsc Dgit`
366         perl -e '$_=shift @ARGV; die "$dsc Dgit $_ ?" unless m/^\w+\b/;' "$val"
367         t-ref-same-val $dsc "$val"
368 }
369
370 t-apply-diff () {
371         local v1=$1
372         local v2=$2
373         (cd $troot/pkg-srcs; debdiff ${p}_${v1}.dsc ${p}_${v2}.dsc) \
374                 | patch -p1 -u
375 }
376
377 t-commit () {
378         local msg=$1
379         v=1.$revision
380         dch -v$v --distribution unstable "$1"
381         git add debian/changelog
382         debcommit
383         revision=$(( $revision + 1 ))
384 }
385
386 t-git-config () {
387         git config --global "$@"
388 }
389
390 t-drs () {
391         export DGIT_TEST_TROOT=$troot
392  t-git-config dgit-distro.test-dummy.git-url "ext::$troot/drs-git-ext %S "
393  t-git-config dgit-distro.test-dummy.git-check true
394  t-git-config dgit-distro.test-dummy.git-create true
395         cp $root/tests/gnupg/{dd.gpg,dm.gpg,dm.txt} $tmp/.
396         cp $root/tests/suites $tmp/.
397
398         drs_dispatch=$tmp/distro=test-dummy
399         mkdir $drs_dispatch
400         ln -sf $root $drs_dispatch/dgit-live
401         ln -sf $tmp/git $drs_dispatch/repos
402         ln -sf $tmp/suites $tmp/dm.txt $drs_dispatch/
403         mkdir -p $drs_dispatch/keyrings
404         ln -sf $tmp/dd.gpg $drs_dispatch/keyrings/debian-keyring.gpg
405         ln -sf $tmp/dm.gpg $drs_dispatch/keyrings/debian-maintainers.gpg
406         ln -sf /bin/true $drs_dispatch/policy-hook
407 }
408
409 t-dsd () {
410         t-drs
411  t-git-config dgit-distro.test-dummy.ssh "$troot/dsd-ssh"
412  t-git-config dgit-distro.test-dummy.git-check ssh-cmd
413  t-git-config dgit-distro.test-dummy.git-create true
414  t-git-config dgit-distro.test-dummy.git-url \
415                 "ext::$troot/dsd-ssh X %S /dgit/test-dummy/repos"
416
417  t-git-config dgit-distro.test-dummy.diverts.drs /drs
418  t-git-config dgit-distro.test-dummy/drs.ssh "$troot/ssh"
419  t-git-config dgit-distro.test-dummy/drs.git-url $tmp/git
420  t-git-config dgit-distro.test-dummy/drs.git-check ssh-cmd
421  t-git-config dgit-distro.test-dummy/drs.git-create ssh-cmd
422
423         echo 'no-such-package* drs' >$drs_dispatch/diverts
424 }
425
426 t-policy-admin () {
427         ${DGIT_INFRA_PFX}dgit-repos-admin-debian --repos $tmp/git "$@"
428 }
429
430 t-policy () {
431         local policyhook=$1
432         ln -sf ${DGIT_INFRA_PFX}$policyhook \
433                 $drs_dispatch/policy-hook
434 }
435
436 t-debpolicy () {
437         t-dsd
438         t-policy dgit-repos-policy-debian
439
440         mkdir $tmp/git
441         t-policy-admin create-db
442 }
443
444 t-policy-periodic () {
445         ${DGIT_REPOS_SERVER_TEST-dgit-repos-server} \
446                 test-dummy $drs_dispatch '' --cron
447 }
448
449 t-chain-test () {
450         local ct=$1
451         local d=${0%/*}
452         cd $root
453         export DGIT_TEST_TESTNAME="$testname"
454         export ADTTMP=$tmp
455         exec "$d/$ct"
456 }       
457
458 t-alt-test () {
459         local t=${0##*/}
460         t-${t%%-*}
461         t-chain-test "${t#*-}"
462 }