d-/test.scm

70 lines
1.6 KiB
Scheme
Raw Normal View History

2024-10-23 09:02:27 -05:00
(use-modules (d-)
2024-11-11 21:35:26 -06:00
(rnrs base)
(srfi srfi-1))
2024-10-23 09:02:27 -05:00
(define-syntax-rule (define-unit-test (test-name body ...))
(let () body ...))
(define-syntax-rule (define-test module-name tests ...)
(begin (define-unit-test tests) ...))
(define-test ~>
(unwrapped
(define value (~> 1 1+ 1+))
(assert (= value 3)))
(wrapped
(define value (~> 1 (/ 2) (/ 2)))
(assert (= value 1/4))))
(define-test ~>>
(unwrapped
(define value (~>> 1 1+ 1+))
(assert (= value 3)))
(wrapped
(define value (~>> 1 (/ 2) (/ 2)))
(assert (= value 1))))
2024-10-25 15:48:01 -05:00
(define-test if-not
(assert (eq? (if-not #f 'a 'b) 'a)))
(define-test when-not
(positive-case
(assert (eq? (when-not #f 'do-some-stuff 'return) 'return)))
(negative-case
(assert (unspecified? (when-not #t 'do-some-stuff 'return)))))
2024-11-01 18:05:27 -05:00
(define-test for
(permutation
(define value (for ([i (iota 2)]
[j (iota 2)])
(cons i j)))
(assert (equal? value '((0 . 0) (0 . 1) (1 . 0) (1 . 1))))))
(define-test if-let
(positive-case
(assert (= (if-let ([v (or #f 1)]) (+ v 1)) 2)))
(negative-case
(assert (not (if-let ([v (and #f 1)]) (+ v 1))))))
2024-10-23 09:02:27 -05:00
(define-test partial
(test
(define value (partial / 2))
(assert (= (value 4) 1/2))
(assert (= (value 1) 2))))
2024-10-25 15:16:04 -05:00
(define-test argmin
(test
2024-11-11 15:38:13 -06:00
(assert (equal? (argmin cdr < '(a . 5) '(b . 2) '(c . 3)) '(b . 2)))))
2024-11-11 21:35:26 -06:00
(define-test make-generator
(test
(define number-generator
(make-generator (lambda (yield)
(let loop ([i 1])
(yield i)
(loop (1+ i))))))
(assert (= (number-generator) 1))
(assert (= (number-generator) 2))
(assert (= (number-generator) 3))
(assert (= (number-generator) 4))))