comparison test/runtime/6888954/vmerrors.sh @ 1490:f03d0a26bf83

6888954: argument formatting for assert() and friends Reviewed-by: kvn, twisti, apetrusenko, never, dcubed
author jcoomes
date Thu, 22 Apr 2010 13:23:15 -0700
parents
children 5b77884bd4b7
comparison
equal deleted inserted replaced
1489:cff162798819 1490:f03d0a26bf83
1 # @test
2 # @bug 6888954
3 # @summary exercise HotSpot error handling code
4 # @author John Coomes
5 # @run shell vmerrors.sh
6
7 # Repeatedly invoke java with a command-line option that causes HotSpot to
8 # produce an error report and terminate just after initialization. Each
9 # invocation is identified by a small integer, <n>, which provokes a different
10 # error (assertion failure, guarantee failure, fatal error, etc.). The output
11 # from stdout/stderr is written to <n>.out and the hs_err_pidXXX.log file is
12 # renamed to <n>.log.
13 #
14 # The automated checking done by this script is minimal. When updating the
15 # fatal error handler it is more useful to run it manually or to use the -retain
16 # option with the jtreg so that test directories are not removed automatically.
17 # To run stand-alone:
18 #
19 # TESTJAVA=/java/home/dir
20 # TESTVMOPTS=...
21 # export TESTJAVA TESTVMOPTS
22 # sh test/runtime/6888954/vmerrors.sh
23
24 ulimit -c 0 # no core files
25
26 i=1
27 rc=0
28
29 assert_re='(assert|guarantee)[(](str|num).*failed: *'
30 guarantee_re='guarantee[(](str|num).*failed: *'
31 fatal_re='fatal error: *'
32 signal_re='(SIGSEGV|EXCEPTION_ACCESS_VIOLATION).* at pc='
33 tail_1='.*expected null'
34 tail_2='.*num='
35
36 for re in \
37 "${assert_re}${tail_1}" "${assert_re}${tail_2}" \
38 "${guarantee_re}${tail_1}" "${guarantee_re}${tail_2}" \
39 "${fatal_re}${tail_1}" "${fatal_re}${tail_2}" \
40 "${fatal_re}.*truncated" "ChunkPool::allocate" \
41 "ShouldNotCall" "ShouldNotReachHere" \
42 "Unimplemented" "$signal_re"
43
44 do
45 i2=$i
46 [ $i -lt 10 ] && i2=0$i
47
48 "$TESTJAVA/bin/java" $TESTVMOPTS -XX:+IgnoreUnrecognizedVMOptions \
49 -XX:ErrorHandlerTest=${i} -version > ${i2}.out 2>&1
50
51 # If ErrorHandlerTest is ignored (product build), stop.
52 #
53 # Using the built-in variable $! to get the pid does not work reliably on
54 # windows; use a wildcard instead.
55 mv hs_err_pid*.log ${i2}.log || exit $rc
56
57 for f in ${i2}.log ${i2}.out
58 do
59 egrep -- "$re" $f > $$
60 if [ $? -ne 0 ]
61 then
62 echo "ErrorHandlerTest=$i failed ($f)"
63 rc=1
64 fi
65 done
66 rm -f $$
67
68 i=$(expr $i + 1)
69 done
70
71 exit $rc