2022-11-03 08:22:42 -05:00
|
|
|
;; This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
;; License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
;; file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
;;
|
|
|
|
;; Copyright (c) KALEIDOS INC
|
|
|
|
|
2022-11-08 04:40:19 -05:00
|
|
|
(ns backend-tests.util-objects-map-test
|
2022-11-03 08:22:42 -05:00
|
|
|
(:require
|
2023-05-19 12:37:53 -05:00
|
|
|
[app.common.fressian :as fres]
|
2023-03-18 04:32:26 -05:00
|
|
|
[app.common.schema.generators :as sg]
|
2024-09-10 06:40:23 -05:00
|
|
|
[app.common.schema.test :as smt]
|
2022-11-03 08:22:42 -05:00
|
|
|
[app.common.transit :as transit]
|
|
|
|
[app.common.types.shape :as cts]
|
|
|
|
[app.common.uuid :as uuid]
|
|
|
|
[app.util.objects-map :as omap]
|
2023-03-18 04:32:26 -05:00
|
|
|
[backend-tests.helpers :as th]
|
2022-11-03 08:22:42 -05:00
|
|
|
[clojure.pprint :refer [pprint]]
|
|
|
|
[clojure.test :as t]
|
2023-03-18 04:32:26 -05:00
|
|
|
[clojure.test.check.generators :as cg]))
|
2022-11-03 08:22:42 -05:00
|
|
|
|
|
|
|
(t/deftest basic-operations
|
|
|
|
(t/testing "assoc"
|
|
|
|
(let [id (uuid/custom 0 1)
|
|
|
|
id' (uuid/custom 0 2)
|
|
|
|
obj (-> (omap/create) (assoc id {:foo 1}))]
|
|
|
|
(t/is (not= id id'))
|
|
|
|
(t/is (not (contains? obj id')))
|
|
|
|
(t/is (contains? obj id))))
|
|
|
|
|
|
|
|
(t/testing "dissoc"
|
|
|
|
(let [id (uuid/custom 0 1)
|
|
|
|
obj (-> (omap/create) (assoc id {:foo 1}))]
|
|
|
|
(t/is (contains? obj id))
|
|
|
|
(let [obj (dissoc obj id)]
|
|
|
|
(t/is (not (contains? obj id))))))
|
|
|
|
|
|
|
|
(t/testing "seq"
|
|
|
|
(let [id (uuid/custom 0 1)
|
|
|
|
obj (-> (omap/create) (assoc id 1))]
|
|
|
|
(t/is (contains? obj id))
|
|
|
|
(let [[entry] (seq obj)]
|
|
|
|
(t/is (map-entry? entry))
|
|
|
|
(t/is (= (key entry) id))
|
|
|
|
(t/is (= (val entry) 1)))))
|
|
|
|
|
2022-11-03 08:46:09 -05:00
|
|
|
(t/testing "cons & count"
|
2022-11-03 08:22:42 -05:00
|
|
|
(let [obj (into (omap/create) [[uuid/zero 1]])]
|
|
|
|
(t/is (contains? obj uuid/zero))
|
|
|
|
(t/is (= 1 (count obj)))
|
|
|
|
(t/is (omap/objects-map? obj))))
|
|
|
|
|
|
|
|
(t/testing "wrap"
|
|
|
|
(let [obj1 (omap/wrap {})
|
|
|
|
tmp (omap/create)
|
|
|
|
obj2 (omap/wrap tmp)]
|
|
|
|
(t/is (omap/objects-map? obj1))
|
|
|
|
(t/is (omap/objects-map? obj2))
|
|
|
|
(t/is (identical? tmp obj2))
|
|
|
|
(t/is (= 0 (count obj1)))
|
|
|
|
(t/is (= 0 (count obj2)))))
|
|
|
|
|
|
|
|
(t/testing "error on non-uuid keys"
|
|
|
|
(let [obj (omap/wrap {})]
|
2023-11-29 06:53:34 -05:00
|
|
|
(t/is (thrown? IllegalArgumentException (assoc obj :foo "bar"))))))
|
2022-11-03 08:22:42 -05:00
|
|
|
|
|
|
|
(t/deftest internal-operation
|
|
|
|
(t/testing "modified & compact"
|
|
|
|
(let [id1 (uuid/custom 0 1)
|
|
|
|
id2 (uuid/custom 0 2)
|
|
|
|
obj (omap/wrap {id1 1 id2 2})]
|
|
|
|
(t/is (= 2 (count obj)))
|
|
|
|
(t/is (omap/modified? obj))
|
|
|
|
(omap/compact! obj)
|
|
|
|
(t/is (not (omap/modified? obj)))
|
|
|
|
(t/is (bytes? (deref obj)))))
|
|
|
|
|
|
|
|
(t/testing "low-level serialize/deserialize"
|
|
|
|
(let [id1 (uuid/custom 0 1)
|
|
|
|
id2 (uuid/custom 0 2)
|
|
|
|
obj1 (omap/wrap {id1 1 id2 2})
|
|
|
|
obj2 (omap/create (deref obj1))]
|
|
|
|
(t/is (= (get obj1 id1) (get obj2 id1)))
|
|
|
|
(t/is (= (get obj1 id2) (get obj2 id2)))
|
|
|
|
(t/is (= (count obj1) (count obj2)))
|
2023-11-29 06:53:34 -05:00
|
|
|
(t/is (= (hash obj1) (hash obj2))))))
|
2022-11-03 08:22:42 -05:00
|
|
|
|
2023-03-18 04:32:26 -05:00
|
|
|
(t/deftest internal-encode-decode
|
2024-09-10 06:40:23 -05:00
|
|
|
(smt/check!
|
|
|
|
(smt/for [data (->> (cg/map cg/uuid (sg/generator ::cts/shape))
|
|
|
|
(cg/not-empty))]
|
2023-03-18 04:32:26 -05:00
|
|
|
(let [obj1 (omap/wrap data)
|
|
|
|
obj2 (omap/create (deref obj1))
|
|
|
|
obj3 (assoc obj2 uuid/zero 1)
|
|
|
|
obj4 (omap/create (deref obj3))]
|
|
|
|
;; (app.common.pprint/pprint data)
|
2024-09-09 12:58:08 -05:00
|
|
|
|
|
|
|
(and (= (hash obj1) (hash obj2))
|
|
|
|
(not= (hash obj2) (hash obj3))
|
|
|
|
(bytes? (deref obj3))
|
|
|
|
(pos? (alength (deref obj3)))
|
|
|
|
(= (hash obj3) (hash obj4)))))
|
|
|
|
{:num 50}))
|
2023-03-18 04:32:26 -05:00
|
|
|
|
|
|
|
(t/deftest fressian-encode-decode
|
2024-09-10 06:40:23 -05:00
|
|
|
(smt/check!
|
|
|
|
(smt/for [data (->> (cg/map cg/uuid (sg/generator ::cts/shape))
|
|
|
|
(cg/not-empty)
|
|
|
|
(cg/fmap omap/wrap)
|
|
|
|
(cg/fmap (fn [o] {:objects o})))]
|
2023-03-18 04:32:26 -05:00
|
|
|
|
|
|
|
(let [res (-> data fres/encode fres/decode)]
|
2024-09-09 12:58:08 -05:00
|
|
|
(and (contains? res :objects)
|
|
|
|
(omap/objects-map? (:objects res))
|
|
|
|
(= (count (:objects data))
|
|
|
|
(count (:objects res)))
|
|
|
|
(= (hash (:objects data))
|
|
|
|
(hash (:objects res))))))
|
|
|
|
{:num 50}))
|
2023-03-18 04:32:26 -05:00
|
|
|
|
|
|
|
(t/deftest transit-encode-decode
|
2024-09-10 06:40:23 -05:00
|
|
|
(smt/check!
|
|
|
|
(smt/for [data (->> (cg/map cg/uuid (sg/generator ::cts/shape))
|
|
|
|
(cg/not-empty)
|
|
|
|
(cg/fmap omap/wrap)
|
|
|
|
(cg/fmap (fn [o] {:objects o})))]
|
2023-03-18 04:32:26 -05:00
|
|
|
(let [res (-> data transit/encode transit/decode)]
|
|
|
|
;; (app.common.pprint/pprint data)
|
|
|
|
;; (app.common.pprint/pprint res)
|
2024-09-09 12:58:08 -05:00
|
|
|
(and (every? (fn [[k v]]
|
|
|
|
(= v (get-in data [:objects k])))
|
|
|
|
(:objects res))
|
|
|
|
(contains? res :objects)
|
|
|
|
(contains? data :objects)
|
|
|
|
(omap/objects-map? (:objects data))
|
|
|
|
(not (omap/objects-map? (:objects res)))
|
|
|
|
(= (count (:objects data))
|
|
|
|
(count (:objects res))))))
|
|
|
|
{:num 50}))
|
2022-11-03 08:22:42 -05:00
|
|
|
|
|
|
|
|