-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathrun-test.scm
149 lines (140 loc) · 4.62 KB
/
run-test.scm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
(add-load-path "./lib")
(add-load-path "./sitelib")
(add-load-path "./ext/time")
#!read-macro=sagittarius/regex
(import (srfi :0)
(srfi :13)
(srfi :37)
(srfi :39)
(rnrs)
(sagittarius)
(sagittarius vm) ;; for vm-current-library
(sagittarius io)
(sagittarius regex))
;; r7rs tests also use dynamic modules
(cond-expand
(sagittarius.os.windows
(add-dynamic-load-path "./build/modules"))
(else
(add-dynamic-load-path "./build")))
;; define build directory fullpath
(define build-directory-path
(string-append (current-directory) "/build"))
;; load test resource
(define (load-test-resource resource)
(if (file-exists? resource)
(call-with-input-file resource
(lambda (p)
(do ((line (get-line p) (get-line p)))
((eof-object? line) #t)
(add-load-path line))))
#f))
(or (load-test-resource ".sagittarius-r6rstestrc")
(add-load-path "./test/r6rs-test-suite"))
(or (load-test-resource ".sagittarius-r7rstestrc")
(begin (add-load-path "./test/r7rs-tests")
(add-load-path "./ext/crypto")))
(define (%call-test-case thunk error-regex environment?)
(define no-error? #t)
(define stdout (current-output-port))
(define buffer (open-output-string))
(define (error-check-port)
(define (write! str start count)
(when no-error?
(put-string buffer str start count)
(when (string-contains str "\n")
(let ((str (extract-output-string buffer)))
(when (error-regex str)
(set! no-error? #f)))))
(put-string stdout str start count)
count)
(make-custom-textual-output-port "error check port" write! #f #f #f))
;; This is needed to avoid confliction of globally defined variables
;; c.f) Both R7RS and SRFI-127 tests have (g) and for some reason
;; this would make test runner confuse.
(if environment?
(parameterize ((vm-current-library environment?))
(with-output-to-port (error-check-port) thunk))
(with-output-to-port (error-check-port) thunk))
(flush-output-port stdout)
no-error?)
(define-syntax call-test-case
(syntax-rules ()
((_ expr regex)
(call-test-case expr regex
(environment '(core) '(core base) '(sagittarius))))
((_ expr regex environment?)
(%call-test-case (lambda () expr) regex environment?))))
(define (main args)
(let-values (((test) (args-fold (cdr args)
'()
(lambda (option name arg . seed)
(assertion-violation 'run-test
"Unrecognized option"
name))
(lambda (operand test)
(values (cons operand test)))
'())))
(define (r6rs-test)
;; for R6RS test suites
(print "testing R6RS test suite")
(flush-output-port (current-output-port))
(call-test-case (load "./test/r6rs-test-suite/tests/r6rs/run.sps")
#/tests failed/))
(define (r7rs-test)
;; for R7RS test
;; prepare for process-context
;; R7RS now depends alot of extension libraries...
(setenv "R7RS_TEST" "OK")
(print "testing R7RS tests")
(flush-output-port (current-output-port))
(and (call-test-case (load "./test/r7rs-tests/tests/r7rs/run.scm")
#/tests failed/)
(call-test-case (load "./test/r7rs-tests/r7rs-tests.scm")
#/failure/)))
(define (sitelib-test :key (multithread? #t) (pattern ".scm$"))
;; for sitelib
(print "testing sitelib")
(flush-output-port (current-output-port))
(load "./test/tests.scm")
(call-test-case (run-sitelib-tests :multithread? multithread?
:pattern pattern)
#/FAIL/
))
(define (ext-test)
;; for extensions
(print "testing extensions")
(flush-output-port (current-output-port))
(parameterize ((current-directory "ext"))
(call-test-case (load "./all-tests.scm")
#/FAIL/
;; very unfortunately, we can't run this test on
;; fresh environment.
;; FIXME separate all dependencies defined in
;; 'user' library!!
#f)))
(let ((r (if (null? test)
(list (r6rs-test)
(r7rs-test)
(sitelib-test)
(ext-test))
(let loop ((test (reverse! test)) (r '()))
(if (null? test)
r
(case (string->symbol (car test))
((r6rs) (loop (cdr test) (cons (r6rs-test) r)))
((r7rs) (loop (cdr test) (cons (r7rs-test) r)))
((sitelib sitelib-m)
(loop (cdr test) (cons (sitelib-test) r)))
((sitelib-s)
(loop (cdr test)
(cons (sitelib-test :multithread? #f) r)))
((sitelib-f)
(loop (cddr test)
(cons (sitelib-test :pattern (cadr test)) r)))
((ext) (loop (cdr test) (cons (ext-test) r)))
(else
(error 'run-test "unknown test" test))))))))
(if (for-all (lambda (b) b) r)
0
1))))