-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
script.clj
executable file
·77 lines (55 loc) · 2.99 KB
/
script.clj
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#!/usr/bin/env bb
(ns script
(:require [babashka.pods :as pods]
[clojure.java.io :as io]
[babashka.fs :as fs]
[clojure.test :as t :refer [deftest is testing]]))
(prn (pods/load-pod "./pod-babashka-go-sqlite3"))
(require '[pod.babashka.go-sqlite3 :as sqlite])
(def temp-file (str (fs/file (fs/temp-dir) "foo.db")))
(fs/delete-if-exists temp-file)
(prn (sqlite/execute! temp-file ["create table if not exists foo (the_text TEXT, the_int INTEGER, the_real REAL, the_blob BLOB, the_json JSON)"]))
(prn (sqlite/execute! temp-file ["delete from foo"]))
(def png (java.nio.file.Files/readAllBytes (.toPath (io/file "resources/babashka.png"))))
(prn (sqlite/execute! temp-file ["insert into foo (the_text, the_int, the_real, the_blob, the_json) values (?,?,?,?,?)" "foo" 1 3.14 png "{\"bar\": \"hello\"}"]))
(prn (sqlite/execute! temp-file ["insert into foo (the_text, the_int, the_real) values (?,?,?)" "foo" 2 1.5]))
(testing "multiple results"
(prn (sqlite/execute! temp-file
["insert into foo (the_text, the_int, the_real) values (?,?,?), (?,?,?)"
"bar" 3 1.5
"baz" 4 1.5])))
(def results (sqlite/query temp-file ["select * from foo order by the_int asc"]))
(def results-min-png (mapv #(dissoc % :the_blob :the_json) results))
(def expected [{:the_int 1, :the_real 3.14, :the_text "foo"}
{:the_int 2, :the_real 1.5, :the_text "foo"}
{:the_int 3, :the_real 1.5, :the_text "bar"}
{:the_int 4, :the_real 1.5, :the_text "baz"}])
(deftest results-test
(is (= expected results-min-png)))
(def direct-results (sqlite/query temp-file "select * from foo order by the_int asc"))
(def direct-results-min-png (mapv #(dissoc % :the_blob :the_json) direct-results))
(deftest direct-results-test
(is (= expected direct-results-min-png)))
(deftest bytes-roundtrip
(is (= (count png) (count (get-in results [0 :the_blob])))))
(def json-field-result (sqlite/query temp-file ["select the_json->>'$.bar' as bar from foo where the_json is not null"]))
(deftest json-field-test
(is (= [{:bar "hello"}] json-field-result)))
(deftest error-test
(is (thrown-with-msg?
Exception #"no such column: non_existing"
(sqlite/query temp-file ["select non_existing from foo"])))
(is (thrown-with-msg?
Exception #"unexpected query type, expected a string or a vector"
(sqlite/query temp-file 42)))
(is (thrown-with-msg?
Exception #"the sqlite connection must be a string"
(sqlite/query nil "select * from foo order by the_int asc"))))
(deftest fts50-test
(sqlite/execute! temp-file ["CREATE VIRTUAL TABLE email USING fts5(sender, title, body)"])
(sqlite/execute! temp-file ["INSERT INTO email VALUES('foo', 'bar', 'baz')"])
(is (= [{:sender "foo" :title "bar" :body "baz"}]
(sqlite/query temp-file
["SELECT * FROM email WHERE email MATCH 'baz';"]))))
(let [{:keys [:fail :error]} (t/run-tests)]
(System/exit (+ fail error)))