racket/collects/tests/r6rs
2008-07-24 00:23:05 +00:00
..
arithmetic more r6rs test missing record-type-descriptors 2008-07-23 20:58:43 +00:00
io r6rs test changes: change utf-8 to latin-1 as suggested by Will, and add missing tests for some carry functions 2008-07-23 15:40:09 +00:00
records finish fishing records/syntactic tests 2008-07-23 00:57:42 +00:00
run R6RS tests: sps files for more convenient testing, README on how to run 2008-07-21 22:16:19 +00:00
base.sls some r6rs test suite fixes 2008-07-21 23:10:59 +00:00
bytevectors.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
conditions.sls R6RS test repairs form Aziz 2008-07-23 00:50:22 +00:00
control.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
enums.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
eval.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
exceptions.sls some r6rs test suite fixes 2008-07-21 23:10:59 +00:00
hashtables.sls another r6rs test 2008-07-23 13:19:30 +00:00
lists.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
mutable-pairs.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
mutable-strings.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
programs.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
r5rs.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
reader.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
README.txt add run-via-eval (from Aziz) 2008-07-23 22:34:07 +00:00
run-via-eval.sps add run-via-eval (from Aziz) 2008-07-23 22:34:07 +00:00
run.sps R6RS tests: sps files for more convenient testing, README on how to run 2008-07-21 22:16:19 +00:00
sorting.sls .ss -> .sls for portable R6RS tests 2008-07-21 20:51:33 +00:00
syntax-case.sls R6RS syntax vector repair (PR 9625) 2008-07-23 12:25:41 +00:00
test.sls change the way multiple-value results are compared in r6rs test suite 2008-07-24 00:23:05 +00:00
unicode.sls some r6rs test suite fixes 2008-07-21 23:10:59 +00:00

------------------------- An R6RS Test Suite -------------------------

======================================================================
Files and libraries
======================================================================

Files that end ".sps" are R6RS programs. The main one is "run.sps",
which runs all the tests.

Files that end ".sls" are R6RS libraries. For example, "base.sls" is a
library that implements `(tests r6rs base)', which is a set of tests
for `(rnrs base)'. Many R6RS implementations will auto-load ".sls"
files if you put the directory of tests in the right place.

In general, for each `(rnrs <id> ... <id>)' in the standard:

 * There's a library of tests "<id>/.../<id>.sls". It defines and
   exports a function `run-<id>-...<id>-tests'.

 * There's a program "run/<id>/.../<id>.sps" that imports
   "<id>/.../<id>.sls", runs the tests, and reports the results.

And then there's "run.sps", which runs all the tests (as noted
above). Also, "test.sls" implements `(tests r6rs test)', which
implements the testing utilities that are used by all the other
libraries.

The "run-via-eval.sps" program is similar to "run.ss", but it
runs each set of tests via `eval'.

======================================================================
Limitations and feedback
======================================================================

One goal of this test suite is to avoid using `eval' (except when
specifcally testing `eval'). Avoiding `eval' makes the test suite as
useful as possible to ahead-of-time compilers that implement `eval'
with a separate interpreter. A drawback of the current approach,
however, is that if an R6RS implementation doesn't supply one binding
or does not support a bit of syntax used in a set of tests, then the
whole set of tests fails to load.

A related problem is that each set of tests is placed into one
function that runs all the tests. This format creates a block of code
that is much larger than in a typical program, which might give some
compilers trouble.

In any case, reports of bugs (in the tests) and new tests would be
very much appreciated. File either as a PLT Scheme bug report at

   http://bugs.plt-scheme.org

======================================================================
Hints on running the tests
======================================================================

Ikarus
------

Put this directory at "<somewhere>/tests/r6rs" and run with "run.sps"

  cd <somewhere>
  ikarus --r6rs-script tests/r6rs/run.sps

or run an individual library's test, such as "run/program.sps" as

  cd <somewhere>
  ikarus --r6rs-script tests/r6rs/run/program.sps

Larceny
-------

Put this directory at "<somewhere>/tests/r6rs" and run with "run.sps"

  larceny -path <somewhere> -r6rs -program run.sps

or run an individual library's test, such as "run/program.sps" as

  larceny -path <somewhere> -r6rs -program run/program.sps

PLT Scheme
----------

If you get an SVN-based or the "Full" nightly build, then these tests are
in a `tests/r6rs' collection already. You can run all of the tests using

   mzscheme -l tests/r6rs/run.sps

and so on.

Otherwise, install this directory as a `tests/r6rs' collection,
perhaps in the location reported by

  (build-path (find-system-path 'addon-dir) 
              (version) "collects"
              "tests" "r6rs")

As of PLT Scheme 4.0.2.5, two tests fail. They correspond to
documented non-conformance with R6RS.

Ypsilon
-------

[If there's a library-autoload mechanism, we didn't figure it
 out. Better ideas are welcome...]

Load the library declarations that you're interested in. For `(rnrs
<id> ... <id>)':

   * Load "test.sls"
   * Load "<id>/...<id>.sls"
   * Eval `(import tests r6rs <id> ... <id>)'
   * Eval `(run-<id>-...<id>-tests)'
   * Eval `(import tests r6rs test)'
   * Eval `(show-test-results)'