chiark / gitweb /
Tests: Introduce t-set-using-tmp and use it in lib and adhoc
[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-dgit () {
203         local dgit=${DGIT_TEST-dgit}
204         : '
205 {{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{'
206         $dgit --dgit=$dgit --dget:-u --dput:--config=$tmp/dput.cf \
207                 -dtest-dummy $DGIT_TEST_OPTS $DGIT_TEST_DEBUG \
208                 -k39B13D8A "$@"
209         : '}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}
210 '
211 }
212
213 t-diff-nogit () {
214         diff --exclude=.git --exclude=.pc -ruN $*
215 }
216
217 t-cloned-fetched-good () {
218         t-diff-nogit ../extract/$p-${v%-*} .
219         t-clean-on-branch dgit/sid
220         t-refs-same-start
221         t-refs-same \
222                 refs/heads/dgit/sid \
223                 refs/remotes/dgit/dgit/sid
224         t-refs-notexist dgit/unstable remotes/dgit/dgit/unstable
225 }
226
227 t-output () {
228         printf "%s\n" "$1" >$tmp/t.want
229         shift
230         "$@" >$tmp/t.got
231         diff $tmp/t.want $tmp/t.got
232 }
233
234 t-clean-on-branch () {
235         t-output "## $1" git status -b --porcelain
236 }
237
238 t-git-get-ref () {
239         local ref=$1
240         git show-ref -d $1 | perl -ne '
241                 $x = $1 if m#^(\w+) \Q'$1'\E(?:\^\{\})?$#;
242                 END { print "$x\n" if length $x; }
243         '
244 }
245
246 t-ref-same () {
247         local name="$1"
248         local val=`t-git-get-ref $name`
249         t-ref-same-val "$name" $val
250 }
251
252 t-ref-head () {
253         local val=`git rev-parse HEAD`
254         t-ref-same-val HEAD $val
255 }
256
257 t-ref-same-val () {
258         local name="$1"
259         local val=$2
260         case "$t_ref_val" in
261         '')             ;;
262         "$val")         ;;
263         *)              fail "ref varies: $name: $val != $t_ref_val" ;;
264         esac
265         t_ref_val="$val"
266 }
267
268 t-refs-same-start () {
269         t_ref_val=''
270 }
271
272 t-refs-same () {
273         local g
274         for g in $*; do
275                 t-ref-same $g
276         done
277 }
278
279 t-refs-notexist () {
280         local val
281         for g in $*; do
282                 val=`t-git-get-ref $g >$tmp/t.refx`
283                 if [ "x$val" != x ]; then
284                         fail "ref $g unexpectedly exists ($val)"
285                 fi
286         done
287 }
288
289 t-v-tag () {
290         echo refs/tags/debian/${v//\~/_}
291 }
292
293 t-pushed-good () {
294         local branch=$1
295         t-ref-dsc-dgit
296         t-refs-same \
297                 refs/heads/$branch \
298                 `t-v-tag` \
299                 refs/remotes/dgit/dgit/sid
300         t-refs-notexist \
301                 refs/heads/dgit/unstable \
302                 refs/remotes/dgit/dgit/unstable
303         (set -e; cd $tmp/git/$p.git
304          t-refs-same \
305                 refs/dgit/sid \
306                 `t-v-tag`
307          t-refs-notexist \
308                 refs/dgit/unstable
309         )
310         git verify-tag `t-v-tag`
311 }
312
313 t-822-field () {
314         local file=$1
315         local field=$2
316         perl -e '
317                 use Dpkg::Control::Hash;
318                 my $h = new Dpkg::Control::Hash allow_pgp=>1;
319                 $h->parse(\*STDIN,"'"$file"'");
320                 my $val = $h->{"'$field'"},"\n";
321                 die "'"$file $field"'" unless defined $val;
322                 print $val,"\n";
323         ' <$file
324 }
325
326 t-ref-dsc-dgit () {
327         local dsc=${p}_${v}.dsc
328         local val=`t-822-field $tmp/incoming/$dsc Dgit`
329         perl -e '$_=shift @ARGV; die "$dsc Dgit $_ ?" unless m/^\w+\b/;' "$val"
330         t-ref-same-val $dsc "$val"
331 }
332
333 t-apply-diff () {
334         local v1=$1
335         local v2=$2
336         (cd $troot/pkg-srcs; debdiff ${p}_${v1}.dsc ${p}_${v2}.dsc) \
337                 | patch -p1 -u
338 }
339
340 t-git-config () {
341         git config --global "$@"
342 }
343
344 t-drs () {
345         export DGIT_TEST_TROOT=$troot
346  t-git-config dgit-distro.test-dummy.git-url "ext::$troot/drs-git-ext %S "
347  t-git-config dgit-distro.test-dummy.git-check true
348  t-git-config dgit-distro.test-dummy.git-create true
349         cp $root/tests/gnupg/{dd.gpg,dm.gpg,dm.txt} $tmp/.
350         cp $root/tests/suites $tmp/.
351
352         drs_dispatch=$tmp/distro=test-dummy
353         mkdir $drs_dispatch
354         ln -sf $root $drs_dispatch/dgit-live
355         ln -sf $tmp/git $drs_dispatch/repos
356         ln -sf $tmp/suites $tmp/dm.txt $drs_dispatch/
357         mkdir -p $drs_dispatch/keyrings
358         ln -sf $tmp/dd.gpg $drs_dispatch/keyrings/debian-keyring.gpg
359         ln -sf $tmp/dm.gpg $drs_dispatch/keyrings/debian-maintainers.gpg
360         ln -sf /bin/true $drs_dispatch/policy-hook
361 }
362
363 t-dsd () {
364         t-drs
365  t-git-config dgit-distro.test-dummy.ssh "$troot/dsd-ssh"
366  t-git-config dgit-distro.test-dummy.git-check ssh-cmd
367  t-git-config dgit-distro.test-dummy.git-create true
368  t-git-config dgit-distro.test-dummy.git-url \
369                 "ext::$troot/dsd-ssh X %S /dgit/test-dummy/repos"
370
371  t-git-config dgit-distro.test-dummy.diverts.drs /drs
372  t-git-config dgit-distro.test-dummy/drs.ssh "$troot/ssh"
373  t-git-config dgit-distro.test-dummy/drs.git-url $tmp/git
374  t-git-config dgit-distro.test-dummy/drs.git-check ssh-cmd
375  t-git-config dgit-distro.test-dummy/drs.git-create ssh-cmd
376
377         echo 'no-such-package* drs' >$drs_dispatch/diverts
378 }
379
380 t-policy-admin () {
381         ${DGIT_INFRA_PFX}dgit-repos-admin-debian --repos $tmp/git "$@"
382 }
383
384 t-debpolicy () {
385         t-dsd
386
387         ln -sf ${DGIT_INFRA_PFX}dgit-repos-policy-debian \
388                 $drs_dispatch/policy-hook
389
390         mkdir $tmp/git
391         t-policy-admin create-db
392 }
393
394 t-policy-periodic () {
395         ${DGIT_REPOS_SERVER_TEST-dgit-repos-server} \
396                 test-dummy $drs_dispatch '' --cron
397 }
398
399 t-chain-test () {
400         local ct=$1
401         local d=${0%/*}
402         cd $root
403         export DGIT_TEST_TESTNAME="$testname"
404         export ADTTMP=$tmp
405         exec "$d/$ct"
406 }       
407
408 t-alt-test () {
409         local t=${0##*/}
410         t-${t%%-*}
411         t-chain-test "${t#*-}"
412 }