]> gitweb.ps.run Git - ps-cgit/blob - tests/setup.sh
tests/setup.sh: cleanup test script output and logging
[ps-cgit] / tests / setup.sh
1 # This file should be sourced by all test-scripts
2 #
3 # Main functions:
4 #   prepare_tests(description) - setup for testing, i.e. create repos+config
5 #   run_test(description, script) - run one test, i.e. eval script
6 #
7 # Helper functions
8 #   cgit_query(querystring) - call cgit with the specified querystring
9 #   cgit_url(url) - call cgit with the specified virtual url
10 #
11 # Example script:
12 #
13 # . setup.sh
14 # prepare_tests "html validation"
15 # run_test 'repo index' 'cgit_url "/" | tidy -e'
16 # run_test 'repo summary' 'cgit_url "/foo" | tidy -e'
17
18
19 mkrepo() {
20         name=$1
21         count=$2
22         dir=$PWD
23         test -d $name && return
24         printf "Creating testrepo %s\n" $name
25         mkdir -p $name
26         cd $name
27         git init
28         for ((n=1; n<=count; n++))
29         do
30                 echo $n >file-$n
31                 git add file-$n
32                 git commit -m "commit $n"
33         done
34         cd $dir
35 }
36
37 setup_repos()
38 {
39         rm -rf trash/cache
40         mkdir -p trash/cache
41         mkrepo trash/repos/foo 5 >/dev/null
42         mkrepo trash/repos/bar 50 >/dev/null
43         cat >trash/cgitrc <<EOF
44 virtual-root=/
45 cache-root=$PWD/trash/cache
46
47 nocache=0
48 snapshots=tar.gz tar.bz zip
49 enable-log-filecount=1
50 enable-log-linecount=1
51 summary-log=5
52 summary-branches=5
53 summary-tags=5
54
55 repo.url=foo
56 repo.path=$PWD/trash/repos/foo/.git
57 # Do not specify a description for this repo, as it then will be assigned
58 # the constant value "[no description]" (which actually used to cause a
59 # segfault).
60
61 repo.url=bar
62 repo.path=$PWD/trash/repos/bar/.git
63 repo.desc=the bar repo
64 EOF
65 }
66
67 prepare_tests()
68 {
69         setup_repos
70         rm -f test-output.log 2>/dev/null
71         test_count=0
72         test_failed=0
73         echo "[$0]" "$@" >test-output.log
74         echo "$@" "($0)"
75 }
76
77 tests_done()
78 {
79         printf "\n"
80         if test $test_failed -gt 0
81         then
82                 printf "test: *** %s failure(s), logfile=%s\n" \
83                         $test_failed "$(pwd)/test-output.log"
84                 false
85         fi
86 }
87
88 run_test()
89 {
90         desc=$1
91         script=$2
92         ((test_count++))
93         printf "\ntest %d: name='%s'\n" $test_count "$desc" >>test-output.log
94         printf "test %d: eval='%s'\n" $test_count "$2" >>test-output.log
95         eval "$2" >>test-output.log 2>>test-output.log
96         res=$?
97         printf "test %d: exitcode=%d\n" $test_count $res >>test-output.log
98         if test $res = 0
99         then
100                 printf " %2d) %-60s [ok]\n" $test_count "$desc"
101         else
102                 ((test_failed++))
103                 printf " %2d) %-60s [failed]\n" $test_count "$desc"
104         fi
105 }
106
107 cgit_query()
108 {
109         CGIT_CONFIG="$PWD/trash/cgitrc" QUERY_STRING="$1" "$PWD/../cgit"
110 }
111
112 cgit_url()
113 {
114         CGIT_CONFIG="$PWD/trash/cgitrc" QUERY_STRING="url=$1" "$PWD/../cgit"
115 }
116