diff options
author | Junio C Hamano <gitster@pobox.com> | 2020-04-29 00:49:55 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2020-04-29 00:49:55 +0200 |
commit | b07c72100f88315d6abef235cee7428fca0886b5 (patch) | |
tree | 909cf1aa4165308fb4d53ccb7669997ba76c0470 /t/README | |
parent | Merge branch 'dd/test-with-busybox' (diff) | |
parent | t/README: suggest how to leave test early with failure (diff) | |
download | git-b07c72100f88315d6abef235cee7428fca0886b5.tar.xz git-b07c72100f88315d6abef235cee7428fca0886b5.zip |
Merge branch 'jc/doc-test-leaving-early'
Document the recommended way to abort a failing test early (e.g. by
exiting a loop), which is to say "return 1".
* jc/doc-test-leaving-early:
t/README: suggest how to leave test early with failure
Diffstat (limited to 't/README')
-rw-r--r-- | t/README | 35 |
1 files changed, 35 insertions, 0 deletions
@@ -547,6 +547,41 @@ Here are the "do's:" reports "ok" or "not ok" to the end user running the tests. Under --verbose, they are shown to help debug the tests. + - Be careful when you loop + + You may need to verify multiple things in a loop, but the + following does not work correctly: + + test_expect_success 'test three things' ' + for i in one two three + do + test_something "$i" + done && + test_something_else + ' + + Because the status of the loop itself is the exit status of the + test_something in the last round, the loop does not fail when + "test_something" for "one" or "two" fails. This is not what you + want. + + Instead, you can break out of the loop immediately when you see a + failure. Because all test_expect_* snippets are executed inside + a function, "return 1" can be used to fail the test immediately + upon a failure: + + test_expect_success 'test three things' ' + for i in one two three + do + test_something "$i" || return 1 + done && + test_something_else + ' + + Note that we still &&-chain the loop to propagate failures from + earlier commands. + + And here are the "don'ts:" - Don't exit() within a <script> part. |