d-/test.scm

78 lines
2.2 KiB
Scheme
Raw Normal View History

2024-10-23 09:02:27 -05:00
(use-modules (d-)
2024-11-21 18:15:13 -06:00
(d- test)
2024-11-11 21:35:26 -06:00
(srfi srfi-1))
2024-10-23 09:02:27 -05:00
2024-11-21 18:15:13 -06:00
(define-test-suite "~>"
(define-test "unwrapped"
(define value (~> 1 1+ 1+))
(assert-equal 3 value))
(define-test "wrapped"
(define value (~> 1 (/ 2) (/ 2)))
(assert-equal 1/4 value)))
2024-11-11 21:58:27 -06:00
2024-11-21 18:15:13 -06:00
(define-test-suite "~>>"
(define-test "unwrapped"
(define value (~>> 1 1+ 1+))
(assert-equal 3 value))
(define-test "wrapped"
(define value (~>> 1 (/ 2) (/ 2)))
(assert-equal 1 value)))
2024-11-11 21:58:27 -06:00
2024-11-21 23:13:27 -06:00
(define-test-suite "as~>"
(define-test "switch sides"
(define value (as~> % 'apples (cons % '()) (cons 'pears %)))
(assert-equal '(pears apples) value))
(define-test "middle argument"
(define value (as~> % '((apples . pears)) (assoc 'apples % equal?)))
(assert-equal '(apples . pears) value)))
2024-11-21 18:15:13 -06:00
(define-test-suite "if-not"
(define-test "test"
(assert-equal 'a (if-not #f 'a 'b))))
2024-11-11 21:58:27 -06:00
2024-11-21 18:15:13 -06:00
(define-test-suite "when-not"
(define-test "positive-case"
(assert-equal 'return (when-not #f 'do-some-stuff 'return)))
(define-test "negative-case"
(assert-unspecified (when-not #t 'do-some-stuff 'return))))
2024-10-23 09:02:27 -05:00
2024-11-21 18:15:13 -06:00
(define-test-suite "for"
(define-test "permutation"
(define value (for ([i (iota 2)]
[j (iota 2)])
(cons i j)))
(assert-equal '((0 . 0) (0 . 1) (1 . 0) (1 . 1)) value)))
2024-10-23 09:02:27 -05:00
2024-11-21 18:15:13 -06:00
(define-test-suite "if-let"
(define-test "positive-case"
(assert-equal 2 (if-let ([v (or #f 1)]) (+ v 1))))
(define-test "negative-case"
(assert-equal #f (if-let ([v (and #f 1)]) (+ v 1)))))
2024-10-23 09:02:27 -05:00
2024-11-21 18:15:13 -06:00
(define-test-suite "partial"
(define-test "test"
(define value (partial / 2))
(assert-equal 1/2 (value 4))
(assert-equal 2 (value 1))))
2024-10-23 09:02:27 -05:00
2024-11-21 18:15:13 -06:00
(define-test-suite "argmin"
(define-test "test"
(assert-equal '(b . 2) (argmin cdr < '(a . 5) '(b . 2) '(c . 3)))))
2024-10-25 15:48:01 -05:00
2024-11-21 23:13:27 -06:00
(define-test-suite "iterate"
(define-test "test"
(define value (iterate 2 1+ 3))
(assert-equal 5 value)))
2024-11-21 18:15:13 -06:00
(define-test-suite "generator"
(define-test "test"
(define number-generator
(generator
(let loop ([i 1])
(yield i)
(loop (1+ i)))))
(assert-equal 1 (number-generator))
(assert-equal 2 (number-generator))
(assert-equal 3 (number-generator))
(assert-equal 4 (number-generator))))