aboutsummaryrefslogtreecommitdiffstats
path: root/test/lisp/sqlite-tests.el
diff options
context:
space:
mode:
authorF. Jason Park2024-03-10 20:13:42 -0700
committerEli Zaretskii2024-03-11 15:23:55 +0200
commitdb5915f30ba063b72b007d243fbd832e8a4e8961 (patch)
tree573d768e8ae5dc14ed813d1ee032a4d8de5e2831 /test/lisp/sqlite-tests.el
parentfe491173e8f839653cb22eea63a7261f4aa1dca9 (diff)
downloademacs-db5915f30ba063b72b007d243fbd832e8a4e8961.tar.gz
emacs-db5915f30ba063b72b007d243fbd832e8a4e8961.zip
Fix 'with-sqlite-transaction'
* lisp/sqlite.el (with-sqlite-transaction): Tuck misplaced body of else form back into feature-test control structure whence it escaped. (Bug#67142) * test/lisp/sqlite-tests.el: New file to accompany test/src/sqlite-tests.el.
Diffstat (limited to 'test/lisp/sqlite-tests.el')
-rw-r--r--test/lisp/sqlite-tests.el51
1 files changed, 51 insertions, 0 deletions
diff --git a/test/lisp/sqlite-tests.el b/test/lisp/sqlite-tests.el
new file mode 100644
index 00000000000..d4892a27efc
--- /dev/null
+++ b/test/lisp/sqlite-tests.el
@@ -0,0 +1,51 @@
1;;; sqlite-tests.el --- Tests for sqlite.el -*- lexical-binding: t; -*-
2
3;; Copyright (C) 2024 Free Software Foundation, Inc.
4
5;; This file is part of GNU Emacs.
6
7;; GNU Emacs is free software: you can redistribute it and/or modify
8;; it under the terms of the GNU General Public License as published by
9;; the Free Software Foundation, either version 3 of the License, or
10;; (at your option) any later version.
11
12;; GNU Emacs is distributed in the hope that it will be useful,
13;; but WITHOUT ANY WARRANTY; without even the implied warranty of
14;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15;; GNU General Public License for more details.
16
17;; You should have received a copy of the GNU General Public License
18;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
19
20;;; Commentary:
21
22;;; Code:
23(require 'sqlite)
24
25(ert-deftest with-sqlite-transaction ()
26 (skip-unless (sqlite-available-p))
27 (let ((db (sqlite-open)))
28 (sqlite-execute db "create table test (a)")
29 (should
30 (eql 42 (with-sqlite-transaction db
31 (sqlite-execute db "insert into test values (1)")
32 (should (equal '((1)) (sqlite-select db "select * from test")))
33 42)))
34 ;; Body runs exactly once.
35 (should (equal '((1)) (sqlite-select db "select * from test")))))
36
37(ert-deftest with-sqlite-transaction/rollback ()
38 (skip-unless (sqlite-available-p))
39 (let ((db (sqlite-open)))
40 (sqlite-execute db "create table test (a)")
41 (should (equal '(sqlite-error
42 ("SQL logic error" "no such function: fake" 1 1))
43 (should-error
44 (with-sqlite-transaction db
45 (sqlite-execute db "insert into test values (1)")
46 (sqlite-execute db "insert into test values (fake(2))")
47 42))))
48 ;; First insertion (a=1) rolled back.
49 (should-not (sqlite-select db "select * from test"))))
50
51;;; sqlite-tests.el ends here