From fee782c1fc7bc1ddaf7b2de177e5ec949fdea0ba Mon Sep 17 00:00:00 2001 From: Nikita Prokopov Date: Wed, 24 Apr 2024 21:39:44 +0200 Subject: [PATCH] Pass through BigInteger/BigDeciman to freeze-fn in serializable (closes #465, closes #466) --- CHANGELOG.md | 1 + src/datascript/serialize.cljc | 7 ++- test/datascript/test/serialize.cljc | 72 +++++++++++++++-------------- 3 files changed, 45 insertions(+), 35 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9ff76656..18c17ad7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,7 @@ - Implement “constant substitution” optimization for queries #462 - Fixed :max-eid for dangling entities during reader-based serialization #463 - Fixed tempid in unique refs #464 +- Pass through BigInteger/BigDeciman to freeze-fn in serializable #465 #466 # 1.6.3 diff --git a/src/datascript/serialize.cljc b/src/datascript/serialize.cljc index e12a97bc..d73edc96 100644 --- a/src/datascript/serialize.cljc +++ b/src/datascript/serialize.cljc @@ -137,7 +137,12 @@ write-v (fn [v] (cond (string? v) v - #?@(:clj [(ratio? v) (write-other v)]) + #?@(:clj [(or + (instance? BigInteger v) + (instance? BigDecimal v) + (instance? clojure.lang.Ratio v) + (instance? clojure.lang.BigInt v)) + (write-other v)]) (number? v) (cond diff --git a/test/datascript/test/serialize.cljc b/test/datascript/test/serialize.cljc index 2df3b06f..c4247a9e 100644 --- a/test/datascript/test/serialize.cljc +++ b/test/datascript/test/serialize.cljc @@ -1,15 +1,15 @@ (ns datascript.test.serialize (:require - [#?(:cljs cljs.reader :clj clojure.edn) :as edn] - #?(:cljs [cljs.test :as t :refer-macros [is are deftest testing]] - :clj [clojure.test :as t :refer [is are deftest testing]]) - [datascript.core :as d] - [datascript.db :as db] - [datascript.test.core :as tdc] - #?(:clj [cheshire.core :as cheshire]) - #?(:clj [jsonista.core :as jsonista])) - #?(:clj - (:import [clojure.lang ExceptionInfo]))) + [#?(:cljs cljs.reader :clj clojure.edn) :as edn] + #?(:cljs [cljs.test :as t :refer-macros [is are deftest testing]] + :clj [clojure.test :as t :refer [is are deftest testing]]) + [datascript.core :as d] + [datascript.db :as db] + [datascript.test.core :as tdc] + #?(:clj [cheshire.core :as cheshire]) + #?(:clj [jsonista.core :as jsonista])) + #?(:clj + (:import [clojure.lang ExceptionInfo]))) (t/use-fixtures :once tdc/no-namespace-maps) @@ -31,17 +31,17 @@ (is (= d (read-fn (pr-str d))))) (let [db (-> (d/empty-db {:name {:db/unique :db.unique/identity}}) - (d/db-with [ [:db/add 1 :name "Petr"] - [:db/add 1 :age 44] ]) - (d/db-with [ [:db/add 2 :name "Ivan"] ]))] + (d/db-with [[:db/add 1 :name "Petr"] + [:db/add 1 :age 44]]) + (d/db-with [[:db/add 2 :name "Ivan"]]))] (is (= (pr-str db) - (str "#datascript/DB {" - ":schema {:name {:db/unique :db.unique/identity}}, " - ":datoms [" - "[1 :age 44 536870913] " - "[1 :name \"Petr\" 536870913] " - "[2 :name \"Ivan\" 536870914]" - "]}"))) + (str "#datascript/DB {" + ":schema {:name {:db/unique :db.unique/identity}}, " + ":datoms [" + "[1 :age 44 536870913] " + "[1 :name \"Petr\" 536870913] " + "[2 :name \"Ivan\" 536870914]" + "]}"))) (is (= db (read-fn (pr-str db)))))))) @@ -54,34 +54,38 @@ [1 :email "petr@gmail.com"] [1 :avatar 10] [10 :url "http://"] - [1 :attach { :some-key :some-value }] + [1 :attach {:some-key :some-value}] [2 :name "Oleg"] [2 :age 30] [2 :email "oleg@gmail.com"] - [2 :attach [ :just :values ]] + [2 :attach [:just :values]] [3 :name "Ivan"] [3 :age 15] [3 :follows 2] - [3 :attach { :another :map }] + [3 :attach {:another :map}] [3 :avatar 30] [4 :name "Nick" d/tx0] [5 :inf ##Inf] [5 :-inf ##-Inf] + #?@(:clj [[5 :ratio 22/7] + [5 :bigint (bigint 100)] + [5 :biginteger (biginteger 100)] + [5 :bigdec (bigdec 100.005)]]) ;; check that facts about transactions doesn’t set off max-eid [d/tx0 :txInstant 0xdeadbeef] - [30 :url "https://" ]]) + [30 :url "https://"]]) (def schema - { :name { } ;; nothing special about name - :aka { :db/cardinality :db.cardinality/many } - :age { :db/index true } - :follows { :db/valueType :db.type/ref } - :email { :db/unique :db.unique/identity } - :avatar { :db/valueType :db.type/ref, :db/isComponent true } - :url { } ;; just a component prop - :attach { } ;; should skip index -}) + {:name {} ;; nothing special about name + :aka {:db/cardinality :db.cardinality/many} + :age {:db/index true} + :follows {:db/valueType :db.type/ref} + :email {:db/unique :db.unique/identity} + :avatar {:db/valueType :db.type/ref, :db/isComponent true} + :url {} ;; just a component prop + :attach {} ;; should skip index + }) (deftest test-init-db @@ -98,7 +102,7 @@ (testing "db-init produces the same max-eid as regular transactions" (let [assertions [ [:db/add -1 :name "Lex"] ]] (is (= (d/db-with db-init assertions) - (d/db-with db-transact assertions))))) + (d/db-with db-transact assertions))))) (testing "Roundtrip" (doseq [[r read-fn] readers]