summaryrefslogtreecommitdiff
path: root/tests/fn.fnl
blob: c7a3aa95f50ff5b791d14afd353bcbec1e152a26 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
(require-macros :tests.test)
(require-macros :cljlib-macros)

(deftest defn
  (testing "defn meta"
    (defn f
      "docstring"
      [x] x)
    (assert-eq (meta f) (when-meta {:fnl/docstring "docstring"
                                    :fnl/arglist ["x"]}))

    (defn f
      "docstring"
      ([x] x))
    (assert-eq (meta f) (when-meta {:fnl/docstring "docstring"
                                    :fnl/arglist ["x"]}))

    (defn f
      "docstring"
      ([x] x)
      ([x y] (+ x y)))
    (assert-eq (meta f) (when-meta {:fnl/docstring "docstring"
                                    :fnl/arglist ["\n  [x]"
                                                  "\n  [x y]"]}))

    (defn f
      "docstring"
      ([x] x)
      ([x y] (+ x y))
      ([x y & z] (+ x y)))
    (assert-eq (meta f) (when-meta {:fnl/docstring "docstring"
                                    :fnl/arglist ["\n  [x]"
                                                  "\n  [x y]"
                                                  "\n  [x y & z]"]}))))

(deftest fn+
  (testing "fn+ meta"
    (fn+ f "docstring" [x] x)
    (assert-eq (meta f) (when-meta {:fnl/docstring "docstring"
                                    :fnl/arglist ["x"]}))

    (fn+ f "docstring" [...] [...])
    (assert-eq (meta f) (when-meta {:fnl/docstring "docstring"
                                    :fnl/arglist ["..."]}))))