hy/tests/native_tests/language.hy

213 lines
4.3 KiB
Hy
Raw Normal View History

2013-03-05 22:08:53 -05:00
;
2013-03-09 21:14:30 -05:00
(import-from tests.resources kwtest)
2013-03-09 19:46:32 -05:00
(import-from os.path exists isdir isfile)
2013-03-09 21:14:30 -05:00
(import sys)
2013-03-19 05:46:00 +00:00
(import-as sys systest)
2013-03-09 19:46:32 -05:00
(defn test-sys-argv []
"NATIVE: test sys.argv"
2013-03-13 21:31:23 -04:00
;
; BTW, this also tests inline comments. Which suck to implement.
;
2013-03-09 19:46:32 -05:00
(assert (isinstance sys.argv list)))
2013-03-06 18:57:21 -05:00
2013-03-09 21:01:59 -05:00
2013-03-09 18:58:47 -05:00
(defn test-lists []
2013-03-05 22:15:45 -05:00
"NATIVE: test lists work right"
2013-03-08 18:18:43 -05:00
(assert (= [1 2 3 4] (+ [1 2] [3 4]))))
2013-03-07 22:52:47 -05:00
2013-03-09 18:58:47 -05:00
(defn test-for-loop []
2013-03-07 22:52:47 -05:00
"NATIVE: test for loops?"
(setv count 0)
2013-03-07 22:52:47 -05:00
(for [x [1 2 3 4 5]]
(setv count (+ count x)))
2013-03-17 17:50:18 -04:00
(assert (= count 15))
(setv count 0)
2013-03-17 17:50:18 -04:00
(for [x [1 2 3 4 5]
y [1 2 3 4 5]]
(setv count (+ count x y)))
2013-03-17 17:51:09 -04:00
(assert (= count 150)))
2013-03-08 20:45:19 -05:00
2013-03-09 18:58:47 -05:00
(defn test-in []
2013-03-08 20:45:19 -05:00
"NATIVE: test in"
(assert (in "a" ["a" "b" "c" "d"]))
(assert (not-in "f" ["a" "b" "c" "d"])))
2013-03-09 18:58:47 -05:00
(defn test-noteq []
2013-03-09 17:15:56 -05:00
"NATIVE: not eq"
(assert (!= 2 3)))
2013-03-09 18:58:47 -05:00
(defn test-numops []
2013-03-08 20:45:19 -05:00
"NATIVE: test numpos"
(assert (> 5 4 3 2 1))
(assert (< 1 2 3 4 5))
(assert (<= 5 5 5 5 ))
(assert (>= 5 5 5 5 )))
2013-03-09 18:58:47 -05:00
(defn test-is []
2013-03-09 00:01:43 -05:00
"NATIVE: test is can deal with None"
(setv a null)
2013-03-09 00:01:43 -05:00
(assert (is a null))
(assert (is-not a "b")))
2013-03-09 18:58:47 -05:00
(defn test-branching []
2013-03-09 00:01:43 -05:00
"NATIVE: test if branching"
(if true
(assert (= 1 1))
(assert (= 2 1))))
2013-03-09 18:58:47 -05:00
(defn test-branching-with-do []
2013-03-09 00:01:43 -05:00
"NATIVE: test if branching (multiline)"
(if false
(assert (= 2 1))
(do
(assert (= 1 1))
(assert (= 1 1))
(assert (= 1 1)))))
2013-03-09 00:18:32 -05:00
2013-03-09 18:58:47 -05:00
(defn test-cond []
2013-03-09 00:18:32 -05:00
"NATIVE: test if cond sorta works."
(cond
2013-04-01 20:00:37 -04:00
((= 1 2) (assert (is true false)))
((is null null) (assert (is true true)))))
2013-03-09 00:55:27 -05:00
2013-03-09 18:58:47 -05:00
(defn test-index []
2013-03-09 00:55:27 -05:00
"NATIVE: Test that dict access works"
2013-03-09 00:56:13 -05:00
(assert (get {"one" "two"} "one") "two")
(assert (= (get [1 2 3 4 5] 1) 2)))
2013-03-09 15:57:13 -05:00
2013-03-09 18:58:47 -05:00
(defn test-lambda []
2013-03-09 15:57:13 -05:00
"NATIVE: test lambda operator"
(setv square (lambda [x] (* x x)))
2013-03-09 15:57:13 -05:00
(assert (= 4 (square 2))))
2013-03-09 19:46:32 -05:00
(defn test-imported-bits []
"NATIVE: test the imports work"
(assert (is (exists ".") true))
(assert (is (isdir ".") true))
(assert (is (isfile ".") false)))
2013-03-09 21:01:59 -05:00
(defn foodec [func]
(lambda [] (+ 1 1)))
(decorate-with foodec
(defn tfunction []
(* 2 2)))
(defn test-decorators []
2013-03-09 21:16:28 -05:00
"NATIVE: test decorators."
2013-03-09 21:01:59 -05:00
(assert (= (tfunction) 2)))
2013-03-09 21:14:30 -05:00
(defn test-kwargs []
2013-03-09 21:16:28 -05:00
"NATIVE: test kwargs things."
2013-03-09 21:14:30 -05:00
(assert (= (kwapply (kwtest) {"one" "two"}) {"one" "two"})))
2013-03-09 22:04:38 -05:00
(defn test-dotted []
"NATIVE: test dotted invocation"
(assert (= (.join " " ["one" "two"]) "one two")))
(defn test-exceptions []
"NATIVE: test Exceptions"
(try
2013-03-11 20:17:27 -04:00
(throw (KeyError))
(catch IOError e (assert (= 2 1)))
(catch KeyError e (+ 1 1) (assert (= 1 1)))))
2013-03-12 12:46:20 -07:00
(defn test-earmuffs []
"NATIVE: Test earmuffs"
(setv *foo* "2")
(setv foo "3")
2013-03-12 12:46:20 -07:00
(assert (= *foo* FOO))
(assert (!= *foo* foo)))
2013-03-12 22:04:51 -04:00
2013-03-12 22:07:32 -04:00
2013-03-12 22:04:51 -04:00
(defn test-threading []
"NATIVE: test threading macro"
(assert (= (-> (.upper "a b c d") (.replace "A" "X") (.split))
["X" "B" "C" "D"])))
2013-03-12 22:07:32 -04:00
2013-03-13 09:03:50 -04:00
(defn test-threading-two []
"NATIVE: test threading macro"
(assert (= (-> "a b c d" .upper (.replace "A" "X") .split)
["X" "B" "C" "D"])))
2013-03-12 22:07:32 -04:00
(defn test-assoc []
"NATIVE: test assoc"
(setv vals {"one" "two"})
2013-03-12 22:07:32 -04:00
(assoc vals "two" "three")
(assert (= (get vals "two") "three")))
2013-03-14 20:55:11 -04:00
(defn test-pass []
"NATIVE: Test pass worksish"
(if true (pass) (pass))
(assert (= 1 1)))
(defn test-yield []
"NATIVE: test yielding"
(defn gen [] (for [x [1 2 3 4]] (yield x)))
(setv ret 0)
(for [y (gen)] (setv ret (+ ret y)))
2013-03-14 20:55:11 -04:00
(assert (= ret 10)))
2013-03-18 16:11:29 -04:00
(defn test-first []
"NATIVE: test firsty things"
(assert (= (first [1 2 3 4 5]) 1))
(assert (= (car [1 2 3 4 5]) 1)))
2013-03-18 19:47:48 -04:00
(defn test-slice []
"NATIVE: test slice"
(assert (= (slice [1 2 3 4 5] 1) [2 3 4 5]))
(assert (= (slice [1 2 3 4 5] 1 3) [2 3]))
(assert (= (slice [1 2 3 4 5]) [1 2 3 4 5])))
2013-03-18 19:49:36 -04:00
(defn test-rest []
"NATIVE: test rest"
(assert (= (rest [1 2 3 4 5]) [2 3 4 5])))
2013-03-19 05:46:00 +00:00
(defn test-importas []
"NATIVE: test import as"
(assert (!= (len systest.path) 0)))
2013-03-24 02:04:44 -04:00
(defn test-context []
"NATIVE: test with"
(with-as (open "README.md" "r") fd
(pass)))
(defn test-comprehensions []
"NATIVE: test list comprehensions"
(assert (= (list-comp (* x 2) (x (range 2))) [0 2]))
(assert (= (list-comp (* x 2) (x (range 4)) (% x 2)) [2 6]))
(assert (= (sorted (list-comp (* y 2) ((, x y) (.items {"1" 1 "2" 2}))))
2013-04-02 20:49:42 -04:00
[2 4]))
(assert (= (list-comp (, x y) (x (range 2) y (range 2)))
[(, 0 0) (, 0 1) (, 1 0) (, 1 1)])))