Skip to content

Commit

Permalink
Add test to that that image is cachable?
Browse files Browse the repository at this point in the history
  • Loading branch information
mk committed Nov 5, 2023
1 parent d1a3e57 commit 38054ca
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 15 deletions.
15 changes: 8 additions & 7 deletions src/nextjournal/clerk/eval.clj
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@

#_(-> [(clojure.java.io/file "notebooks") (find-ns 'user)] nippy/freeze nippy/thaw)


(defn ->cache-file [hash]
(str config/cache-dir fs/file-separator hash))

Expand Down Expand Up @@ -87,7 +86,7 @@
hash)))


(defn ^:private cachable-value? [value]
(defn cachable? [value]
(and (some? value)
(try
(and (not (analyzer/exceeds-bounded-count-limit? value))
Expand All @@ -97,10 +96,12 @@
(catch Exception _
false))))

#_(cachable-value? (vec (range 100)))
#_(cachable-value? (range))
#_(cachable-value? (map inc (range)))
#_(cachable-value? [{:hello (map inc (range))}])
#_(cachable? (vec (range 100)))
#_(cachable? (range))
#_(cachable? java.lang.String)
#_(cachable? (map inc (range)))
#_(cachable? [{:hello (map inc (range))}])
#_(cachable? {:foo (javax.imageio.ImageIO/read (clojure.java.io/file "trees.png"))})


(defn ^:private cache! [digest-file var-value]
Expand Down Expand Up @@ -138,7 +139,7 @@
(when (and (not no-cache?)
(not ns-effect?)
freezable?
(cachable-value? var-value)
(cachable? var-value)
(or (not var) var-from-def?))
(cache! digest-file var-value))
(let [blob-id (cond no-cache? (analyzer/->hash-str var-value)
Expand Down
17 changes: 9 additions & 8 deletions test/nextjournal/clerk/eval_test.clj
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
(ns nextjournal.clerk.eval-test
(:require [clojure.string :as str]
(:require [clojure.java.io :as io]
[clojure.string :as str]
[clojure.test :refer [deftest is testing]]
[matcher-combinators.test :refer [match?]]
[nextjournal.clerk :as clerk]
Expand Down Expand Up @@ -219,15 +220,15 @@

(deftest cacheable-value?-test
(testing "finite sequence is cacheable"
(is (#'eval/cachable-value? (vec (range 100)))))
(testing "nippy doesn't know how to freeze instances of clojure.lang.Iterate"
(is (not (#'eval/cachable-value? (range 100)))))
(is (eval/cachable? (vec (range 100)))))
(testing "infinite sequences can't be cached"
(is (not (#'eval/cachable-value? (range))))
(is (not (#'eval/cachable-value? (map inc (range))))))
(is (not (eval/cachable? (range))))
(is (not (eval/cachable? (map inc (range))))))
(testing "class is not cachable"
(is (not (#'eval/cachable-value? java.lang.String)))
(is (not (#'eval/cachable-value? {:foo java.lang.String})))))
(is (not (eval/cachable? java.lang.String)))
(is (not (eval/cachable? {:foo java.lang.String}))))
(testing "image is cachable"
(is (eval/cachable? (javax.imageio.ImageIO/read (io/file "trees.png"))))))

(deftest show!-test
(testing "in-memory cache is preserved when exception is thrown (#549)"
Expand Down

0 comments on commit 38054ca

Please sign in to comment.