Commit [4c81c6] Maximize Restore History

Rework test infrastructure to keep track of tests which are disabled

on the platform/feature combination being tested, and to differentiate
between tests disabled because the test is broken in some way, and those
skipped because the platform in question is broken in some way (or the test
is irrelevant for the given feature set).

This takes the form of two new keywords to WITH-TEST -- :BROKEN-ON, which
notes that the test itself is broken for a given feature expression, or
:SKIPPED-ON, which skips a test for a given feature expression. This
information is noted at the end of a test run like so:

Finished running tests.
Status:
Skipped (broken): debug.impure.lisp / (TRACE ENCAPSULATE NIL)
Skipped (broken): debug.impure.lisp / (TRACE-RECURSIVE ENCAPSULATE NIL)
Expected failure: packages.impure.lisp / USE-PACKAGE-CONFLICT-SET
Expected failure: packages.impure.lisp / IMPORT-SINGLE-CONFLICT
(38 tests skipped for this combination of platform and features)
ok
//apparent success (reached end of run-tests.sh normally)
Thu Jun 2 15:59:31 EDT 2011

Note that there is no :WORKS-ON or :ENABLED-ON, even though many of the
read-time conditionals this replaced were for a given feature instead of for
its absence -- you can still do, eg:

(with-test (:name foo :broken-on '(not :x86)) ...)

but such declarations are almost always too general (one exception being
`:skipped-on '(not :sb-thread)'), and IMO, should be discouraged.

While here, re-enable a bunch of tests previously skipped on Solaris which
now work.

Jim Wise Jim Wise 2011-06-06

changed tests/alien.impure.lisp
changed tests/deadline.impure.lisp
changed tests/debug.impure.lisp
changed tests/dynamic-extent.impure.lisp
changed tests/eval.impure.lisp
changed tests/exhaust.impure.lisp
changed tests/float.pure.lisp
changed tests/gc.impure.lisp
changed tests/hash.impure.lisp
changed tests/interface.impure.lisp
changed tests/interface.pure.lisp
changed tests/octets.pure.lisp
changed tests/packages.impure.lisp
changed tests/pathnames.impure.lisp
changed tests/print.impure.lisp
changed tests/run-program.impure.lisp
changed tests/run-tests.lisp
changed tests/stream.impure.lisp
changed tests/test-util.lisp
changed tests/threads.pure.lisp
changed tests/timer.impure.lisp
changed tests/win32-foreign-stack-unwind.impure.lisp
tests/alien.impure.lisp Diff Switch to side-by-side view
Loading...
tests/deadline.impure.lisp Diff Switch to side-by-side view
Loading...
tests/debug.impure.lisp Diff Switch to side-by-side view
Loading...
tests/dynamic-extent.impure.lisp Diff Switch to side-by-side view
Loading...
tests/eval.impure.lisp Diff Switch to side-by-side view
Loading...
tests/exhaust.impure.lisp Diff Switch to side-by-side view
Loading...
tests/float.pure.lisp Diff Switch to side-by-side view
Loading...
tests/gc.impure.lisp Diff Switch to side-by-side view
Loading...
tests/hash.impure.lisp Diff Switch to side-by-side view
Loading...
tests/interface.impure.lisp Diff Switch to side-by-side view
Loading...
tests/interface.pure.lisp Diff Switch to side-by-side view
Loading...
tests/octets.pure.lisp Diff Switch to side-by-side view
Loading...
tests/packages.impure.lisp Diff Switch to side-by-side view
Loading...
tests/pathnames.impure.lisp Diff Switch to side-by-side view
Loading...
tests/print.impure.lisp Diff Switch to side-by-side view
Loading...
tests/run-program.impure.lisp Diff Switch to side-by-side view
Loading...
tests/run-tests.lisp Diff Switch to side-by-side view
Loading...
tests/stream.impure.lisp Diff Switch to side-by-side view
Loading...
tests/test-util.lisp Diff Switch to side-by-side view
Loading...
tests/threads.pure.lisp Diff Switch to side-by-side view
Loading...
tests/timer.impure.lisp Diff Switch to side-by-side view
Loading...
tests/win32-foreign-stack-unwind.impure.lisp Diff Switch to side-by-side view
Loading...