;; Copyright 2016 Mozilla ;; ;; Licensed under the Apache License, Version 2.0 (the "License"); you may not use ;; this file except in compliance with the License. You may obtain a copy of the ;; License at http://www.apache.org/licenses/LICENSE-2.0 ;; Unless required by applicable law or agreed to in writing, software distributed ;; under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR ;; CONDITIONS OF ANY KIND, either express or implied. See the License for the ;; specific language governing permissions and limitations under the License. (ns datomish.transact-test #?(:cljs (:require-macros [datomish.pair-chan :refer [go-pair = !]]]) #?@(:cljs [[datomish.js-sqlite] [datomish.pair-chan] [datomish.test-macros :refer-macros [deftest-async deftest-db]] [datomish.node-tempfile :refer [tempfile]] [cljs.test :as t :refer-macros [is are deftest testing async]] [cljs.core.async :as a :refer [!]]])) #?(:clj (:import [clojure.lang ExceptionInfo])) #?(:clj (:import [datascript.db DB]))) #?(:cljs (def Throwable js/Error)) (defn- tempids [tx] (into {} (map (juxt (comp :idx first) second) (:tempids tx)))) (def test-schema [{:db/id (d/id-literal :db.part/user) :db/ident :x :db/unique :db.unique/identity :db/valueType :db.type/long :db.install/_attribute :db.part/db} {:db/id (d/id-literal :db.part/user) :db/ident :name :db/unique :db.unique/identity :db/valueType :db.type/string :db.install/_attribute :db.part/db} {:db/id (d/id-literal :db.part/user) :db/ident :y :db/cardinality :db.cardinality/many :db/valueType :db.type/long :db.install/_attribute :db.part/db} {:db/id (d/id-literal :db.part/user) :db/ident :aka :db/cardinality :db.cardinality/many :db/valueType :db.type/string :db.install/_attribute :db.part/db} {:db/id (d/id-literal :db.part/user) :db/ident :age :db/valueType :db.type/long :db.install/_attribute :db.part/db} {:db/id (d/id-literal :db.part/user) :db/ident :email :db/unique :db.unique/identity :db/valueType :db.type/string :db.install/_attribute :db.part/db} {:db/id (d/id-literal :db.part/user) :db/ident :spouse :db/unique :db.unique/value :db/valueType :db.type/string :db.install/_attribute :db.part/db} {:db/id (d/id-literal :db.part/user) :db/ident :friends :db/cardinality :db.cardinality/many :db/valueType :db.type/ref :db.install/_attribute :db.part/db} ]) (deftest-db test-overlapping-transacts conn (let [{tx0 :tx} ( [[id0 :email (str "@" %) (+ 3 % tx0) 0] [id0 :email (str "@" (inc %)) (+ 3 % tx0) 1]]) (range 0 (dec n)))) (filter #(not= :db/txInstant (second %)) (! c1 :token-1) (is (= :token-1 (! c2 :token-1) (is (= :token-1 ( (count xs) 0)) (is (> (count es) 0)) (is (= {:error :transact/connection-closed} (ex-data e)))))) (finally ;; Closing a closed connection is a no-op. (