mirror of
https://github.com/tursodatabase/libsql.git
synced 2025-06-16 17:59:48 +00:00
.cargo
.github
bindings
bottomless
bottomless-cli
docker-compose
docs
libsql
libsql-ffi
libsql-hrana
libsql-replication
libsql-server
libsql-shell
libsql-sqlite3
art
autoconf
contrib
crates
doc
ext
mptest
config01.test
config02.test
crash01.test
crash02.subtest
mptest.c
multiwrite01.test
src
test
tool
vsixtest
.gitignore
Dockerfile-wasm-udf
LIBSQL_VERSION
LICENSE.md
Makefile.in
Makefile.linux-gcc
Makefile.msc
README-SQLite.md
VERSION
aclocal.m4
config.guess
config.sub
configure
configure.ac
install-sh
libsql.pc.in
ltmain.sh
magic.txt
main.mk
manifest
manifest.uuid
spec.template
sqlite.pc.in
sqlite3.1
sqlite3.pc.in
sqlite_cfg.h.in
libsql-sys
tools
vendored
xtask
.dockerignore
.env
.gitignore
.gitmodules
CODE_OF_CONDUCT.md
Cargo.lock
Cargo.toml
Dockerfile
Dockerfile.dev
LICENSE.md
README-libsql.md
README.md
docker-entrypoint.sh
fly.toml
rust-toolchain.toml
107 lines
2.9 KiB
Plaintext
107 lines
2.9 KiB
Plaintext
/* Test cases involving incomplete transactions that must be rolled back.
|
|
*/
|
|
--task 1
|
|
DROP TABLE IF EXISTS t1;
|
|
CREATE TABLE t1(a INTEGER PRIMARY KEY, b);
|
|
--sleep 1
|
|
INSERT INTO t1 VALUES(1, randomblob(2000));
|
|
INSERT INTO t1 VALUES(2, randomblob(1000));
|
|
--sleep 1
|
|
INSERT INTO t1 SELECT a+2, randomblob(1500) FROM t1;
|
|
INSERT INTO t1 SELECT a+4, randomblob(1500) FROM t1;
|
|
INSERT INTO t1 SELECT a+8, randomblob(1500) FROM t1;
|
|
--sleep 1
|
|
INSERT INTO t1 SELECT a+16, randomblob(1500) FROM t1;
|
|
--sleep 1
|
|
INSERT INTO t1 SELECT a+32, randomblob(1500) FROM t1;
|
|
SELECT count(*) FROM t1;
|
|
--match 64
|
|
SELECT avg(length(b)) FROM t1;
|
|
--match 1500.0
|
|
--sleep 2
|
|
UPDATE t1 SET b='x'||a||'y';
|
|
SELECT sum(length(b)) FROM t1;
|
|
--match 247
|
|
SELECT a FROM t1 WHERE b='x17y';
|
|
--match 17
|
|
CREATE INDEX t1b ON t1(b);
|
|
SELECT a FROM t1 WHERE b='x17y';
|
|
--match 17
|
|
SELECT a FROM t1 WHERE b GLOB 'x2?y' ORDER BY b DESC LIMIT 5;
|
|
--match 29 28 27 26 25
|
|
--end
|
|
--wait 1
|
|
--task 2
|
|
DROP TABLE IF EXISTS t2;
|
|
CREATE TABLE t2(a INTEGER PRIMARY KEY, b);
|
|
INSERT INTO t2 SELECT a, b FROM t1;
|
|
UPDATE t1 SET b='x'||a||'y';
|
|
SELECT sum(length(b)) FROM t2;
|
|
--match 247
|
|
SELECT a FROM t2 WHERE b='x17y';
|
|
--match 17
|
|
CREATE INDEX t2b ON t2(b);
|
|
SELECT a FROM t2 WHERE b='x17y';
|
|
--match 17
|
|
SELECT a FROM t2 WHERE b GLOB 'x2?y' ORDER BY b DESC LIMIT 5;
|
|
--match 29 28 27 26 25
|
|
--end
|
|
--task 3
|
|
DROP TABLE IF EXISTS t3;
|
|
CREATE TABLE t3(a INTEGER PRIMARY KEY, b);
|
|
INSERT INTO t3 SELECT a, b FROM t1;
|
|
UPDATE t1 SET b='x'||a||'y';
|
|
SELECT sum(length(b)) FROM t3;
|
|
--match 247
|
|
SELECT a FROM t3 WHERE b='x17y';
|
|
--match 17
|
|
CREATE INDEX t3b ON t3(b);
|
|
SELECT a FROM t3 WHERE b='x17y';
|
|
--match 17
|
|
SELECT a FROM t3 WHERE b GLOB 'x2?y' ORDER BY b DESC LIMIT 5;
|
|
--match 29 28 27 26 25
|
|
--end
|
|
--task 4
|
|
DROP TABLE IF EXISTS t4;
|
|
CREATE TABLE t4(a INTEGER PRIMARY KEY, b);
|
|
INSERT INTO t4 SELECT a, b FROM t1;
|
|
UPDATE t1 SET b='x'||a||'y';
|
|
SELECT sum(length(b)) FROM t4;
|
|
--match 247
|
|
SELECT a FROM t4 WHERE b='x17y';
|
|
--match 17
|
|
CREATE INDEX t4b ON t4(b);
|
|
SELECT a FROM t4 WHERE b='x17y';
|
|
--match 17
|
|
SELECT a FROM t4 WHERE b GLOB 'x2?y' ORDER BY b DESC LIMIT 5;
|
|
--match 29 28 27 26 25
|
|
--end
|
|
--task 5
|
|
DROP TABLE IF EXISTS t5;
|
|
CREATE TABLE t5(a INTEGER PRIMARY KEY, b);
|
|
INSERT INTO t5 SELECT a, b FROM t1;
|
|
UPDATE t1 SET b='x'||a||'y';
|
|
SELECT sum(length(b)) FROM t5;
|
|
--match 247
|
|
SELECT a FROM t5 WHERE b='x17y';
|
|
--match 17
|
|
CREATE INDEX t5b ON t5(b);
|
|
SELECT a FROM t5 WHERE b='x17y';
|
|
--match 17
|
|
SELECT a FROM t5 WHERE b GLOB 'x2?y' ORDER BY b DESC LIMIT 5;
|
|
--match 29 28 27 26 25
|
|
--end
|
|
|
|
--wait all
|
|
/* After the database file has been set up, run the crash2 subscript
|
|
** multiple times. */
|
|
--source crash02.subtest
|
|
--source crash02.subtest
|
|
--source crash02.subtest
|
|
--source crash02.subtest
|
|
--source crash02.subtest
|
|
--source crash02.subtest
|
|
--source crash02.subtest
|
|
--source crash02.subtest
|
|
--source crash02.subtest
|