diff options
author | Karen Arutyunov <karen@codesynthesis.com> | 2020-11-18 12:51:49 +0300 |
---|---|---|
committer | Karen Arutyunov <karen@codesynthesis.com> | 2020-11-19 13:07:57 +0300 |
commit | f91468192ad7066a5e6fa63ddc4e4231e632a457 (patch) | |
tree | 5e399478261a27e8b2298b0f56b08a0e5b7dc3ab /tests/recipe/buildscript/testscript | |
parent | 15507d112650477ad64a5c9b19b4e515124affec (diff) |
Remove target files on ad hoc rule update buildscript error
Diffstat (limited to 'tests/recipe/buildscript/testscript')
-rw-r--r-- | tests/recipe/buildscript/testscript | 73 |
1 files changed, 60 insertions, 13 deletions
diff --git a/tests/recipe/buildscript/testscript b/tests/recipe/buildscript/testscript index 787bafd..6b3f6c7 100644 --- a/tests/recipe/buildscript/testscript +++ b/tests/recipe/buildscript/testscript @@ -17,24 +17,71 @@ : update : { - echo 'bar' >=bar; + : success + : + { + echo 'bar' >=bar; - cat <<EOI >=buildfile; - foo: bar - {{ - cp $path($<) $path($>) - }} - EOI + cat <<EOI >=buildfile; + foo: bar + {{ + cp $path($<) $path($>) + }} + EOI - $* 2>'cp file{foo}'; + $* 2>'cp file{foo}'; - cat <<<foo >'bar'; + cat <<<foo >'bar'; - # While at it, make sure there is no rebuild. - # - $* 2>/'info: dir{./} is up to date'; + # While at it, make sure there is no rebuild. + # + $* 2>/'info: dir{./} is up to date'; - $* clean 2>- + $* clean 2>- + } + + : error + : + : Test that the target file is removed on error and is created on subsequent + : successful update. + : + { + echo 'bar' >=bar; + + cat <<EOI >=buildfile; + foo: bar + {{ + diag concat $< + + t = $path($>) + p = $path($<) + + cp $p $t + + cat $(p).baz >>$t + }} + EOI + + $* 2>>~%EOE% != 0; + concat file{bar.} + %cat: unable to print '.+bar.baz': .+% + buildfile:10:3: error: cat exited with code 1 + %.+ + EOE + + test -f foo != 0; + + echo 'baz' >=bar.baz; + + $* 2>'concat file{bar.}'; + + cat <<<foo >>EOO; + bar + baz + EOO + + $* clean 2>- + } } : clean |