mirror of
https://github.com/carp-lang/Carp.git
synced 2024-11-12 12:49:13 +03:00
75 lines
1.4 KiB
Plaintext
75 lines
1.4 KiB
Plaintext
(use Int)
|
|
|
|
(load "Test.carp")
|
|
(use Test)
|
|
|
|
(defn break-test []
|
|
(let [x 0]
|
|
(do
|
|
(while (< x 10)
|
|
(if (> x 4)
|
|
(break)
|
|
(set! x (inc x))))
|
|
x)))
|
|
|
|
(defn when-test-true []
|
|
(let [x 0]
|
|
(do
|
|
(when true
|
|
(set! x 5))
|
|
x)))
|
|
|
|
(defn when-test-false []
|
|
(let [x 0]
|
|
(do
|
|
(when false
|
|
(set! x 5))
|
|
x)))
|
|
|
|
(defn unless-test-true []
|
|
(let [x 0]
|
|
(do
|
|
(unless true
|
|
(set! x 5))
|
|
x)))
|
|
|
|
(defn unless-test-false []
|
|
(let [x 0]
|
|
(do
|
|
(unless false
|
|
(set! x 5))
|
|
x)))
|
|
|
|
(defn all-eq [a b]
|
|
(if (/= (Array.length a) (Array.length b))
|
|
false
|
|
(let [eq true]
|
|
(do
|
|
(for [i 0 (Array.length a)]
|
|
(if (/= @(Array.unsafe-nth a i) @(Array.unsafe-nth b i))
|
|
(set! eq false)
|
|
()))
|
|
eq))))
|
|
|
|
(deftest test
|
|
(assert-equal test
|
|
5
|
|
(break-test)
|
|
"break works as expected")
|
|
(assert-equal test
|
|
5
|
|
(when-test-true)
|
|
"when works as expected when true")
|
|
(assert-equal test
|
|
0
|
|
(when-test-false)
|
|
"when works as expected when false")
|
|
(assert-equal test
|
|
0
|
|
(unless-test-true)
|
|
"unless works as expected when true")
|
|
(assert-equal test
|
|
5
|
|
(unless-test-false)
|
|
"unless works as expected when false"))
|