File: test_clj.clj

package info (click to toggle)
pomegranate-clojure 1.2.24-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 636 kB
  • sloc: xml: 135; sh: 37; makefile: 17
file content (72 lines) | stat: -rw-r--r-- 3,340 bytes parent folder | download
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
(ns test-clj
  (:require [babashka.cli :as cli]
            [babashka.tasks :as t]
            [clojure.string :as string]
            [lread.status-line :as status]))

(defn -main [& args]
  (let [old-clojure-versions ["1.4" "1.5" "1.6" "1.7"]
        all-clojure-versions (concat old-clojure-versions ["1.8" "1.9" "1.10" "1.11" "1.12"])
        default-version (first all-clojure-versions)
        valid-clj-version-opt-values (conj all-clojure-versions ":all")
        all-suites [:unit :isolated]
        valid-suite-opt-values (conj all-suites :all)
        spec {:suite
              {:ref "<suite>"
               :desc (str "The test suite to run, valid values: " (string/join ", " valid-suite-opt-values))
               :coerce :keyword
               :default :all
               :validate
               {:pred (set valid-suite-opt-values)
                :ex-msg (fn [_m]
                          (str "--suite must be one of: " (string/join ", " valid-suite-opt-values)))}}
              :clj-version
              {:ref "<version>"
               :desc (str "The Clojure version to test against, valid values: " (string/join ", " valid-clj-version-opt-values))
               :coerce :string
               :booya :foo
               :default-desc default-version
               ;; don't specify :default, we want to know if the user passed this option in
               :validate
               {:pred (set valid-clj-version-opt-values)
                :ex-msg (fn [_m]
                          (str "--clj-version must be one of: " (string/join ", " valid-clj-version-opt-values)))}}}
        opts (cli/parse-opts args {:spec spec})
        suite (:suite opts)
        clj-version (:clj-version opts)
        runner-args (if-not (or clj-version suite)
                      args
                      (loop [args args
                             out-args []]
                        (if-let [a (first args)]
                          (if (re-matches #"(--|:)(clj-version|suite)" a)
                            (recur (drop 2 args) out-args)
                            (recur (rest args) (conj out-args a)))
                          out-args)))
        clj-version (or clj-version default-version)]

    (if (:help opts)
      (do
        (status/line :head "bb task option help")
        (println (cli/format-opts {:spec spec}))
        (status/line :head "test-runner option help")
        (t/clojure "-M:test:old-runner --test-help"))
      (let [suites (if (= :all suite)
                     all-suites
                     [suite])
            clj-versions (if (= ":all" clj-version)
                           all-clojure-versions
                           [clj-version])]
        (doseq [v clj-versions
                s suites
                :let [test-alias (if (some #{v} old-clojure-versions)
                                   "test:old-runner"
                                   "test")
                      test-alias (if (= :isolated s)
                                   (str test-alias ":isolated")
                                   test-alias)]]
          (status/line :head "Testing %s suite against Clojure version %s" s v)
          (apply t/clojure (format "-M:%s:%s" v test-alias) runner-args))))))

(when (= *file* (System/getProperty "babashka.file"))
  (apply -main *command-line-args*))