fix up closing of dbs after each test

This commit is contained in:
Stephen Lombardo 2009-04-22 11:27:52 -04:00
parent f20d127e83
commit 4e87eca3ae
1 changed files with 15 additions and 13 deletions

View File

@ -57,11 +57,11 @@ do_test codec-1.1 {
SELECT name FROM sqlite_master WHERE type='table'; SELECT name FROM sqlite_master WHERE type='table';
} }
} {} } {}
db close
# set an encryption key and create some basic data # set an encryption key and create some basic data
# create table and insert operations should work # create table and insert operations should work
do_test codec-1.2 { do_test codec-1.2 {
db close
sqlite_orig db test.db sqlite_orig db test.db
execsql { execsql {
PRAGMA key = 'testkey'; PRAGMA key = 'testkey';
@ -69,12 +69,12 @@ do_test codec-1.2 {
INSERT INTO t1 VALUES ('test1', 'test2'); INSERT INTO t1 VALUES ('test1', 'test2');
} }
} {} } {}
db close
# close database, open it again with the same # close database, open it again with the same
# key. verify that the table is readable # key. verify that the table is readable
# and the data just inserted is visible # and the data just inserted is visible
do_test codec-1.3 { do_test codec-1.3 {
db close
sqlite_orig db test.db sqlite_orig db test.db
execsql { execsql {
PRAGMA key = 'testkey'; PRAGMA key = 'testkey';
@ -82,33 +82,33 @@ do_test codec-1.3 {
SELECT * from t1; SELECT * from t1;
} }
} {t1 test1 test2} } {t1 test1 test2}
db close
# open the database and try to read from it without # open the database and try to read from it without
# providing a passphrase. verify that the # providing a passphrase. verify that the
# an error is returned from the library # an error is returned from the library
do_test codec-1.4 { do_test codec-1.4 {
db close
sqlite_orig db test.db sqlite_orig db test.db
catchsql { catchsql {
SELECT name FROM sqlite_master WHERE type='table'; SELECT name FROM sqlite_master WHERE type='table';
} }
} {1 {file is encrypted or is not a database}} } {1 {file is encrypted or is not a database}}
db close
# open the database and try to set an invalid # open the database and try to set an invalid
# passphrase. verify that an error is returned # passphrase. verify that an error is returned
# and that data couldn't be read # and that data couldn't be read
do_test codec-1.5 { do_test codec-1.5 {
db close
sqlite_orig db test.db sqlite_orig db test.db
catchsql { catchsql {
PRAGMA key = 'testkey2'; PRAGMA key = 'testkey2';
SELECT name FROM sqlite_master WHERE type='table'; SELECT name FROM sqlite_master WHERE type='table';
} }
} {1 {file is encrypted or is not a database}} } {1 {file is encrypted or is not a database}}
db close
# test a large number of inserts in a transaction to a memory database # test a large number of inserts in a transaction to a memory database
do_test codec-1.6 { do_test codec-1.6 {
db close
sqlite_orig db :memory: sqlite_orig db :memory:
execsql { execsql {
PRAGMA key = 'testkey3'; PRAGMA key = 'testkey3';
@ -122,22 +122,24 @@ do_test codec-1.6 {
execsql { execsql {
COMMIT; COMMIT;
SELECT count(*) FROM t2; SELECT count(*) FROM t2;
DELETE FROM t2;
SELECT count(*) FROM t2;
} }
} {25000} } {25000 0}
db close
# test invalid hex key fails # test invalid hex key fails
do_test codec-1.7 { do_test codec-1.7 {
db close
sqlite_orig db test.db sqlite_orig db test.db
catchsql { catchsql {
PRAGMA hexkey = '98483C6EB40B6C31A448C22A66DED3B5E5E8D5119CAC8327B655C8B5C4836480'; PRAGMA hexkey = '98483C6EB40B6C31A448C22A66DED3B5E5E8D5119CAC8327B655C8B5C4836480';
SELECT name FROM sqlite_master WHERE type='table'; SELECT name FROM sqlite_master WHERE type='table';
} }
} {1 {file is encrypted or is not a database}} } {1 {file is encrypted or is not a database}}
db close
# test a large number of inserts in a transaction for multiple pages # test a large number of inserts in a transaction for multiple pages
do_test codec-1.8 { do_test codec-1.8 {
db close
sqlite_orig db test.db sqlite_orig db test.db
execsql { execsql {
PRAGMA key = 'testkey'; PRAGMA key = 'testkey';
@ -153,17 +155,17 @@ do_test codec-1.8 {
SELECT count(*) FROM t2; SELECT count(*) FROM t2;
} }
} {25000} } {25000}
db close
# test initial rekey # test initial rekey
do_test codec-1.9 { do_test codec-1.9 {
db close
sqlite_orig db test.db sqlite_orig db test.db
execsql { execsql {
PRAGMA key = 'testkey'; PRAGMA key = 'testkey';
PRAGMA rekey = 'testkeynew'; PRAGMA rekey = 'testkeynew';
} }
db close
} {} } {}
db close
# test that now the new key opens the database # test that now the new key opens the database
# now close database re-open with new key # now close database re-open with new key
@ -174,6 +176,7 @@ do_test codec-1.10 {
SELECT count(*) FROM t2; SELECT count(*) FROM t2;
} }
} {25000} } {25000}
db close
# test rekey on an unecrypted database # test rekey on an unecrypted database
do_test codec-1.11 { do_test codec-1.11 {
@ -202,8 +205,6 @@ do_test codec-1.11 {
} db2 } db2
} {25000} } {25000}
db close
db2 close db2 close
# attach an encrypted database # attach an encrypted database
@ -225,7 +226,6 @@ do_test codec-1.12 {
COMMIT; COMMIT;
} db3 } db3
db3 close
sqlite_orig db2 test2.db sqlite_orig db2 test2.db
@ -237,6 +237,7 @@ do_test codec-1.12 {
} db2 } db2
} {25000 15000} } {25000 15000}
db3 close
do_test codec-1.13 { do_test codec-1.13 {
execsql { execsql {
@ -256,5 +257,6 @@ do_test codec-1.13 {
DETACH db3; DETACH db3;
} db2 } db2
} {35000 25000} } {35000 25000}
db2 close
finish_test finish_test