27 lines
872 B
Clojure
27 lines
872 B
Clojure
|
|
(ns testdoc.style.code-first-test
|
||
|
|
(:require
|
||
|
|
[clojure.string :as str]
|
||
|
|
[clojure.test :as t]
|
||
|
|
[testdoc.style.code-first :as sut]))
|
||
|
|
|
||
|
|
(defn- lines
|
||
|
|
[ls]
|
||
|
|
(str/join "\n" ls))
|
||
|
|
|
||
|
|
(t/deftest parse-doc-test
|
||
|
|
(t/are [expected in] (= expected (sut/parse-doc (lines in)))
|
||
|
|
'[[a b]], ["a" ";; => b"]
|
||
|
|
'[[(a b) c]], ["(a" "b)" ";; => c"]
|
||
|
|
'[[(a b) c]], ["head" "(a" "b)" ";; => c"]
|
||
|
|
'[[a b] [c d]], ["a" ";; => b" "c" ";; => d"]
|
||
|
|
'[], ["a"]
|
||
|
|
'[[a b]], ["a" ";; => b" "c"]
|
||
|
|
'[[a b]], ["a" ";; => b" ";; => c"]
|
||
|
|
'[[a (b c)]], ["a" ";; => [b" ";; => c]"]))
|
||
|
|
|
||
|
|
(t/deftest parse-doc-with-meta-test
|
||
|
|
(let [ret (sut/parse-doc (lines ["" "a" ";; => 6" "c" ";; => :d"]))]
|
||
|
|
(t/is (= '[[a 6] [c :d]] ret))
|
||
|
|
(t/is (= 2 (-> ret first meta :testdoc.string/line)))
|
||
|
|
(t/is (= 4 (-> ret second meta :testdoc.string/line)))))
|