1
0
mirror of https://github.com/sqlite/sqlite.git synced 2025-07-30 19:03:16 +03:00

When processing a BETWEEN or CASE expression, avoid transforming a node of the original expression into a TK_REGISTER node. Instead, take a copy and use it instead. Fix for [1be72aab9].

FossilOrigin-Name: 7ef7b23cbb1b9ace9f853238d9133320c153e6c3417e6823ab6394ee1fe56358
This commit is contained in:
dan
2019-07-17 14:34:17 +00:00
parent 3db3d12cd1
commit 8b65e5919d
5 changed files with 119 additions and 47 deletions

41
test/checkfault.test Normal file
View File

@ -0,0 +1,41 @@
# 2019 July 17
#
# The author disclaims copyright to this source code. In place of
# a legal notice, here is a blessing:
#
# May you do good and not evil.
# May you find forgiveness for yourself and forgive others.
# May you share freely, never taking more than you give.
#
#***********************************************************************
#
# This file contains fault-injection test cases for the
# sqlite3_db_cacheflush API.
#
set testdir [file dirname $argv0]
source $testdir/tester.tcl
set testprefix cffault
source $testdir/malloc_common.tcl
do_execsql_test 1.0 {
CREATE TABLE t1 (Col0 CHECK(1 COLLATE BINARY BETWEEN 1 AND 1) ) ;
CREATE TABLE t2(b, a CHECK(
CASE 'abc' COLLATE nocase WHEN a THEN 1 ELSE 0 END)
);
}
do_faultsim_test 1.1 -faults oom* -body {
execsql { INSERT INTO t1 VALUES ('ABCDEFG') }
} -test {
faultsim_test_result {0 {}}
}
do_faultsim_test 1.2 -faults oom* -body {
execsql { INSERT INTO t2(a) VALUES('abc') }
} -test {
faultsim_test_result {0 {}}
}
finish_test