Skip to content

Commit

Permalink
Ensure support for Clojure 1.10 and above (#65)
Browse files Browse the repository at this point in the history
* Ensure support for Clojure 1.10 and above

Closes #60

* review feedback: move `test-clj` task code to file
  • Loading branch information
lread authored Aug 12, 2024
1 parent 173c5b0 commit f5a61fd
Show file tree
Hide file tree
Showing 8 changed files with 61 additions and 7 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ jobs:
restore-keys: cljdeps-

- name: Run clj tests
run: bb test:clj
run: bb test:clj :clj-all

- name: Run bb tests
run: bb test:bb
7 changes: 6 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
# Changelog

Babashka [http-client](https://github.com/babashka/http-client): HTTP client for Clojure and babashka built on java.net.http
Babashka [http-client](https://github.com/babashka/http-client): HTTP client for Clojure and babashka built on java.net.http

## Unreleased

- [#60](https://github.com/babashka/http-client/issues/60): Minimum Clojure version is now 1.10
([@lread](https://github.com/lread))

## 0.4.19 (2024-04-24)

Expand Down
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ See [API.md](API.md).

> NOTE: The `babashka.http-client` library is built-in as of babashka version 1.1.171.
> TIP: We test and support `babashka.http-client` on Clojure v1.10 and above.
## Stability

The `babashka.http-client` namespace can be considered stable. The
Expand Down
6 changes: 4 additions & 2 deletions bb.edn
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
{:tasks
{test:clj (apply clojure "-M:test" *command-line-args*)
{:paths ["script"]
:tasks
{test:clj {:doc "Run jvm tests, optionally specify clj-version (ex. :clj-1.10 :clj-1.11(default) or :clj-all)"
:task test-clj/-main}

test:bb {:extra-paths ["src" "test"]
:extra-deps {io.github.cognitect-labs/test-runner
Expand Down
4 changes: 4 additions & 0 deletions deps.edn
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,10 @@
:aliases
{:neil {:project {:name org.babashka/http-client
:version "0.4.19"}}
:clj-1.10 {:extra-deps {org.clojure/clojure {:mvn/version "1.10.3"}}}
:clj-1.11 {:extra-deps {org.clojure/clojure {:mvn/version "1.11.4"}}}
:clj-1.12 {:extra-deps {org.clojure/clojure {:mvn/version "1.12.0-rc1"}}}

:repl {:extra-deps {cheshire/cheshire {:mvn/version "5.11.0"}
io.github.borkdude/deflet {:mvn/version "0.1.0"}
babashka/fs {:mvn/version "0.2.16"}}}
Expand Down
41 changes: 41 additions & 0 deletions script/test_clj.clj
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
#!/usr/bin/env bb

(ns test-clj
(:require
[babashka.tasks :as tasks]
[clojure.edn :as edn]
[clojure.string :as str]))

(defn -main[& args]
(let [farg (first *command-line-args*)
;; allow for missing leading colon
farg (if (and farg (str/starts-with? farg "clj-"))
(str ":" farg)
farg)
clj-version-aliases (->> "deps.edn"
slurp
edn/read-string
:aliases
keys
(map str)
(filter (fn [a] (-> a name (str/starts-with? ":clj-"))))
sort
(into []))
[aliases args] (cond
(nil? farg) [[":clj-1.11"] []]

(= ":clj-all" farg) [clj-version-aliases (rest args)]

(and (str/starts-with? farg ":clj-")
(not (some #{farg} clj-version-aliases)))
(throw (ex-info (format "%s not recognized, valid clj- args are: %s or \":clj-all\"" farg clj-version-aliases) {}))

(some #{farg} clj-version-aliases) [[farg] (rest args)]

:else [[":clj-1.11"] args])]
(doseq [alias aliases]
(println (format "-[Running jvm tests for %s]-" alias))
(apply tasks/clojure (str "-M:test" alias) args))))

(when (= *file* (System/getProperty "babashka.file"))
(apply -main *command-line-args*))
2 changes: 1 addition & 1 deletion src/babashka/http_client/internal/multipart.clj
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@
See https://www.ietf.org/rfc/rfc2046.txt"
[]
(str "babashka_http_client_Boundary" (random-uuid)))
(str "babashka_http_client_Boundary" (java.util.UUID/randomUUID)))

(defn concat-streams [^InputStream is1 ^InputStream is2 & more]
(let [is (new java.io.SequenceInputStream is1 is2)]
Expand Down
4 changes: 2 additions & 2 deletions test/babashka/http_client_test.clj
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
(let [server
(server/run-server
(fn [{:keys [uri body] :as req}]
(let [status (parse-long (subs uri 1))
(let [status (Long/valueOf (subs uri 1))
json? (some-> req :headers (get "accept") (str/includes? "application/json"))]
(case status
200 (let [body (if json?
Expand Down Expand Up @@ -423,7 +423,7 @@
:code)))))))

(deftest multipart-test
(let [uuid (.toString (random-uuid))
(let [uuid (.toString (java.util.UUID/randomUUID))
_ (spit (doto (io/file ".test-data")
(.deleteOnExit)) uuid)
resp (http/post "https://postman-echo.com/post"
Expand Down

0 comments on commit f5a61fd

Please sign in to comment.