]>
Commit | Line | Data |
---|---|---|
e1970ce4 JH |
1 | #!/bin/sh |
2 | # | |
3 | # Copyright (c) 2005 Junio C Hamano | |
4 | # | |
5 | ||
6 | # For repeatability, reset the environment to known value. | |
7 | LANG=C | |
899460f3 | 8 | LC_ALL=C |
d9bdd39e | 9 | PAGER=cat |
e1970ce4 | 10 | TZ=UTC |
899460f3 | 11 | export LANG LC_ALL PAGER TZ |
8ff99e74 EW |
12 | EDITOR=: |
13 | VISUAL=: | |
18508c39 | 14 | unset GIT_EDITOR |
e1970ce4 JH |
15 | unset AUTHOR_DATE |
16 | unset AUTHOR_EMAIL | |
17 | unset AUTHOR_NAME | |
18 | unset COMMIT_AUTHOR_EMAIL | |
19 | unset COMMIT_AUTHOR_NAME | |
28a94f88 | 20 | unset EMAIL |
e1970ce4 JH |
21 | unset GIT_ALTERNATE_OBJECT_DIRECTORIES |
22 | unset GIT_AUTHOR_DATE | |
29e55cd5 JH |
23 | GIT_AUTHOR_EMAIL=author@example.com |
24 | GIT_AUTHOR_NAME='A U Thor' | |
6677c466 | 25 | unset GIT_COMMITTER_DATE |
29e55cd5 JH |
26 | GIT_COMMITTER_EMAIL=committer@example.com |
27 | GIT_COMMITTER_NAME='C O Mitter' | |
e1970ce4 JH |
28 | unset GIT_DIFF_OPTS |
29 | unset GIT_DIR | |
892c41b9 | 30 | unset GIT_WORK_TREE |
e1970ce4 JH |
31 | unset GIT_EXTERNAL_DIFF |
32 | unset GIT_INDEX_FILE | |
33 | unset GIT_OBJECT_DIRECTORY | |
34 | unset SHA1_FILE_DIRECTORIES | |
35 | unset SHA1_FILE_DIRECTORY | |
8d0fc48f SP |
36 | GIT_MERGE_VERBOSITY=5 |
37 | export GIT_MERGE_VERBOSITY | |
29e55cd5 JH |
38 | export GIT_AUTHOR_EMAIL GIT_AUTHOR_NAME |
39 | export GIT_COMMITTER_EMAIL GIT_COMMITTER_NAME | |
8ff99e74 | 40 | export EDITOR VISUAL |
e1970ce4 | 41 | |
886a3907 JH |
42 | # Protect ourselves from common misconfiguration to export |
43 | # CDPATH into the environment | |
44 | unset CDPATH | |
45 | ||
3d5c0cc9 | 46 | case $(echo $GIT_TRACE |tr "[A-Z]" "[a-z]") in |
6ce4e61f CC |
47 | 1|2|true) |
48 | echo "* warning: Some tests will not work if GIT_TRACE" \ | |
49 | "is set as to trace on STDERR ! *" | |
50 | echo "* warning: Please set GIT_TRACE to something" \ | |
51 | "other than 1, 2 or true ! *" | |
52 | ;; | |
53 | esac | |
54 | ||
e1970ce4 JH |
55 | # Each test should start with something like this, after copyright notices: |
56 | # | |
57 | # test_description='Description of this test... | |
58 | # This test checks if command xyzzy does the right thing... | |
59 | # ' | |
60 | # . ./test-lib.sh | |
61 | ||
55db1df0 | 62 | [ "x$TERM" != "xdumb" ] && |
f31dfa60 | 63 | [ -t 1 ] && |
55db1df0 PH |
64 | tput bold >/dev/null 2>&1 && |
65 | tput setaf 1 >/dev/null 2>&1 && | |
66 | tput sgr0 >/dev/null 2>&1 && | |
67 | color=t | |
e1970ce4 | 68 | |
e1970ce4 JH |
69 | while test "$#" -ne 0 |
70 | do | |
71 | case "$1" in | |
72 | -d|--d|--de|--deb|--debu|--debug) | |
73 | debug=t; shift ;; | |
886856ab JH |
74 | -i|--i|--im|--imm|--imme|--immed|--immedi|--immedia|--immediat|--immediate) |
75 | immediate=t; shift ;; | |
e1970ce4 | 76 | -h|--h|--he|--hel|--help) |
570f3226 | 77 | help=t; shift ;; |
e1970ce4 JH |
78 | -v|--v|--ve|--ver|--verb|--verbo|--verbos|--verbose) |
79 | verbose=t; shift ;; | |
1ece1274 PH |
80 | -q|--q|--qu|--qui|--quie|--quiet) |
81 | quiet=t; shift ;; | |
55db1df0 PH |
82 | --no-color) |
83 | color=; shift ;; | |
abb7c7b3 | 84 | --no-python) |
7cdbff14 JH |
85 | # noop now... |
86 | shift ;; | |
e1970ce4 JH |
87 | *) |
88 | break ;; | |
89 | esac | |
90 | done | |
91 | ||
55db1df0 PH |
92 | if test -n "$color"; then |
93 | say_color () { | |
94 | case "$1" in | |
95 | error) tput bold; tput setaf 1;; # bold red | |
96 | skip) tput bold; tput setaf 2;; # bold green | |
97 | pass) tput setaf 2;; # green | |
98 | info) tput setaf 3;; # brown | |
1ece1274 | 99 | *) test -n "$quiet" && return;; |
55db1df0 PH |
100 | esac |
101 | shift | |
102 | echo "* $*" | |
103 | tput sgr0 | |
104 | } | |
105 | else | |
106 | say_color() { | |
1ece1274 | 107 | test -z "$1" && test -n "$quiet" && return |
55db1df0 PH |
108 | shift |
109 | echo "* $*" | |
110 | } | |
111 | fi | |
112 | ||
113 | error () { | |
114 | say_color error "error: $*" | |
115 | trap - exit | |
116 | exit 1 | |
117 | } | |
118 | ||
119 | say () { | |
120 | say_color info "$*" | |
121 | } | |
122 | ||
570f3226 MB |
123 | test "${test_description}" != "" || |
124 | error "Test script did not set test_description." | |
125 | ||
126 | if test "$help" = "t" | |
127 | then | |
128 | echo "$test_description" | |
129 | exit 0 | |
130 | fi | |
131 | ||
4d9d62fa | 132 | exec 5>&1 |
e1970ce4 JH |
133 | if test "$verbose" = "t" |
134 | then | |
135 | exec 4>&2 3>&1 | |
136 | else | |
137 | exec 4>/dev/null 3>/dev/null | |
138 | fi | |
139 | ||
140 | test_failure=0 | |
141 | test_count=0 | |
41ac414e JH |
142 | test_fixed=0 |
143 | test_broken=0 | |
e1970ce4 | 144 | |
41184273 PR |
145 | trap 'echo >&5 "FATAL: Unexpected exit with code $?"; exit 1' exit |
146 | ||
04509738 JH |
147 | test_tick () { |
148 | if test -z "${test_tick+set}" | |
149 | then | |
21afc41c | 150 | test_tick=1112911993 |
04509738 JH |
151 | else |
152 | test_tick=$(($test_tick + 60)) | |
153 | fi | |
21afc41c JH |
154 | GIT_COMMITTER_DATE="$test_tick -0700" |
155 | GIT_AUTHOR_DATE="$test_tick -0700" | |
04509738 JH |
156 | export GIT_COMMITTER_DATE GIT_AUTHOR_DATE |
157 | } | |
e1970ce4 | 158 | |
886856ab JH |
159 | # You are not expected to call test_ok_ and test_failure_ directly, use |
160 | # the text_expect_* functions instead. | |
161 | ||
162 | test_ok_ () { | |
e1970ce4 | 163 | test_count=$(expr "$test_count" + 1) |
55db1df0 | 164 | say_color "" " ok $test_count: $@" |
e1970ce4 JH |
165 | } |
166 | ||
886856ab | 167 | test_failure_ () { |
e1970ce4 JH |
168 | test_count=$(expr "$test_count" + 1) |
169 | test_failure=$(expr "$test_failure" + 1); | |
55db1df0 | 170 | say_color error "FAIL $test_count: $1" |
bf0dd8a8 JH |
171 | shift |
172 | echo "$@" | sed -e 's/^/ /' | |
41184273 | 173 | test "$immediate" = "" || { trap - exit; exit 1; } |
886856ab JH |
174 | } |
175 | ||
41ac414e JH |
176 | test_known_broken_ok_ () { |
177 | test_count=$(expr "$test_count" + 1) | |
178 | test_fixed=$(($test_fixed+1)) | |
179 | say_color "" " FIXED $test_count: $@" | |
180 | } | |
181 | ||
182 | test_known_broken_failure_ () { | |
183 | test_count=$(expr "$test_count" + 1) | |
184 | test_broken=$(($test_broken+1)) | |
185 | say_color skip " still broken $test_count: $@" | |
186 | } | |
886856ab JH |
187 | |
188 | test_debug () { | |
8e832ebc | 189 | test "$debug" = "" || eval "$1" |
e1970ce4 JH |
190 | } |
191 | ||
4d9d62fa | 192 | test_run_ () { |
4d9d62fa PR |
193 | eval >&3 2>&4 "$1" |
194 | eval_ret="$?" | |
4d9d62fa PR |
195 | return 0 |
196 | } | |
197 | ||
04ece593 JH |
198 | test_skip () { |
199 | this_test=$(expr "./$0" : '.*/\(t[0-9]*\)-[^/]*$') | |
200 | this_test="$this_test.$(expr "$test_count" + 1)" | |
201 | to_skip= | |
202 | for skp in $GIT_SKIP_TESTS | |
203 | do | |
204 | case "$this_test" in | |
205 | $skp) | |
206 | to_skip=t | |
207 | esac | |
208 | done | |
209 | case "$to_skip" in | |
210 | t) | |
55db1df0 | 211 | say_color skip >&3 "skipping test: $@" |
04ece593 | 212 | test_count=$(expr "$test_count" + 1) |
55db1df0 | 213 | say_color skip "skip $test_count: $1" |
04ece593 JH |
214 | : true |
215 | ;; | |
216 | *) | |
217 | false | |
218 | ;; | |
219 | esac | |
220 | } | |
221 | ||
e1970ce4 | 222 | test_expect_failure () { |
8e832ebc | 223 | test "$#" = 2 || |
e1970ce4 | 224 | error "bug in the test script: not 2 parameters to test-expect-failure" |
04ece593 | 225 | if ! test_skip "$@" |
e1970ce4 | 226 | then |
41ac414e | 227 | say >&3 "checking known breakage: $2" |
04ece593 | 228 | test_run_ "$2" |
41ac414e | 229 | if [ "$?" = 0 -a "$eval_ret" = 0 ] |
04ece593 | 230 | then |
41ac414e | 231 | test_known_broken_ok_ "$1" |
04ece593 | 232 | else |
41ac414e | 233 | test_known_broken_failure_ "$1" |
04ece593 | 234 | fi |
e1970ce4 | 235 | fi |
7a0cf2d0 | 236 | echo >&3 "" |
e1970ce4 JH |
237 | } |
238 | ||
239 | test_expect_success () { | |
8e832ebc | 240 | test "$#" = 2 || |
e1970ce4 | 241 | error "bug in the test script: not 2 parameters to test-expect-success" |
04ece593 | 242 | if ! test_skip "$@" |
e1970ce4 | 243 | then |
04ece593 JH |
244 | say >&3 "expecting success: $2" |
245 | test_run_ "$2" | |
246 | if [ "$?" = 0 -a "$eval_ret" = 0 ] | |
247 | then | |
248 | test_ok_ "$1" | |
249 | else | |
250 | test_failure_ "$@" | |
251 | fi | |
e1970ce4 | 252 | fi |
7a0cf2d0 | 253 | echo >&3 "" |
e1970ce4 JH |
254 | } |
255 | ||
d3bfdb75 FK |
256 | test_expect_code () { |
257 | test "$#" = 3 || | |
258 | error "bug in the test script: not 3 parameters to test-expect-code" | |
04ece593 | 259 | if ! test_skip "$@" |
d3bfdb75 | 260 | then |
04ece593 JH |
261 | say >&3 "expecting exit code $1: $3" |
262 | test_run_ "$3" | |
263 | if [ "$?" = 0 -a "$eval_ret" = "$1" ] | |
264 | then | |
265 | test_ok_ "$2" | |
266 | else | |
267 | test_failure_ "$@" | |
268 | fi | |
d3bfdb75 | 269 | fi |
7a0cf2d0 | 270 | echo >&3 "" |
d3bfdb75 FK |
271 | } |
272 | ||
0509eb21 | 273 | # Most tests can use the created repository, but some may need to create more. |
eedf8f97 CW |
274 | # Usage: test_create_repo <directory> |
275 | test_create_repo () { | |
276 | test "$#" = 1 || | |
277 | error "bug in the test script: not 1 parameter to test-create-repo" | |
278 | owd=`pwd` | |
279 | repo="$1" | |
280 | mkdir "$repo" | |
281 | cd "$repo" || error "Cannot setup test environment" | |
5c94f87e NP |
282 | "$GIT_EXEC_PATH/git" init --template=$GIT_EXEC_PATH/templates/blt/ >/dev/null 2>&1 || |
283 | error "cannot run git init -- have you built things yet?" | |
eedf8f97 CW |
284 | mv .git/hooks .git/hooks-disabled |
285 | cd "$owd" | |
286 | } | |
a6080a0a | 287 | |
e1970ce4 | 288 | test_done () { |
41184273 | 289 | trap - exit |
41ac414e JH |
290 | |
291 | if test "$test_fixed" != 0 | |
292 | then | |
293 | say_color pass "fixed $test_fixed known breakage(s)" | |
294 | fi | |
295 | if test "$test_broken" != 0 | |
296 | then | |
297 | say_color error "still have $test_broken known breakage(s)" | |
298 | fi | |
e1970ce4 | 299 | case "$test_failure" in |
10b94e28 | 300 | 0) |
e1970ce4 JH |
301 | # We could: |
302 | # cd .. && rm -fr trash | |
303 | # but that means we forbid any tests that use their own | |
304 | # subdirectory from calling test_done without coming back | |
305 | # to where they started from. | |
306 | # The Makefile provided will clean this test area so | |
307 | # we will leave things as they are. | |
308 | ||
55db1df0 | 309 | say_color pass "passed all $test_count test(s)" |
e1970ce4 JH |
310 | exit 0 ;; |
311 | ||
312 | *) | |
55db1df0 | 313 | say_color error "failed $test_failure among $test_count test(s)" |
e1970ce4 JH |
314 | exit 1 ;; |
315 | ||
316 | esac | |
317 | } | |
318 | ||
319 | # Test the binaries we have just built. The tests are kept in | |
320 | # t/ subdirectory and are run in trash subdirectory. | |
321 | PATH=$(pwd)/..:$PATH | |
a0fa2a10 | 322 | GIT_EXEC_PATH=$(pwd)/.. |
8683a45d | 323 | GIT_TEMPLATE_DIR=$(pwd)/../templates/blt |
8565d2d8 JS |
324 | GIT_CONFIG=.git/config |
325 | export PATH GIT_EXEC_PATH GIT_TEMPLATE_DIR GIT_CONFIG | |
49ccb087 | 326 | |
6fcca938 PB |
327 | GITPERLLIB=$(pwd)/../perl/blib/lib:$(pwd)/../perl/blib/arch/auto/Git |
328 | export GITPERLLIB | |
eea42069 JH |
329 | test -d ../templates/blt || { |
330 | error "You haven't built things yet, have you?" | |
331 | } | |
e1970ce4 | 332 | |
56cf9806 EW |
333 | if ! test -x ../test-chmtime; then |
334 | echo >&2 'You need to build test-chmtime:' | |
335 | echo >&2 'Run "make test-chmtime" in the source (toplevel) directory' | |
336 | exit 1 | |
337 | fi | |
338 | ||
e1970ce4 JH |
339 | # Test repository |
340 | test=trash | |
341 | rm -fr "$test" | |
eedf8f97 CW |
342 | test_create_repo $test |
343 | cd "$test" | |
04ece593 JH |
344 | |
345 | this_test=$(expr "./$0" : '.*/\(t[0-9]*\)-[^/]*$') | |
346 | for skp in $GIT_SKIP_TESTS | |
347 | do | |
348 | to_skip= | |
349 | for skp in $GIT_SKIP_TESTS | |
350 | do | |
351 | case "$this_test" in | |
352 | $skp) | |
353 | to_skip=t | |
354 | esac | |
355 | done | |
356 | case "$to_skip" in | |
357 | t) | |
55db1df0 PH |
358 | say_color skip >&3 "skipping test $this_test altogether" |
359 | say_color skip "skip all tests in $this_test" | |
04ece593 JH |
360 | test_done |
361 | esac | |
362 | done |