2014-05-16 12:58:57 -04:00
|
|
|
(defn test-shadow-addition []
|
|
|
|
"NATIVE: test shadow addition"
|
|
|
|
(let [[x +]]
|
2014-08-26 21:38:52 +12:00
|
|
|
(assert (try
|
|
|
|
(x)
|
|
|
|
(catch [TypeError] True)
|
|
|
|
(else (throw AssertionError))))
|
2014-05-16 12:58:57 -04:00
|
|
|
(assert (= (x 1 2 3 4) 10))
|
2014-08-26 21:38:52 +12:00
|
|
|
(assert (= (x 1 2 3 4 5) 15))
|
|
|
|
; with strings
|
|
|
|
(assert (= (x "a")
|
|
|
|
"a"))
|
|
|
|
(assert (= (x "a" "b" "c")
|
|
|
|
"abc"))
|
|
|
|
; with lists
|
|
|
|
(assert (= (x ["a"])
|
|
|
|
["a"]))
|
|
|
|
(assert (= (x ["a"] ["b"] ["c"])
|
|
|
|
["a" "b" "c"]))))
|
2014-05-16 12:58:57 -04:00
|
|
|
|
|
|
|
|
|
|
|
(defn test-shadow-subtraction []
|
|
|
|
"NATIVE: test shadow subtraction"
|
|
|
|
(let [[x -]]
|
|
|
|
(assert (try
|
|
|
|
(x)
|
|
|
|
(catch [TypeError] True)
|
|
|
|
(else (throw AssertionError))))
|
|
|
|
(assert (= (x 1) -1))
|
|
|
|
(assert (= (x 2 1) 1))
|
|
|
|
(assert (= (x 2 1 1) 0))))
|
|
|
|
|
|
|
|
|
|
|
|
(defn test-shadow-multiplication []
|
|
|
|
"NATIVE: test shadow multiplication"
|
|
|
|
(let [[x *]]
|
|
|
|
(assert (= (x) 1))
|
|
|
|
(assert (= (x 3) 3))
|
|
|
|
(assert (= (x 3 3) 9))))
|
|
|
|
|
|
|
|
|
|
|
|
(defn test-shadow-division []
|
|
|
|
"NATIVE: test shadow division"
|
|
|
|
(let [[x /]]
|
|
|
|
(assert (try
|
|
|
|
(x)
|
|
|
|
(catch [TypeError] True)
|
|
|
|
(else (throw AssertionError))))
|
|
|
|
(assert (= (x 1) 1))
|
|
|
|
(assert (= (x 8 2) 4))
|
|
|
|
(assert (= (x 8 2 2) 2))
|
|
|
|
(assert (= (x 8 2 2 2) 1))))
|