-
Notifications
You must be signed in to change notification settings - Fork 2
/
tester.rkt
146 lines (119 loc) · 6 KB
/
tester.rkt
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
;; Tester suite functions
(module tester racket
(provide (all-defined-out))
(define (id x) x)
(define (square x) (* x x))
(define (num-elements lo hi inc) (add1 (/ (- hi lo) inc)))
(define (make-elements lo hi inc)
(build-list (num-elements lo hi inc) (lambda (x) (+ lo (* inc x)))))
(define (build-by-twos str pow)
(if (<= pow 0) str
(build-by-twos (string-append str str) (- pow 1))))
;; Adapter from mean-variance found at nklein.com
(define (mean-variance lon)
(if (null? lon)
(cons 0 0)
(let loop ([n 1] [xs (car lon)] [x2s (square (car lon))] [lon (cdr lon)])
(if (null? lon)
(let ([mean (/ xs n)])
(cons mean (- (/ x2s n) (square mean))))
(loop (+ n 1) (+ xs (car lon)) (+ x2s (square (car lon))) (cdr lon))))))
;; Particulary useful
(define (doall proc stuff) (map (lambda (x) (apply proc x)) stuff))
;; TEST FLAGS
(define all-tests (box empty))
(define test-lo 10)
(define test-hi 20)
(define test-inc 1)
(define num-tests 20)
;; Mutationy stuff
(define (set-app! place value) (set-box! place (append (unbox place) (list value))))
(define (set-inc! place inc) (set-box! place (+ (unbox place) inc)))
(define (reset! place) (set-box! place empty))
(define (add-test! test) (set-app! all-tests test))
(define (add-stats! place results)
(set-app! place (mean-variance results)))
;; Printing CSV stuff
(define (doublequote str) (string-append "\"" str "\""))
(define (seperate str) (string-append (doublequote str) ";"))
(define end (string-append (doublequote "") "~n"))
(define (print-seperated nums title type)
(define (make-str x) (seperate (number->string (exact->inexact x))))
(define (print-seperated* nums means varies)
(if (null? nums)
(begin (printf (string-append means end)) (printf (string-append varies end)))
(let ([mean (make-str (caar nums))] [vari (make-str (cdar nums))])
(print-seperated* (cdr nums)
(string-append means mean)
(string-append varies vari)))))
(if (null? nums)
(printf "HUH?")
(print-seperated* nums
(seperate (string-append type title "MEAN"))
(seperate (string-append type title "VARIANCE")))))
(define (print-test-stats cpus rels gbcs test type)
(doall print-seperated (list (list (unbox cpus) "CPU" type)
(list (unbox rels) "REAL" type)
(list (unbox gbcs) "GARBAGE" type))))
(define (bool->string b) (if b "Passed" "Failed"))
(define (print-as-expect lob)
(define (print-as-expected* lob)
(if (null? lob) (printf end)
(begin (printf (seperate (bool->string (car lob))))
(print-as-expected* (cdr lob)))))
(if (null? lob) (printf "HUH?") (print-as-expected* lob)))
(define (->all_at_once test times)
(lambda (string)
(for-each (lambda (run) (test string))
(build-list times id))))
(define (make-test-matcher matcher all_at_once? times)
(if all_at_once? (->all_at_once matcher times) matcher))
(define (normalize num all_at_once? times) (if all_at_once? (/ num times) num))
;; The actual test thats run
;; (: build-test : (String -> Bool) (Natrual-> String) String Naturalx3)
(define (build-test matcher input type test lo hi inc should-be repeated? times)
(lambda ()
(printf (string-append "~n" (doublequote test) "~n"))
(printf (seperate "Size of Input"))
(let ([isexpect? (box empty)] [cpu-stats (box empty)]
[rel-stats (box empty)] [gbc-stats (box empty)]
[sizes (make-elements lo hi inc)]
[expects (box true)]
[cpus (box empty)] [rels (box empty)] [gbcs (box empty)]
[test-runs (build-list num-tests id)]
[matcher (make-test-matcher matcher repeated? times)])
(for-each (lambda (size)
(let ([string (list (input size))])
(printf (seperate (number->string (string-length (car string)))))
(for-each (lambda (run)
(let-values ([(res cpu rel gbc) (time-apply matcher string)])
(set-box! expects (and (unbox expects)
(equal? (car res) should-be)))
(doall set-app! (list (list cpus (normalize cpu repeated? times))
(list rels (normalize rel repeated? times))
(list gbcs (normalize gbc repeated? times))))))
test-runs)
(doall add-stats! (list (list cpu-stats (unbox cpus))
(list rel-stats (unbox rels))
(list gbc-stats (unbox gbcs))))
(set-app! isexpect? expects)
(map reset! (list cpus rels gbcs))
(set-box! expects true)))
(make-elements lo hi inc))
(printf (string-append (doublequote " ") "~n"))
(print-test-stats cpu-stats rel-stats gbc-stats test type)
(print-as-expect (unbox isexpect?)))))
;; (: test : (String -> Bool) (String -> Bool) (-> String) String)
(define (test dfa rgx input test expect #:repeated? [repeated? #t] #:times [times 20])
(add-test! (build-test dfa input "DFA: " test test-lo test-hi test-inc expect repeated? times))
(add-test! (build-test rgx input "RGX: " test test-lo test-hi test-inc expect repeated? times)))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Running tests, with optional file output
(define (run-tests)
(map (lambda (x) (x)) (unbox all-tests))
(printf "ALL tests completed"))
(define (log-to name)
(with-output-to-file name
(lambda ()
(run-tests))))
)