tuple: update to make use of C++11
[chromium-blink-merge.git] / third_party / sqlite / src / test / pager1.test
blob8c31e1539c36689863f9d508cf0c6492a07c7a7a
1 # 2010 June 15
3 # The author disclaims copyright to this source code.  In place of
4 # a legal notice, here is a blessing:
6 #    May you do good and not evil.
7 #    May you find forgiveness for yourself and forgive others.
8 #    May you share freely, never taking more than you give.
10 #***********************************************************************
13 set testdir [file dirname $argv0]
14 source $testdir/tester.tcl
15 source $testdir/lock_common.tcl
16 source $testdir/malloc_common.tcl
17 source $testdir/wal_common.tcl
19 # Do not use a codec for tests in this file, as the database file is
20 # manipulated directly using tcl scripts (using the [hexio_write] command).
22 do_not_use_codec
25 # pager1-1.*: Test inter-process locking (clients in multiple processes).
27 # pager1-2.*: Test intra-process locking (multiple clients in this process).
29 # pager1-3.*: Savepoint related tests.
31 # pager1-4.*: Hot-journal related tests.
33 # pager1-5.*: Cases related to multi-file commits.
35 # pager1-6.*: Cases related to "PRAGMA max_page_count"
37 # pager1-7.*: Cases specific to "PRAGMA journal_mode=TRUNCATE"
39 # pager1-8.*: Cases using temporary and in-memory databases.
41 # pager1-9.*: Tests related to the backup API.
43 # pager1-10.*: Test that the assumed file-system sector-size is limited to
44 #              64KB.
46 # pager1-12.*: Tests involving "PRAGMA page_size"
48 # pager1-13.*: Cases specific to "PRAGMA journal_mode=PERSIST"
50 # pager1-14.*: Cases specific to "PRAGMA journal_mode=OFF"
52 # pager1-15.*: Varying sqlite3_vfs.szOsFile
54 # pager1-16.*: Varying sqlite3_vfs.mxPathname
56 # pager1-17.*: Tests related to "PRAGMA omit_readlock"
58 # pager1-18.*: Test that the pager layer responds correctly if the b-tree
59 #              requests an invalid page number (due to db corruption).
62 proc recursive_select {id table {script {}}} {
63   set cnt 0
64   db eval "SELECT rowid, * FROM $table WHERE rowid = ($id-1)" {
65     recursive_select $rowid $table $script
66     incr cnt
67   }
68   if {$cnt==0} { eval $script }
71 set a_string_counter 1
72 proc a_string {n} {
73   global a_string_counter
74   incr a_string_counter
75   string range [string repeat "${a_string_counter}." $n] 1 $n
77 db func a_string a_string
79 do_multiclient_test tn {
81   # Create and populate a database table using connection [db]. Check 
82   # that connections [db2] and [db3] can see the schema and content.
83   #
84   do_test pager1-$tn.1 {
85     sql1 {
86       CREATE TABLE t1(a PRIMARY KEY, b);
87       CREATE INDEX i1 ON t1(b);
88       INSERT INTO t1 VALUES(1, 'one'); INSERT INTO t1 VALUES(2, 'two');
89     }
90   } {}
91   do_test pager1-$tn.2 { sql2 { SELECT * FROM t1 } } {1 one 2 two}
92   do_test pager1-$tn.3 { sql3 { SELECT * FROM t1 } } {1 one 2 two}
94   # Open a transaction and add a row using [db]. This puts [db] in
95   # RESERVED state. Check that connections [db2] and [db3] can still
96   # read the database content as it was before the transaction was
97   # opened. [db] should see the inserted row.
98   #
99   do_test pager1-$tn.4 {
100     sql1 {
101       BEGIN;
102         INSERT INTO t1 VALUES(3, 'three');
103     }
104   } {}
105   do_test pager1-$tn.5 { sql2 { SELECT * FROM t1 } } {1 one 2 two}
106   do_test pager1-$tn.7 { sql1 { SELECT * FROM t1 } } {1 one 2 two 3 three}
108   # [db] still has an open write transaction. Check that this prevents
109   # other connections (specifically [db2]) from writing to the database.
110   #
111   # Even if [db2] opens a transaction first, it may not write to the
112   # database. After the attempt to write the db within a transaction, 
113   # [db2] is left with an open transaction, but not a read-lock on
114   # the main database. So it does not prevent [db] from committing.
115   #
116   do_test pager1-$tn.8 { 
117     csql2 { UPDATE t1 SET a = a + 10 }
118   } {1 {database is locked}}
119   do_test pager1-$tn.9 { 
120     csql2 { 
121       BEGIN;
122       UPDATE t1 SET a = a + 10;
123     }
124   } {1 {database is locked}}
126   # Have [db] commit its transactions. Check the other connections can
127   # now see the new database content.
128   #
129   do_test pager1-$tn.10 { sql1 { COMMIT } } {}
130   do_test pager1-$tn.11 { sql1 { SELECT * FROM t1 } } {1 one 2 two 3 three}
131   do_test pager1-$tn.12 { sql2 { SELECT * FROM t1 } } {1 one 2 two 3 three}
132   do_test pager1-$tn.13 { sql3 { SELECT * FROM t1 } } {1 one 2 two 3 three}
134   # Check that, as noted above, [db2] really did keep an open transaction
135   # after the attempt to write the database failed.
136   #
137   do_test pager1-$tn.14 { 
138     csql2 { BEGIN } 
139   } {1 {cannot start a transaction within a transaction}}
140   do_test pager1-$tn.15 { sql2 { ROLLBACK } } {}
142   # Have [db2] open a transaction and take a read-lock on the database.
143   # Check that this prevents [db] from writing to the database (outside
144   # of any transaction). After this fails, check that [db3] can read
145   # the db (showing that [db] did not take a PENDING lock etc.)
146   #
147   do_test pager1-$tn.15 { 
148     sql2 { BEGIN; SELECT * FROM t1; }
149   } {1 one 2 two 3 three}
150   do_test pager1-$tn.16 { 
151     csql1 { UPDATE t1 SET a = a + 10 }
152   } {1 {database is locked}}
153   do_test pager1-$tn.17 { sql3 { SELECT * FROM t1 } } {1 one 2 two 3 three}
155   # This time, have [db] open a transaction before writing the database.
156   # This works - [db] gets a RESERVED lock which does not conflict with
157   # the SHARED lock [db2] is holding.
158   #
159   do_test pager1-$tn.18 { 
160     sql1 { 
161       BEGIN;  
162       UPDATE t1 SET a = a + 10; 
163     }
164   } {}
165   do_test pager1-$tn-19 { 
166     sql1 { PRAGMA lock_status } 
167   } {main reserved temp closed}
168   do_test pager1-$tn-20 { 
169     sql2 { PRAGMA lock_status } 
170   } {main shared temp closed}
172   # Check that all connections can still read the database. Only [db] sees
173   # the updated content (as the transaction has not been committed yet).
174   #
175   do_test pager1-$tn.21 { sql1 { SELECT * FROM t1 } } {11 one 12 two 13 three}
176   do_test pager1-$tn.22 { sql2 { SELECT * FROM t1 } } {1 one 2 two 3 three}
177   do_test pager1-$tn.23 { sql3 { SELECT * FROM t1 } } {1 one 2 two 3 three}
179   # Because [db2] still has the SHARED lock, [db] is unable to commit the
180   # transaction. If it tries, an error is returned and the connection 
181   # upgrades to a PENDING lock.
182   #
183   # Once this happens, [db] can read the database and see the new content,
184   # [db2] (still holding SHARED) can still read the old content, but [db3]
185   # (not holding any lock) is prevented by [db]'s PENDING from reading
186   # the database.
187   #
188   do_test pager1-$tn.24 { csql1 { COMMIT } } {1 {database is locked}}
189   do_test pager1-$tn-25 { 
190     sql1 { PRAGMA lock_status } 
191   } {main pending temp closed}
192   do_test pager1-$tn.26 { sql1 { SELECT * FROM t1  } } {11 one 12 two 13 three}
193   do_test pager1-$tn.27 { sql2 { SELECT * FROM t1  } } {1 one 2 two 3 three}
194   do_test pager1-$tn.28 { csql3 { SELECT * FROM t1 } } {1 {database is locked}}
196   # Have [db2] commit its read transaction, releasing the SHARED lock it
197   # is holding. Now, neither [db2] nor [db3] may read the database (as [db]
198   # is still holding a PENDING).
199   #
200   do_test pager1-$tn.29 { sql2 { COMMIT } } {}
201   do_test pager1-$tn.30 { csql2 { SELECT * FROM t1 } } {1 {database is locked}}
202   do_test pager1-$tn.31 { csql3 { SELECT * FROM t1 } } {1 {database is locked}}
204   # [db] is now able to commit the transaction. Once the transaction is 
205   # committed, all three connections can read the new content.
206   #
207   do_test pager1-$tn.25 { sql1 { UPDATE t1 SET a = a+10 } } {}
208   do_test pager1-$tn.26 { sql1 { COMMIT } } {}
209   do_test pager1-$tn.27 { sql1 { SELECT * FROM t1 } } {21 one 22 two 23 three}
210   do_test pager1-$tn.27 { sql2 { SELECT * FROM t1 } } {21 one 22 two 23 three}
211   do_test pager1-$tn.28 { sql3 { SELECT * FROM t1 } } {21 one 22 two 23 three}
213   # Install a busy-handler for connection [db].
214   #
215   set ::nbusy [list]
216   proc busy {n} {
217     lappend ::nbusy $n
218     if {$n>5} { sql2 COMMIT }
219     return 0
220   }
221   db busy busy
223   do_test pager1-$tn.29 { 
224     sql1 { BEGIN ; INSERT INTO t1 VALUES('x', 'y') } 
225   } {}
226   do_test pager1-$tn.30 { 
227     sql2 { BEGIN ; SELECT * FROM t1 } 
228   } {21 one 22 two 23 three}
229   do_test pager1-$tn.31 { sql1 COMMIT } {}
230   do_test pager1-$tn.32 { set ::nbusy } {0 1 2 3 4 5 6}
233 #-------------------------------------------------------------------------
234 # Savepoint related test cases.
236 # pager1-3.1.2.*: Force a savepoint rollback to cause the database file
237 #                 to grow.
239 # pager1-3.1.3.*: Use a journal created in synchronous=off mode as part
240 #                 of a savepoint rollback.
242 do_test pager1-3.1.1 {
243   faultsim_delete_and_reopen
244   execsql {
245     CREATE TABLE t1(a PRIMARY KEY, b);
246     CREATE TABLE counter(
247       i CHECK (i<5), 
248       u CHECK (u<10)
249     );
250     INSERT INTO counter VALUES(0, 0);
251     CREATE TRIGGER tr1 AFTER INSERT ON t1 BEGIN
252       UPDATE counter SET i = i+1;
253     END;
254     CREATE TRIGGER tr2 AFTER UPDATE ON t1 BEGIN
255       UPDATE counter SET u = u+1;
256     END;
257   }
258   execsql { SELECT * FROM counter }
259 } {0 0}
261 do_execsql_test pager1-3.1.2 {
262   PRAGMA cache_size = 10;
263   BEGIN;
264     INSERT INTO t1 VALUES(1, randomblob(1500));
265     INSERT INTO t1 VALUES(2, randomblob(1500));
266     INSERT INTO t1 VALUES(3, randomblob(1500));
267     SELECT * FROM counter;
268 } {3 0}
269 do_catchsql_test pager1-3.1.3 {
270     INSERT INTO t1 SELECT a+3, randomblob(1500) FROM t1
271 } {1 {constraint failed}}
272 do_execsql_test pager1-3.4 { SELECT * FROM counter } {3 0}
273 do_execsql_test pager1-3.5 { SELECT a FROM t1 } {1 2 3}
274 do_execsql_test pager1-3.6 { COMMIT } {}
276 foreach {tn sql tcl} {
277   7  { PRAGMA synchronous = NORMAL ; PRAGMA temp_store = 0 } {
278     testvfs tv -default 1
279     tv devchar safe_append
280   }
281   8  { PRAGMA synchronous = NORMAL ; PRAGMA temp_store = 2 } {
282     testvfs tv -default 1
283     tv devchar sequential
284   }
285   9  { PRAGMA synchronous = FULL } { }
286   10 { PRAGMA synchronous = NORMAL } { }
287   11 { PRAGMA synchronous = OFF } { }
288   12 { PRAGMA synchronous = FULL ; PRAGMA fullfsync = 1 } { }
289   13 { PRAGMA synchronous = FULL } {
290     testvfs tv -default 1
291     tv devchar sequential
292   }
293   14 { PRAGMA locking_mode = EXCLUSIVE } {
294   }
295 } {
296   do_test pager1-3.$tn.1 {
297     eval $tcl
298     faultsim_delete_and_reopen
299     db func a_string a_string
300     execsql $sql
301     execsql {
302       PRAGMA auto_vacuum = 2;
303       PRAGMA cache_size = 10;
304       CREATE TABLE z(x INTEGER PRIMARY KEY, y);
305       BEGIN;
306         INSERT INTO z VALUES(NULL, a_string(800));
307         INSERT INTO z SELECT NULL, a_string(800) FROM z;     --   2
308         INSERT INTO z SELECT NULL, a_string(800) FROM z;     --   4
309         INSERT INTO z SELECT NULL, a_string(800) FROM z;     --   8
310         INSERT INTO z SELECT NULL, a_string(800) FROM z;     --  16
311         INSERT INTO z SELECT NULL, a_string(800) FROM z;     --  32
312         INSERT INTO z SELECT NULL, a_string(800) FROM z;     --  64
313         INSERT INTO z SELECT NULL, a_string(800) FROM z;     -- 128
314         INSERT INTO z SELECT NULL, a_string(800) FROM z;     -- 256
315       COMMIT;
316     }
317     execsql { PRAGMA auto_vacuum }
318   } {2}
319   do_execsql_test pager1-3.$tn.2 {
320     BEGIN;
321       INSERT INTO z VALUES(NULL, a_string(800));
322       INSERT INTO z VALUES(NULL, a_string(800));
323       SAVEPOINT one;
324         UPDATE z SET y = NULL WHERE x>256;
325         PRAGMA incremental_vacuum;
326         SELECT count(*) FROM z WHERE x < 100;
327       ROLLBACK TO one;
328     COMMIT;
329   } {99}
331   do_execsql_test pager1-3.$tn.3 {
332     BEGIN;
333       SAVEPOINT one;
334         UPDATE z SET y = y||x;
335       ROLLBACK TO one;
336     COMMIT;
337     SELECT count(*) FROM z;
338   } {258}
340   do_execsql_test pager1-3.$tn.4 {
341     SAVEPOINT one;
342       UPDATE z SET y = y||x;
343     ROLLBACK TO one;
344   } {}
345   do_execsql_test pager1-3.$tn.5 {
346     SELECT count(*) FROM z;
347     RELEASE one;
348     PRAGMA integrity_check;
349   } {258 ok}
351   do_execsql_test pager1-3.$tn.6 {
352     SAVEPOINT one;
353     RELEASE one;
354   } {}
356   db close
357   catch { tv delete }
360 #-------------------------------------------------------------------------
361 # Hot journal rollback related test cases.
363 # pager1.4.1.*: Test that the pager module deletes very small invalid
364 #               journal files.
366 # pager1.4.2.*: Test that if the master journal pointer at the end of a
367 #               hot-journal file appears to be corrupt (checksum does not
368 #               compute) the associated journal is rolled back (and no
369 #               xAccess() call to check for the presence of any master 
370 #               journal file is made).
372 # pager1.4.3.*: Test that the contents of a hot-journal are ignored if the
373 #               page-size or sector-size in the journal header appear to
374 #               be invalid (too large, too small or not a power of 2).
376 # pager1.4.4.*: Test hot-journal rollback of journal file with a master
377 #               journal pointer generated in various "PRAGMA synchronous"
378 #               modes.
380 # pager1.4.5.*: Test that hot-journal rollback stops if it encounters a
381 #               journal-record for which the checksum fails.
383 # pager1.4.6.*: Test that when rolling back a hot-journal that contains a
384 #               master journal pointer, the master journal file is deleted
385 #               after all the hot-journals that refer to it are deleted.
387 # pager1.4.7.*: Test that if a hot-journal file exists but a client can
388 #               open it for reading only, the database cannot be accessed and
389 #               SQLITE_CANTOPEN is returned.
391 do_test pager1.4.1.1 {
392   faultsim_delete_and_reopen
393   execsql { 
394     CREATE TABLE x(y, z);
395     INSERT INTO x VALUES(1, 2);
396   }
397   set fd [open test.db-journal w]
398   puts -nonewline $fd "helloworld"
399   close $fd
400   file exists test.db-journal
401 } {1}
402 do_test pager1.4.1.2 { execsql { SELECT * FROM x } } {1 2}
403 do_test pager1.4.1.3 { file exists test.db-journal } {0}
405 # Set up a [testvfs] to snapshot the file-system just before SQLite
406 # deletes the master-journal to commit a multi-file transaction.
408 # In subsequent test cases, invoking [faultsim_restore_and_reopen] sets
409 # up the file system to contain two databases, two hot-journal files and
410 # a master-journal.
412 do_test pager1.4.2.1 {
413   testvfs tstvfs -default 1
414   tstvfs filter xDelete
415   tstvfs script xDeleteCallback
416   proc xDeleteCallback {method file args} {
417     set file [file tail $file]
418     if { [string match *mj* $file] } { faultsim_save }
419   }
420   faultsim_delete_and_reopen
421   db func a_string a_string
422   execsql {
423     ATTACH 'test.db2' AS aux;
424     PRAGMA journal_mode = DELETE;
425     PRAGMA main.cache_size = 10;
426     PRAGMA aux.cache_size = 10;
427     CREATE TABLE t1(a UNIQUE, b UNIQUE);
428     CREATE TABLE aux.t2(a UNIQUE, b UNIQUE);
429     INSERT INTO t1 VALUES(a_string(200), a_string(300));
430     INSERT INTO t1 SELECT a_string(200), a_string(300) FROM t1;
431     INSERT INTO t1 SELECT a_string(200), a_string(300) FROM t1;
432     INSERT INTO t2 SELECT * FROM t1;
433     BEGIN;
434       INSERT INTO t1 SELECT a_string(201), a_string(301) FROM t1;
435       INSERT INTO t1 SELECT a_string(202), a_string(302) FROM t1;
436       INSERT INTO t1 SELECT a_string(203), a_string(303) FROM t1;
437       INSERT INTO t1 SELECT a_string(204), a_string(304) FROM t1;
438       REPLACE INTO t2 SELECT * FROM t1;
439     COMMIT;
440   }
441   db close
442   tstvfs delete
443 } {}
444 do_test pager1.4.2.2 {
445   faultsim_restore_and_reopen
446   execsql {
447     SELECT count(*) FROM t1;
448     PRAGMA integrity_check;
449   }
450 } {4 ok}
451 do_test pager1.4.2.3 {
452   faultsim_restore_and_reopen
453   foreach f [glob test.db-mj*] { file delete -force $f }
454   execsql {
455     SELECT count(*) FROM t1;
456     PRAGMA integrity_check;
457   }
458 } {64 ok}
459 do_test pager1.4.2.4 {
460   faultsim_restore_and_reopen
461   hexio_write test.db-journal [expr [file size test.db-journal]-20] 123456
462   execsql {
463     SELECT count(*) FROM t1;
464     PRAGMA integrity_check;
465   }
466 } {4 ok}
467 do_test pager1.4.2.5 {
468   faultsim_restore_and_reopen
469   hexio_write test.db-journal [expr [file size test.db-journal]-20] 123456
470   foreach f [glob test.db-mj*] { file delete -force $f }
471   execsql {
472     SELECT count(*) FROM t1;
473     PRAGMA integrity_check;
474   }
475 } {4 ok}
477 do_test pager1.4.3.1 {
478   testvfs tstvfs -default 1
479   tstvfs filter xSync
480   tstvfs script xSyncCallback
481   proc xSyncCallback {method file args} {
482     set file [file tail $file]
483     if { 0==[string match *journal $file] } { faultsim_save }
484   }
485   faultsim_delete_and_reopen
486   execsql {
487     PRAGMA journal_mode = DELETE;
488     CREATE TABLE t1(a, b);
489     INSERT INTO t1 VALUES(1, 2);
490     INSERT INTO t1 VALUES(3, 4);
491   }
492   db close
493   tstvfs delete
494 } {}
496 foreach {tn ofst value result} {
497           2   20    31       {1 2 3 4}
498           3   20    32       {1 2 3 4}
499           4   20    33       {1 2 3 4}
500           5   20    65536    {1 2 3 4}
501           6   20    131072   {1 2 3 4}
503           7   24    511      {1 2 3 4}
504           8   24    513      {1 2 3 4}
505           9   24    131072   {1 2 3 4}
507          10   32    65536    {1 2}
508 } {
509   do_test pager1.4.3.$tn {
510     faultsim_restore_and_reopen
511     hexio_write test.db-journal $ofst [format %.8x $value]
512     execsql { SELECT * FROM t1 }
513   } $result
515 db close
517 # Set up a VFS that snapshots the file-system just before a master journal
518 # file is deleted to commit a multi-file transaction. Specifically, the
519 # file-system is saved just before the xDelete() call to remove the 
520 # master journal file from the file-system.
522 testvfs tv -default 1
523 tv script copy_on_mj_delete
524 set ::mj_filename_length 0
525 proc copy_on_mj_delete {method filename args} {
526   if {[string match *mj* [file tail $filename]]} { 
527     set ::mj_filename_length [string length $filename]
528     faultsim_save 
529   }
530   return SQLITE_OK
533 set pwd [pwd]
534 foreach {tn1 tcl} {
535   1 { set prefix "test.db" }
536   2 { 
537     # This test depends on the underlying VFS being able to open paths
538     # 512 bytes in length. The idea is to create a hot-journal file that
539     # contains a master-journal pointer so large that it could contain
540     # a valid page record (if the file page-size is 512 bytes). So as to
541     # make sure SQLite doesn't get confused by this.
542     #
543     set nPadding [expr 511 - $::mj_filename_length]
544     if {$tcl_platform(platform)=="windows"} {
545       # TBD need to figure out how to do this correctly for Windows!!!
546       set nPadding [expr 255 - $::mj_filename_length]
547     }
549     # We cannot just create a really long database file name to open, as
550     # Linux limits a single component of a path to 255 bytes by default
551     # (and presumably other systems have limits too). So create a directory
552     # hierarchy to work in.
553     #
554     set dirname "d123456789012345678901234567890/"
555     set nDir [expr $nPadding / 32]
556     if { $nDir } {
557       set p [string repeat $dirname $nDir]
558       file mkdir $p
559       cd $p
560     }
562     set padding [string repeat x [expr $nPadding %32]]
563     set prefix "test.db${padding}"
564   }
565 } {
566   eval $tcl
567   foreach {tn2 sql} {
568     o { 
569       PRAGMA main.synchronous=OFF;
570       PRAGMA aux.synchronous=OFF;
571       PRAGMA journal_mode = DELETE;
572     }
573     o512 { 
574       PRAGMA main.synchronous=OFF;
575       PRAGMA aux.synchronous=OFF;
576       PRAGMA main.page_size = 512;
577       PRAGMA aux.page_size = 512;
578       PRAGMA journal_mode = DELETE;
579     }
580     n { 
581       PRAGMA main.synchronous=NORMAL;
582       PRAGMA aux.synchronous=NORMAL;
583       PRAGMA journal_mode = DELETE;
584     }
585     f { 
586       PRAGMA main.synchronous=FULL;
587       PRAGMA aux.synchronous=FULL;
588       PRAGMA journal_mode = DELETE;
589     }
590   } {
592     set tn "${tn1}.${tn2}"
593   
594     # Set up a connection to have two databases, test.db (main) and 
595     # test.db2 (aux). Then run a multi-file transaction on them. The
596     # VFS will snapshot the file-system just before the master-journal
597     # file is deleted to commit the transaction.
598     #
599     tv filter xDelete
600     do_test pager1-4.4.$tn.1 {
601       faultsim_delete_and_reopen $prefix
602       execsql "
603         ATTACH '${prefix}2' AS aux;
604         $sql
605         CREATE TABLE a(x);
606         CREATE TABLE aux.b(x);
607         INSERT INTO a VALUES('double-you');
608         INSERT INTO a VALUES('why');
609         INSERT INTO a VALUES('zed');
610         INSERT INTO b VALUES('won');
611         INSERT INTO b VALUES('too');
612         INSERT INTO b VALUES('free');
613       "
614       execsql {
615         BEGIN;
616           INSERT INTO a SELECT * FROM b WHERE rowid<=3;
617           INSERT INTO b SELECT * FROM a WHERE rowid<=3;
618         COMMIT;
619       }
620     } {}
621     tv filter {}
622     
623     # Check that the transaction was committed successfully.
624     #
625     do_execsql_test pager1-4.4.$tn.2 {
626       SELECT * FROM a
627     } {double-you why zed won too free}
628     do_execsql_test pager1-4.4.$tn.3 {
629       SELECT * FROM b
630     } {won too free double-you why zed}
631     
632     # Restore the file-system and reopen the databases. Check that it now
633     # appears that the transaction was not committed (because the file-system
634     # was restored to the state where it had not been).
635     #
636     do_test pager1-4.4.$tn.4 {
637       faultsim_restore_and_reopen $prefix
638       execsql "ATTACH '${prefix}2' AS aux"
639     } {}
640     do_execsql_test pager1-4.4.$tn.5 {SELECT * FROM a} {double-you why zed}
641     do_execsql_test pager1-4.4.$tn.6 {SELECT * FROM b} {won too free}
642     
643     # Restore the file-system again. This time, before reopening the databases,
644     # delete the master-journal file from the file-system. It now appears that
645     # the transaction was committed (no master-journal file == no rollback).
646     #
647     do_test pager1-4.4.$tn.7 {
648       faultsim_restore_and_reopen $prefix
649       foreach f [glob ${prefix}-mj*] { file delete -force $f }
650       execsql "ATTACH '${prefix}2' AS aux"
651     } {}
652     do_execsql_test pager1-4.4.$tn.8 {
653       SELECT * FROM a
654     } {double-you why zed won too free}
655     do_execsql_test pager1-4.4.$tn.9 {
656       SELECT * FROM b
657     } {won too free double-you why zed}
658   }
660   cd $pwd
662 db close
663 tv delete
664 file delete -force $dirname
667 # Set up a VFS to make a copy of the file-system just before deleting a
668 # journal file to commit a transaction. The transaction modifies exactly
669 # two database pages (and page 1 - the change counter).
671 testvfs tv -default 1
672 tv sectorsize 512
673 tv script copy_on_journal_delete
674 tv filter xDelete
675 proc copy_on_journal_delete {method filename args} {
676   if {[string match *journal $filename]} faultsim_save 
677   return SQLITE_OK
679 faultsim_delete_and_reopen
680 do_execsql_test pager1.4.5.1 {
681   PRAGMA journal_mode = DELETE;
682   PRAGMA page_size = 1024;
683   CREATE TABLE t1(a, b);
684   CREATE TABLE t2(a, b);
685   INSERT INTO t1 VALUES('I', 'II');
686   INSERT INTO t2 VALUES('III', 'IV');
687   BEGIN;
688     INSERT INTO t1 VALUES(1, 2);
689     INSERT INTO t2 VALUES(3, 4);
690   COMMIT;
691 } {delete}
692 tv filter {}
694 # Check the transaction was committed:
696 do_execsql_test pager1.4.5.2 {
697   SELECT * FROM t1;
698   SELECT * FROM t2;
699 } {I II 1 2 III IV 3 4}
701 # Now try four tests:
703 #  pager1-4.5.3: Restore the file-system. Check that the whole transaction 
704 #                is rolled back.
706 #  pager1-4.5.4: Restore the file-system. Corrupt the first record in the
707 #                journal. Check the transaction is not rolled back.
709 #  pager1-4.5.5: Restore the file-system. Corrupt the second record in the
710 #                journal. Check that the first record in the transaction is 
711 #                played back, but not the second.
713 #  pager1-4.5.6: Restore the file-system. Try to open the database with a
714 #                readonly connection. This should fail, as a read-only
715 #                connection cannot roll back the database file.
717 faultsim_restore_and_reopen
718 do_execsql_test pager1.4.5.3 {
719   SELECT * FROM t1;
720   SELECT * FROM t2;
721 } {I II III IV}
722 faultsim_restore_and_reopen
723 hexio_write test.db-journal [expr 512+4+1024 - 202] 0123456789ABCDEF
724 do_execsql_test pager1.4.5.4 {
725   SELECT * FROM t1;
726   SELECT * FROM t2;
727 } {I II 1 2 III IV 3 4}
728 faultsim_restore_and_reopen
729 hexio_write test.db-journal [expr 512+4+1024+4+4+1024 - 202] 0123456789ABCDEF
730 do_execsql_test pager1.4.5.5 {
731   SELECT * FROM t1;
732   SELECT * FROM t2;
733 } {I II III IV 3 4}
735 faultsim_restore_and_reopen
736 db close
737 sqlite3 db test.db -readonly 1
738 do_catchsql_test pager1.4.5.6 {
739   SELECT * FROM t1;
740   SELECT * FROM t2;
741 } {1 {disk I/O error}}
742 db close
744 # Snapshot the file-system just before multi-file commit. Save the name
745 # of the master journal file in $::mj_filename.
747 tv script copy_on_mj_delete
748 tv filter xDelete
749 proc copy_on_mj_delete {method filename args} {
750   if {[string match *mj* [file tail $filename]]} { 
751     set ::mj_filename $filename
752     faultsim_save 
753   }
754   return SQLITE_OK
756 do_test pager1.4.6.1 {
757   faultsim_delete_and_reopen
758   execsql {
759     PRAGMA journal_mode = DELETE;
760     ATTACH 'test.db2' AS two;
761     CREATE TABLE t1(a, b);
762     CREATE TABLE two.t2(a, b);
763     INSERT INTO t1 VALUES(1, 't1.1');
764     INSERT INTO t2 VALUES(1, 't2.1');
765     BEGIN;
766       UPDATE t1 SET b = 't1.2';
767       UPDATE t2 SET b = 't2.2';
768     COMMIT;
769   }
770   tv filter {}
771   db close
772 } {}
774 faultsim_restore_and_reopen
775 do_execsql_test pager1.4.6.2 { SELECT * FROM t1 }           {1 t1.1}
776 do_test         pager1.4.6.3 { file exists $::mj_filename } {1}
777 do_execsql_test pager1.4.6.4 {
778   ATTACH 'test.db2' AS two;
779   SELECT * FROM t2;
780 } {1 t2.1}
781 do_test pager1.4.6.5 { file exists $::mj_filename } {0}
783 faultsim_restore_and_reopen
784 db close
785 do_test pager1.4.6.8 {
786   set ::mj_filename1 $::mj_filename
787   tv filter xDelete
788   sqlite3 db test.db2
789   execsql {
790     PRAGMA journal_mode = DELETE;
791     ATTACH 'test.db3' AS three;
792     CREATE TABLE three.t3(a, b);
793     INSERT INTO t3 VALUES(1, 't3.1');
794     BEGIN;
795       UPDATE t2 SET b = 't2.3';
796       UPDATE t3 SET b = 't3.3';
797     COMMIT;
798   }
799   expr {$::mj_filename1 != $::mj_filename}
800 } {1}
801 faultsim_restore_and_reopen
802 tv filter {}
804 # The file-system now contains:
806 #   * three databases
807 #   * three hot-journal files
808 #   * two master-journal files.
810 # The hot-journals associated with test.db2 and test.db3 point to
811 # master journal $::mj_filename. The hot-journal file associated with
812 # test.db points to master journal $::mj_filename1. So reading from
813 # test.db should delete $::mj_filename1.
815 do_test pager1.4.6.9 {
816   lsort [glob test.db*]
817 } [lsort [list                                           \
818   test.db test.db2 test.db3                              \
819   test.db-journal test.db2-journal test.db3-journal      \
820   [file tail $::mj_filename] [file tail $::mj_filename1]
823 # The master-journal $::mj_filename1 contains pointers to test.db and 
824 # test.db2. However the hot-journal associated with test.db2 points to
825 # a different master-journal. Therefore, reading from test.db only should
826 # be enough to cause SQLite to delete $::mj_filename1.
828 do_test         pager1.4.6.10 { file exists $::mj_filename  } {1}
829 do_test         pager1.4.6.11 { file exists $::mj_filename1 } {1}
830 do_execsql_test pager1.4.6.12 { SELECT * FROM t1 } {1 t1.1}
831 do_test         pager1.4.6.13 { file exists $::mj_filename  } {1}
832 do_test         pager1.4.6.14 { file exists $::mj_filename1 } {0}
834 do_execsql_test pager1.4.6.12 {
835   ATTACH 'test.db2' AS two;
836   SELECT * FROM t2;
837 } {1 t2.1}
838 do_test         pager1.4.6.13 { file exists $::mj_filename }  {1}
839 do_execsql_test pager1.4.6.14 {
840   ATTACH 'test.db3' AS three;
841   SELECT * FROM t3;
842 } {1 t3.1}
843 do_test         pager1.4.6.15 { file exists $::mj_filename }  {0}
845 db close
846 tv delete
848 testvfs tv -default 1
849 tv sectorsize 512
850 tv script copy_on_journal_delete
851 tv filter xDelete
852 proc copy_on_journal_delete {method filename args} {
853   if {[string match *journal $filename]} faultsim_save 
854   return SQLITE_OK
856 faultsim_delete_and_reopen
857 do_execsql_test pager1.4.7.1 {
858   PRAGMA journal_mode = DELETE;
859   CREATE TABLE t1(x PRIMARY KEY, y);
860   CREATE INDEX i1 ON t1(y);
861   INSERT INTO t1 VALUES('I',   'one');
862   INSERT INTO t1 VALUES('II',  'four');
863   INSERT INTO t1 VALUES('III', 'nine');
864   BEGIN;
865     INSERT INTO t1 VALUES('IV', 'sixteen');
866     INSERT INTO t1 VALUES('V' , 'twentyfive');
867   COMMIT;
868 } {delete}
869 tv filter {}
870 db close
871 tv delete 
872 do_test pager1.4.7.2 {
873   faultsim_restore_and_reopen
874   catch {file attributes test.db-journal -permissions r--------}
875   catch {file attributes test.db-journal -readonly 1}
876   catchsql { SELECT * FROM t1 }
877 } {1 {unable to open database file}}
878 do_test pager1.4.7.3 {
879   db close
880   catch {file attributes test.db-journal -permissions rw-rw-rw-}
881   catch {file attributes test.db-journal -readonly 0}
882   file delete test.db-journal
883   file exists test.db-journal
884 } {0}
886 #-------------------------------------------------------------------------
887 # The following tests deal with multi-file commits.
889 # pager1-5.1.*: The case where a multi-file cannot be committed because
890 #               another connection is holding a SHARED lock on one of the
891 #               files. After the SHARED lock is removed, the COMMIT succeeds.
893 # pager1-5.2.*: Multi-file commits with journal_mode=memory.
895 # pager1-5.3.*: Multi-file commits with journal_mode=memory.
897 # pager1-5.4.*: Check that with synchronous=normal, the master-journal file
898 #               name is added to a journal file immediately after the last
899 #               journal record. But with synchronous=full, extra unused space
900 #               is allocated between the last journal record and the 
901 #               master-journal file name so that the master-journal file
902 #               name does not lie on the same sector as the last journal file
903 #               record.
905 # pager1-5.5.*: Check that in journal_mode=PERSIST mode, a journal file is
906 #               truncated to zero bytes when a multi-file transaction is 
907 #               committed (instead of the first couple of bytes being zeroed).
910 do_test pager1-5.1.1 {
911   faultsim_delete_and_reopen
912   execsql {
913     ATTACH 'test.db2' AS aux;
914     CREATE TABLE t1(a, b);
915     CREATE TABLE aux.t2(a, b);
916     INSERT INTO t1 VALUES(17, 'Lenin');
917     INSERT INTO t1 VALUES(22, 'Stalin');
918     INSERT INTO t1 VALUES(53, 'Khrushchev');
919   }
920 } {}
921 do_test pager1-5.1.2 {
922   execsql {
923     BEGIN;
924       INSERT INTO t1 VALUES(64, 'Brezhnev');
925       INSERT INTO t2 SELECT * FROM t1;
926   }
927   sqlite3 db2 test.db2
928   execsql {
929     BEGIN;
930       SELECT * FROM t2;
931   } db2
932 } {}
933 do_test pager1-5.1.3 {
934   catchsql COMMIT
935 } {1 {database is locked}}
936 do_test pager1-5.1.4 {
937   execsql COMMIT db2
938   execsql COMMIT
939   execsql { SELECT * FROM t2 } db2
940 } {17 Lenin 22 Stalin 53 Khrushchev 64 Brezhnev}
941 do_test pager1-5.1.5 {
942   db2 close
943 } {}
945 do_test pager1-5.2.1 {
946   execsql {
947     PRAGMA journal_mode = memory;
948     BEGIN;
949       INSERT INTO t1 VALUES(84, 'Andropov');
950       INSERT INTO t2 VALUES(84, 'Andropov');
951     COMMIT;
952   }
953 } {memory}
954 do_test pager1-5.3.1 {
955   execsql {
956     PRAGMA journal_mode = off;
957     BEGIN;
958       INSERT INTO t1 VALUES(85, 'Gorbachev');
959       INSERT INTO t2 VALUES(85, 'Gorbachev');
960     COMMIT;
961   }
962 } {off}
964 do_test pager1-5.4.1 {
965   db close
966   testvfs tv
967   sqlite3 db test.db -vfs tv
968   execsql { ATTACH 'test.db2' AS aux }
970   tv filter xDelete
971   tv script max_journal_size
972   tv sectorsize 512
973   set ::max_journal 0
974   proc max_journal_size {method args} {
975     set sz 0
976     catch { set sz [file size test.db-journal] }
977     if {$sz > $::max_journal} {
978       set ::max_journal $sz
979     }
980     return SQLITE_OK
981   }
982   execsql {
983     PRAGMA journal_mode = DELETE;
984     PRAGMA synchronous = NORMAL;
985     BEGIN;
986       INSERT INTO t1 VALUES(85, 'Gorbachev');
987       INSERT INTO t2 VALUES(85, 'Gorbachev');
988     COMMIT;
989   }
990   set ::max_journal
991 } [expr 2615+[string length [pwd]]]
992 do_test pager1-5.4.2 {
993   set ::max_journal 0
994   execsql {
995     PRAGMA synchronous = full;
996     BEGIN;
997       DELETE FROM t1 WHERE b = 'Lenin';
998       DELETE FROM t2 WHERE b = 'Lenin';
999     COMMIT;
1000   }
1001   set ::max_journal
1002 } [expr 3111+[string length [pwd]]]
1003 db close
1004 tv delete
1006 do_test pager1-5.5.1 {
1007   sqlite3 db test.db
1008   execsql { 
1009     ATTACH 'test.db2' AS aux;
1010     PRAGMA journal_mode = PERSIST;
1011     CREATE TABLE t3(a, b);
1012     INSERT INTO t3 SELECT randomblob(1500), randomblob(1500) FROM t1;
1013     UPDATE t3 SET b = randomblob(1500);
1014   }
1015   expr [file size test.db-journal] > 15000
1016 } {1}
1017 do_test pager1-5.5.2 {
1018   execsql {
1019     PRAGMA synchronous = full;
1020     BEGIN;
1021       DELETE FROM t1 WHERE b = 'Stalin';
1022       DELETE FROM t2 WHERE b = 'Stalin';
1023     COMMIT;
1024   }
1025   file size test.db-journal
1026 } {0}
1029 #-------------------------------------------------------------------------
1030 # The following tests work with "PRAGMA max_page_count"
1032 do_test pager1-6.1 {
1033   faultsim_delete_and_reopen
1034   execsql {
1035     PRAGMA auto_vacuum = none;
1036     PRAGMA max_page_count = 10;
1037     CREATE TABLE t2(a, b);
1038     CREATE TABLE t3(a, b);
1039     CREATE TABLE t4(a, b);
1040     CREATE TABLE t5(a, b);
1041     CREATE TABLE t6(a, b);
1042     CREATE TABLE t7(a, b);
1043     CREATE TABLE t8(a, b);
1044     CREATE TABLE t9(a, b);
1045     CREATE TABLE t10(a, b);
1046   }
1047 } {10}
1048 do_catchsql_test pager1-6.2 {
1049   CREATE TABLE t11(a, b)
1050 } {1 {database or disk is full}}
1051 do_execsql_test pager1-6.4 { PRAGMA max_page_count      } {10}
1052 do_execsql_test pager1-6.5 { PRAGMA max_page_count = 15 } {15}
1053 do_execsql_test pager1-6.6 { CREATE TABLE t11(a, b)     } {}
1054 do_execsql_test pager1-6.7 {
1055   BEGIN;
1056     INSERT INTO t11 VALUES(1, 2);
1057     PRAGMA max_page_count = 13;
1058 } {13}
1059 do_execsql_test pager1-6.8 {
1060     INSERT INTO t11 VALUES(3, 4);
1061     PRAGMA max_page_count = 10;
1062 } {11}
1063 do_execsql_test pager1-6.9 { COMMIT } {}
1065 do_execsql_test pager1-6.10 { PRAGMA max_page_count = 10 } {11}
1066 do_execsql_test pager1-6.11 { SELECT * FROM t11 }          {1 2 3 4}
1067 do_execsql_test pager1-6.12 { PRAGMA max_page_count }      {11}
1070 #-------------------------------------------------------------------------
1071 # The following tests work with "PRAGMA journal_mode=TRUNCATE" and
1072 # "PRAGMA locking_mode=EXCLUSIVE".
1074 # Each test is specified with 5 variables. As follows:
1076 #   $tn:  Test Number. Used as part of the [do_test] test names.
1077 #   $sql: SQL to execute.
1078 #   $res: Expected result of executing $sql.
1079 #   $js:  The expected size of the journal file, in bytes, after executing
1080 #         the SQL script. Or -1 if the journal is not expected to exist.
1081 #   $ws:  The expected size of the WAL file, in bytes, after executing
1082 #         the SQL script. Or -1 if the WAL is not expected to exist.
1084 ifcapable wal {
1085   faultsim_delete_and_reopen
1086   foreach {tn sql res js ws} [subst {
1087   
1088     1  {
1089       CREATE TABLE t1(a, b);
1090       PRAGMA auto_vacuum=OFF;
1091       PRAGMA synchronous=NORMAL;
1092       PRAGMA page_size=1024;
1093       PRAGMA locking_mode=EXCLUSIVE;
1094       PRAGMA journal_mode=TRUNCATE;
1095       INSERT INTO t1 VALUES(1, 2);
1096     } {exclusive truncate} 0 -1
1097   
1098     2  {
1099       BEGIN IMMEDIATE;
1100         SELECT * FROM t1;
1101       COMMIT;
1102     } {1 2} 0 -1
1103   
1104     3  {
1105       BEGIN;
1106         SELECT * FROM t1;
1107       COMMIT;
1108     } {1 2} 0 -1
1109   
1110     4  { PRAGMA journal_mode = WAL }    wal       -1 -1
1111     5  { INSERT INTO t1 VALUES(3, 4) }  {}        -1 [wal_file_size 1 1024]
1112     6  { PRAGMA locking_mode = NORMAL } exclusive -1 [wal_file_size 1 1024]
1113     7  { INSERT INTO t1 VALUES(5, 6); } {}        -1 [wal_file_size 2 1024]
1114   
1115     8  { PRAGMA journal_mode = TRUNCATE } truncate          0 -1
1116     9  { INSERT INTO t1 VALUES(7, 8) }    {}                0 -1
1117     10 { SELECT * FROM t1 }               {1 2 3 4 5 6 7 8} 0 -1
1118   
1119   }] {
1120     do_execsql_test pager1-7.1.$tn.1 $sql $res
1121     catch { set J -1 ; set J [file size test.db-journal] }
1122     catch { set W -1 ; set W [file size test.db-wal] }
1123     do_test pager1-7.1.$tn.2 { list $J $W } [list $js $ws]
1124   }
1127 do_test pager1-7.2.1 {
1128   faultsim_delete_and_reopen
1129   execsql {
1130     PRAGMA locking_mode = EXCLUSIVE;
1131     CREATE TABLE t1(a, b);
1132     BEGIN;
1133       PRAGMA journal_mode = delete;
1134       PRAGMA journal_mode = truncate;
1135   }
1136 } {exclusive delete truncate}
1137 do_test pager1-7.2.2 {
1138   execsql { INSERT INTO t1 VALUES(1, 2) }
1139   execsql { PRAGMA journal_mode = persist }
1140 } {truncate}
1141 do_test pager1-7.2.3 {
1142   execsql { COMMIT }
1143   execsql {
1144     PRAGMA journal_mode = persist;
1145     PRAGMA journal_size_limit;
1146   }
1147 } {persist -1}
1149 #-------------------------------------------------------------------------
1150 # The following tests, pager1-8.*, test that the special filenames 
1151 # ":memory:" and "" open temporary databases.
1153 foreach {tn filename} {
1154   1 :memory:
1155   2 ""
1156 } {
1157   do_test pager1-8.$tn.1 {
1158     faultsim_delete_and_reopen
1159     db close
1160     sqlite3 db $filename
1161     execsql {
1162       PRAGMA auto_vacuum = 1;
1163       CREATE TABLE x1(x);
1164       INSERT INTO x1 VALUES('Charles');
1165       INSERT INTO x1 VALUES('James');
1166       INSERT INTO x1 VALUES('Mary');
1167       SELECT * FROM x1;
1168     }
1169   } {Charles James Mary}
1171   do_test pager1-8.$tn.2 {
1172     sqlite3 db2 $filename
1173     catchsql { SELECT * FROM x1 } db2
1174   } {1 {no such table: x1}}
1176   do_execsql_test pager1-8.$tn.3 {
1177     BEGIN;
1178       INSERT INTO x1 VALUES('William');
1179       INSERT INTO x1 VALUES('Anne');
1180     ROLLBACK;
1181   } {}
1184 #-------------------------------------------------------------------------
1185 # The next block of tests - pager1-9.* - deal with interactions between
1186 # the pager and the backup API. Test cases:
1188 #   pager1-9.1.*: Test that a backup completes successfully even if the
1189 #                 source db is written to during the backup op.
1191 #   pager1-9.2.*: Test that a backup completes successfully even if the
1192 #                 source db is written to and then rolled back during a 
1193 #                 backup operation.
1195 do_test pager1-9.0.1 {
1196   faultsim_delete_and_reopen
1197   db func a_string a_string
1198   execsql {
1199     PRAGMA cache_size = 10;
1200     BEGIN;
1201       CREATE TABLE ab(a, b, UNIQUE(a, b));
1202       INSERT INTO ab VALUES( a_string(200), a_string(300) );
1203       INSERT INTO ab SELECT a_string(200), a_string(300) FROM ab;
1204       INSERT INTO ab SELECT a_string(200), a_string(300) FROM ab;
1205       INSERT INTO ab SELECT a_string(200), a_string(300) FROM ab;
1206       INSERT INTO ab SELECT a_string(200), a_string(300) FROM ab;
1207       INSERT INTO ab SELECT a_string(200), a_string(300) FROM ab;
1208       INSERT INTO ab SELECT a_string(200), a_string(300) FROM ab;
1209       INSERT INTO ab SELECT a_string(200), a_string(300) FROM ab;
1210     COMMIT;
1211   }
1212 } {}
1213 do_test pager1-9.0.2 {
1214   sqlite3 db2 test.db2
1215   db2 eval { PRAGMA cache_size = 10 }
1216   sqlite3_backup B db2 main db main
1217   list [B step 10000] [B finish]
1218 } {SQLITE_DONE SQLITE_OK}
1219 do_test pager1-9.0.3 {
1220  db one {SELECT md5sum(a, b) FROM ab}
1221 } [db2 one {SELECT md5sum(a, b) FROM ab}]
1223 do_test pager1-9.1.1 {
1224   execsql { UPDATE ab SET a = a_string(201) }
1225   sqlite3_backup B db2 main db main
1226   B step 30
1227 } {SQLITE_OK}
1228 do_test pager1-9.1.2 {
1229   execsql { UPDATE ab SET b = a_string(301) }
1230   list [B step 10000] [B finish]
1231 } {SQLITE_DONE SQLITE_OK}
1232 do_test pager1-9.1.3 {
1233  db one {SELECT md5sum(a, b) FROM ab}
1234 } [db2 one {SELECT md5sum(a, b) FROM ab}]
1235 do_test pager1-9.1.4 { execsql { SELECT count(*) FROM ab } } {128}
1237 do_test pager1-9.2.1 {
1238   execsql { UPDATE ab SET a = a_string(202) }
1239   sqlite3_backup B db2 main db main
1240   B step 30
1241 } {SQLITE_OK}
1242 do_test pager1-9.2.2 {
1243   execsql { 
1244     BEGIN;
1245       UPDATE ab SET b = a_string(301);
1246     ROLLBACK;
1247   }
1248   list [B step 10000] [B finish]
1249 } {SQLITE_DONE SQLITE_OK}
1250 do_test pager1-9.2.3 {
1251  db one {SELECT md5sum(a, b) FROM ab}
1252 } [db2 one {SELECT md5sum(a, b) FROM ab}]
1253 do_test pager1-9.2.4 { execsql { SELECT count(*) FROM ab } } {128}
1254 db close
1255 db2 close
1257 do_test pager1-9.3.1 {
1258   testvfs tv -default 1
1259   tv sectorsize 4096
1260   faultsim_delete_and_reopen
1262   execsql { PRAGMA page_size = 1024 }
1263   for {set ii 0} {$ii < 4} {incr ii} { execsql "CREATE TABLE t${ii}(a, b)" }
1264 } {}
1265 do_test pager1-9.3.2 {
1266   sqlite3 db2 test.db2
1268   execsql {
1269     PRAGMA page_size = 4096;
1270     PRAGMA synchronous = OFF;
1271     CREATE TABLE t1(a, b);
1272     CREATE TABLE t2(a, b);
1273   } db2
1275   sqlite3_backup B db2 main db main
1276   B step 30
1277   list [B step 10000] [B finish]
1278 } {SQLITE_DONE SQLITE_OK}
1279 do_test pager1-9.3.3 {
1280   db2 close
1281   db close
1282   tv delete
1283   file size test.db2
1284 } [file size test.db]
1286 do_test pager1-9.4.1 {
1287   faultsim_delete_and_reopen
1288   sqlite3 db2 test.db2
1289   execsql {
1290     PRAGMA page_size = 4096;
1291     CREATE TABLE t1(a, b);
1292     CREATE TABLE t2(a, b);
1293   } db2
1294   sqlite3_backup B db2 main db main
1295   list [B step 10000] [B finish]
1296 } {SQLITE_DONE SQLITE_OK}
1297 do_test pager1-9.4.2 {
1298   list [file size test.db2] [file size test.db]
1299 } {0 0}
1300 db2 close
1302 #-------------------------------------------------------------------------
1303 # Test that regardless of the value returned by xSectorSize(), the
1304 # minimum effective sector-size is 512 and the maximum 65536 bytes.
1306 testvfs tv -default 1
1307 foreach sectorsize {
1308     32   64   128   256   512   1024   2048 
1309     4096 8192 16384 32768 65536 131072 262144
1310 } {
1311   tv sectorsize $sectorsize
1312   set eff $sectorsize
1313   if {$sectorsize < 512}   { set eff 512 }
1314   if {$sectorsize > 65536} { set eff 65536 }
1316   do_test pager1-10.$sectorsize.1 {
1317     faultsim_delete_and_reopen
1318     db func a_string a_string
1319     execsql {
1320       PRAGMA journal_mode = PERSIST;
1321       PRAGMA page_size = 1024;
1322       BEGIN;
1323         CREATE TABLE t1(a, b);
1324         CREATE TABLE t2(a, b);
1325         CREATE TABLE t3(a, b);
1326       COMMIT;
1327     }
1328     file size test.db-journal
1329   } [expr $sectorsize > 65536 ? 65536 : $sectorsize]
1331   do_test pager1-10.$sectorsize.2 {
1332     execsql { 
1333       INSERT INTO t3 VALUES(a_string(300), a_string(300));
1334       INSERT INTO t3 SELECT * FROM t3;        /*  2 */
1335       INSERT INTO t3 SELECT * FROM t3;        /*  4 */
1336       INSERT INTO t3 SELECT * FROM t3;        /*  8 */
1337       INSERT INTO t3 SELECT * FROM t3;        /* 16 */
1338       INSERT INTO t3 SELECT * FROM t3;        /* 32 */
1339     }
1340   } {}
1342   do_test pager1-10.$sectorsize.3 {
1343     db close
1344     sqlite3 db test.db
1345     execsql { 
1346       PRAGMA cache_size = 10;
1347       BEGIN;
1348     }
1349     recursive_select 32 t3 {db eval "INSERT INTO t2 VALUES(1, 2)"}
1350     execsql {
1351       COMMIT;
1352       SELECT * FROM t2;
1353     }
1354   } {1 2}
1356   do_test pager1-10.$sectorsize.4 {
1357     execsql {
1358       CREATE TABLE t6(a, b);
1359       CREATE TABLE t7(a, b);
1360       CREATE TABLE t5(a, b);
1361       DROP TABLE t6;
1362       DROP TABLE t7;
1363     }
1364     execsql {
1365       BEGIN;
1366         CREATE TABLE t6(a, b);
1367     }
1368     recursive_select 32 t3 {db eval "INSERT INTO t5 VALUES(1, 2)"}
1369     execsql {
1370       COMMIT;
1371       SELECT * FROM t5;
1372     }
1373   } {1 2}
1374   
1376 db close
1378 tv sectorsize 4096
1379 do_test pager1.10.x.1 {
1380   faultsim_delete_and_reopen
1381   execsql {
1382     PRAGMA auto_vacuum = none;
1383     PRAGMA page_size = 1024;
1384     CREATE TABLE t1(x);
1385   }
1386   for {set i 0} {$i<30} {incr i} {
1387     execsql { INSERT INTO t1 VALUES(zeroblob(900)) }
1388   }
1389   file size test.db
1390 } {32768}
1391 do_test pager1.10.x.2 {
1392   execsql {
1393     CREATE TABLE t2(x);
1394     DROP TABLE t2;
1395   }
1396   file size test.db
1397 } {33792}
1398 do_test pager1.10.x.3 {
1399   execsql {
1400     BEGIN;
1401     CREATE TABLE t2(x);
1402   }
1403   recursive_select 30 t1
1404   execsql {
1405     CREATE TABLE t3(x);
1406     COMMIT;
1407   }
1408 } {}
1410 db close
1411 tv delete
1413 testvfs tv -default 1
1414 faultsim_delete_and_reopen
1415 db func a_string a_string
1416 do_execsql_test pager1-11.1 {
1417   PRAGMA journal_mode = DELETE;
1418   PRAGMA cache_size = 10;
1419   BEGIN;
1420     CREATE TABLE zz(top PRIMARY KEY);
1421     INSERT INTO zz VALUES(a_string(222));
1422     INSERT INTO zz SELECT a_string((SELECT 222+max(rowid) FROM zz)) FROM zz;
1423     INSERT INTO zz SELECT a_string((SELECT 222+max(rowid) FROM zz)) FROM zz;
1424     INSERT INTO zz SELECT a_string((SELECT 222+max(rowid) FROM zz)) FROM zz;
1425     INSERT INTO zz SELECT a_string((SELECT 222+max(rowid) FROM zz)) FROM zz;
1426     INSERT INTO zz SELECT a_string((SELECT 222+max(rowid) FROM zz)) FROM zz;
1427   COMMIT;
1428   BEGIN;
1429     UPDATE zz SET top = a_string(345);
1430 } {delete}
1432 proc lockout {method args} { return SQLITE_IOERR }
1433 tv script lockout
1434 tv filter {xWrite xTruncate xSync}
1435 do_catchsql_test pager1-11.2 { COMMIT } {1 {disk I/O error}}
1437 tv script {}
1438 do_test pager1-11.3 {
1439   sqlite3 db2 test.db
1440   execsql {
1441     PRAGMA journal_mode = TRUNCATE;
1442     PRAGMA integrity_check;
1443   } db2
1444 } {truncate ok}
1445 do_test pager1-11.4 {
1446   db2 close
1447   file exists test.db-journal
1448 } {0}
1449 do_execsql_test pager1-11.5 { SELECT count(*) FROM zz } {32}
1450 db close
1451 tv delete
1452   
1453 #-------------------------------------------------------------------------
1454 # Test "PRAGMA page_size"
1456 testvfs tv -default 1
1457 tv sectorsize 1024
1458 foreach pagesize {
1459     512   1024   2048 4096 8192 16384 32768 
1460 } {
1461   faultsim_delete_and_reopen
1463   # The sector-size (according to the VFS) is 1024 bytes. So if the
1464   # page-size requested using "PRAGMA page_size" is greater than the
1465   # compile time value of SQLITE_MAX_PAGE_SIZE, then the effective 
1466   # page-size remains 1024 bytes.
1467   #
1468   set eff $pagesize
1469   if {$eff > $::SQLITE_MAX_PAGE_SIZE} { set eff 1024 }
1471   do_test pager1-12.$pagesize.1 {
1472     sqlite3 db2 test.db
1473     execsql "
1474       PRAGMA page_size = $pagesize;
1475       CREATE VIEW v AS SELECT * FROM sqlite_master;
1476     " db2
1477     file size test.db
1478   } $eff
1479   do_test pager1-12.$pagesize.2 {
1480     sqlite3 db2 test.db
1481     execsql { 
1482       SELECT count(*) FROM v;
1483       PRAGMA main.page_size;
1484     } db2
1485   } [list 1 $eff]
1486   do_test pager1-12.$pagesize.3 {
1487     execsql { 
1488       SELECT count(*) FROM v;
1489       PRAGMA main.page_size;
1490     }
1491   } [list 1 $eff]
1492   db2 close
1494 db close
1495 tv delete
1497 #-------------------------------------------------------------------------
1498 # Test specal "PRAGMA journal_mode=PERSIST" test cases.
1500 # pager1-13.1.*: This tests a special case encountered in persistent 
1501 #                journal mode: If the journal associated with a transaction
1502 #                is smaller than the journal file (because a previous 
1503 #                transaction left a very large non-hot journal file in the
1504 #                file-system), then SQLite has to be careful that there is
1505 #                not a journal-header left over from a previous transaction
1506 #                immediately following the journal content just written.
1507 #                If there is, and the process crashes so that the journal
1508 #                becomes a hot-journal and must be rolled back by another
1509 #                process, there is a danger that the other process may roll
1510 #                back the aborted transaction, then continue copying data
1511 #                from an older transaction from the remainder of the journal.
1512 #                See the syncJournal() function for details.
1514 # pager1-13.2.*: Same test as the previous. This time, throw an index into
1515 #                the mix to make the integrity-check more likely to catch
1516 #                errors.
1518 testvfs tv -default 1
1519 tv script xSyncCb
1520 tv filter xSync
1521 proc xSyncCb {method filename args} {
1522   set t [file tail $filename]
1523   if {$t == "test.db"} faultsim_save
1524   return SQLITE_OK
1526 faultsim_delete_and_reopen
1527 db func a_string a_string
1529 # The UPDATE statement at the end of this test case creates a really big
1530 # journal. Since the cache-size is only 10 pages, the journal contains 
1531 # frequent journal headers.
1533 do_execsql_test pager1-13.1.1 {
1534   PRAGMA page_size = 1024;
1535   PRAGMA journal_mode = PERSIST;
1536   PRAGMA cache_size = 10;
1537   BEGIN;
1538     CREATE TABLE t1(a INTEGER PRIMARY KEY, b BLOB);
1539     INSERT INTO t1 VALUES(NULL, a_string(400));
1540     INSERT INTO t1 SELECT NULL, a_string(400) FROM t1;          /*   2 */
1541     INSERT INTO t1 SELECT NULL, a_string(400) FROM t1;          /*   4 */
1542     INSERT INTO t1 SELECT NULL, a_string(400) FROM t1;          /*   8 */
1543     INSERT INTO t1 SELECT NULL, a_string(400) FROM t1;          /*  16 */
1544     INSERT INTO t1 SELECT NULL, a_string(400) FROM t1;          /*  32 */
1545     INSERT INTO t1 SELECT NULL, a_string(400) FROM t1;          /*  64 */
1546     INSERT INTO t1 SELECT NULL, a_string(400) FROM t1;          /* 128 */
1547   COMMIT;
1548   UPDATE t1 SET b = a_string(400);
1549 } {persist}
1551 # Run transactions of increasing sizes. Eventually, one (or more than one)
1552 # of these will write just enough content that one of the old headers created 
1553 # by the transaction in the block above lies immediately after the content
1554 # journalled by the current transaction.
1556 for {set nUp 1} {$nUp<64} {incr nUp} {
1557   do_execsql_test pager1-13.1.2.$nUp.1 { 
1558     UPDATE t1 SET b = a_string(399) WHERE a <= $nUp
1559   } {}
1560   do_execsql_test pager1-13.1.2.$nUp.2 { PRAGMA integrity_check } {ok} 
1562   # Try to access the snapshot of the file-system.
1563   #
1564   sqlite3 db2 sv_test.db
1565   do_test pager1-13.1.2.$nUp.3 {
1566     execsql { SELECT sum(length(b)) FROM t1 } db2
1567   } [expr {128*400 - ($nUp-1)}]
1568   do_test pager1-13.1.2.$nUp.4 {
1569     execsql { PRAGMA integrity_check } db2
1570   } {ok}
1571   db2 close
1574 # Same test as above. But this time with an index on the table.
1576 do_execsql_test pager1-13.2.1 {
1577   CREATE INDEX i1 ON t1(b);
1578   UPDATE t1 SET b = a_string(400);
1579 } {}
1580 for {set nUp 1} {$nUp<64} {incr nUp} {
1581   do_execsql_test pager1-13.2.2.$nUp.1 { 
1582     UPDATE t1 SET b = a_string(399) WHERE a <= $nUp
1583   } {}
1584   do_execsql_test pager1-13.2.2.$nUp.2 { PRAGMA integrity_check } {ok} 
1585   sqlite3 db2 sv_test.db
1586   do_test pager1-13.2.2.$nUp.3 {
1587     execsql { SELECT sum(length(b)) FROM t1 } db2
1588   } [expr {128*400 - ($nUp-1)}]
1589   do_test pager1-13.2.2.$nUp.4 {
1590     execsql { PRAGMA integrity_check } db2
1591   } {ok}
1592   db2 close
1595 db close
1596 tv delete
1598 #-------------------------------------------------------------------------
1599 # Test specal "PRAGMA journal_mode=OFF" test cases.
1601 faultsim_delete_and_reopen
1602 do_execsql_test pager1-14.1.1 {
1603   PRAGMA journal_mode = OFF;
1604   CREATE TABLE t1(a, b);
1605   BEGIN;
1606     INSERT INTO t1 VALUES(1, 2);
1607   COMMIT;
1608   SELECT * FROM t1;
1609 } {off 1 2}
1610 do_catchsql_test pager1-14.1.2 {
1611   BEGIN;
1612     INSERT INTO t1 VALUES(3, 4);
1613   ROLLBACK;
1614 } {0 {}}
1615 do_execsql_test pager1-14.1.3 {
1616   SELECT * FROM t1;
1617 } {1 2}
1618 do_catchsql_test pager1-14.1.4 {
1619   BEGIN;
1620     INSERT INTO t1(rowid, a, b) SELECT a+3, b, b FROM t1;
1621     INSERT INTO t1(rowid, a, b) SELECT a+3, b, b FROM t1;
1622 } {1 {PRIMARY KEY must be unique}}
1623 do_execsql_test pager1-14.1.5 {
1624   COMMIT;
1625   SELECT * FROM t1;
1626 } {1 2 2 2}
1628 #-------------------------------------------------------------------------
1629 # Test opening and closing the pager sub-system with different values
1630 # for the sqlite3_vfs.szOsFile variable.
1632 faultsim_delete_and_reopen
1633 do_execsql_test pager1-15.0 {
1634   CREATE TABLE tx(y, z);
1635   INSERT INTO tx VALUES('Ayutthaya', 'Beijing');
1636   INSERT INTO tx VALUES('London', 'Tokyo');
1637 } {}
1638 db close
1639 for {set i 0} {$i<513} {incr i 3} {
1640   testvfs tv -default 1 -szosfile $i
1641   sqlite3 db test.db
1642   do_execsql_test pager1-15.$i.1 {
1643     SELECT * FROM tx;
1644   } {Ayutthaya Beijing London Tokyo}
1645   db close
1646   tv delete
1649 #-------------------------------------------------------------------------
1650 # Check that it is not possible to open a database file if the full path
1651 # to the associated journal file will be longer than sqlite3_vfs.mxPathname.
1653 testvfs tv -default 1
1654 tv script xOpenCb
1655 tv filter xOpen
1656 proc xOpenCb {method filename} {
1657   set ::file_len [string length $filename]
1659 sqlite3 db test.db
1660 db close
1661 tv delete
1663 for {set ii [expr $::file_len-5]} {$ii < [expr $::file_len+20]} {incr ii} {
1664   testvfs tv -default 1 -mxpathname $ii
1666   # The length of the full path to file "test.db-journal" is ($::file_len+8).
1667   # If the configured sqlite3_vfs.mxPathname value greater than or equal to
1668   # this, then the file can be opened. Otherwise, it cannot.
1669   #
1670   if {$ii >= [expr $::file_len+8]} {
1671     set res {0 {}}
1672   } else {
1673     set res {1 {unable to open database file}}
1674   }
1676   do_test pager1-16.1.$ii {
1677     list [catch { sqlite3 db test.db } msg] $msg
1678   } $res
1680   catch {db close}
1681   tv delete
1684 #-------------------------------------------------------------------------
1685 # Test "PRAGMA omit_readlock". 
1687 #   pager1-17.$tn.1.*: Test that if a second connection has an open 
1688 #                      read-transaction, it is not usually possible to write 
1689 #                      the database.
1691 #   pager1-17.$tn.2.*: Test that if the second connection was opened with
1692 #                      the SQLITE_OPEN_READONLY flag, and 
1693 #                      "PRAGMA omit_readlock = 1" is executed before attaching
1694 #                      the database and opening a read-transaction on it, it is
1695 #                      possible to write the db.
1697 #   pager1-17.$tn.3.*: Test that if the second connection was *not* opened with
1698 #                      the SQLITE_OPEN_READONLY flag, executing 
1699 #                      "PRAGMA omit_readlock = 1" has no effect.
1701 do_multiclient_test tn {
1702   do_test pager1-17.$tn.1.1 {
1703     sql1 { 
1704       CREATE TABLE t1(a, b);
1705       INSERT INTO t1 VALUES(1, 2);
1706     }
1707     sql2 {
1708       BEGIN;
1709       SELECT * FROM t1;
1710     }
1711   } {1 2}
1712   do_test pager1-17.$tn.1.2 {
1713     csql1 { INSERT INTO t1 VALUES(3, 4) }
1714   } {1 {database is locked}}
1715   do_test pager1-17.$tn.1.3 {
1716     sql2 { COMMIT }
1717     sql1 { INSERT INTO t1 VALUES(3, 4) }
1718   } {}
1720   do_test pager1-17.$tn.2.1 {
1721     code2 {
1722       db2 close
1723       sqlite3 db2 :memory: -readonly 1
1724     }
1725     sql2 { 
1726       PRAGMA omit_readlock = 1;
1727       ATTACH 'test.db' AS two;
1728       BEGIN;
1729       SELECT * FROM t1;
1730     }
1731   } {1 2 3 4}
1732   do_test pager1-17.$tn.2.2 { sql1 "INSERT INTO t1 VALUES(5, 6)" } {}
1733   do_test pager1-17.$tn.2.3 { sql2 "SELECT * FROM t1" }            {1 2 3 4}
1734   do_test pager1-17.$tn.2.4 { sql2 "COMMIT ; SELECT * FROM t1" }   {1 2 3 4 5 6}
1736   do_test pager1-17.$tn.3.1 {
1737     code2 {
1738       db2 close
1739       sqlite3 db2 :memory:
1740     }
1741     sql2 { 
1742       PRAGMA omit_readlock = 1;
1743       ATTACH 'test.db' AS two;
1744       BEGIN;
1745       SELECT * FROM t1;
1746     }
1747   } {1 2 3 4 5 6}
1748   do_test pager1-17.$tn.3.2 {
1749   csql1 { INSERT INTO t1 VALUES(3, 4) }
1750   } {1 {database is locked}}
1751   do_test pager1-17.$tn.3.3 { sql2 COMMIT } {}
1754 #-------------------------------------------------------------------------
1755 # Test the pagers response to the b-tree layer requesting illegal page 
1756 # numbers:
1758 #   + The locking page,
1759 #   + Page 0,
1760 #   + A page with a page number greater than (2^31-1).
1762 do_test pager1-18.1 {
1763   faultsim_delete_and_reopen
1764   db func a_string a_string
1765   execsql { 
1766     PRAGMA page_size = 1024;
1767     CREATE TABLE t1(a, b);
1768     INSERT INTO t1 VALUES(a_string(500), a_string(200));
1769     INSERT INTO t1 SELECT a_string(500), a_string(200) FROM t1;
1770     INSERT INTO t1 SELECT a_string(500), a_string(200) FROM t1;
1771     INSERT INTO t1 SELECT a_string(500), a_string(200) FROM t1;
1772     INSERT INTO t1 SELECT a_string(500), a_string(200) FROM t1;
1773     INSERT INTO t1 SELECT a_string(500), a_string(200) FROM t1;
1774     INSERT INTO t1 SELECT a_string(500), a_string(200) FROM t1;
1775     INSERT INTO t1 SELECT a_string(500), a_string(200) FROM t1;
1776   }
1777 } {}
1778 do_test pager1-18.2 {
1779   set root [db one "SELECT rootpage FROM sqlite_master"]
1780   set lockingpage [expr (0x10000/1024) + 1]
1781   execsql {
1782     PRAGMA writable_schema = 1;
1783     UPDATE sqlite_master SET rootpage = $lockingpage;
1784   }
1785   sqlite3 db2 test.db
1786   catchsql { SELECT count(*) FROM t1 } db2
1787 } {1 {database disk image is malformed}}
1788 db2 close
1789 do_test pager1-18.3 {
1790   execsql {
1791     CREATE TABLE t2(x);
1792     INSERT INTO t2 VALUES(a_string(5000));
1793   }
1794   set pgno [expr ([file size test.db] / 1024)-2]
1795   hexio_write test.db [expr ($pgno-1)*1024] 00000000
1796   sqlite3 db2 test.db
1797   catchsql { SELECT length(x) FROM t2 } db2
1798 } {1 {database disk image is malformed}}
1799 db2 close
1800 do_test pager1-18.4 {
1801   hexio_write test.db [expr ($pgno-1)*1024] 90000000
1802   sqlite3 db2 test.db
1803   catchsql { SELECT length(x) FROM t2 } db2
1804 } {1 {database disk image is malformed}}
1805 db2 close
1806 do_test pager1-18.5 {
1807   sqlite3 db ""
1808   execsql {
1809     CREATE TABLE t1(a, b);
1810     CREATE TABLE t2(a, b);
1811     PRAGMA writable_schema = 1;
1812     UPDATE sqlite_master SET rootpage=5 WHERE tbl_name = 't1';
1813     PRAGMA writable_schema = 0;
1814     ALTER TABLE t1 RENAME TO x1;
1815   }
1816   catchsql { SELECT * FROM x1 }
1817 } {1 {database disk image is malformed}}
1818 db close
1820 do_test pager1-18.6 {
1821   faultsim_delete_and_reopen
1822   db func a_string a_string
1823   execsql {
1824     PRAGMA page_size = 1024;
1825     CREATE TABLE t1(x);
1826     INSERT INTO t1 VALUES(a_string(800));
1827     INSERT INTO t1 VALUES(a_string(800));
1828   }
1830   set root [db one "SELECT rootpage FROM sqlite_master"]
1831   db close
1833   hexio_write test.db [expr ($root-1)*1024 + 8] 00000000
1834   sqlite3 db test.db
1835   catchsql { SELECT length(x) FROM t1 }
1836 } {1 {database disk image is malformed}}
1838 do_test pager1-19.1 {
1839   sqlite3 db ""
1840   db func a_string a_string
1841   execsql {
1842     PRAGMA page_size = 512;
1843     PRAGMA auto_vacuum = 1;
1844     CREATE TABLE t1(aa, ab, ac, ad, ae, af, ag, ah, ai, aj, ak, al, am, an,
1845                     ba, bb, bc, bd, be, bf, bg, bh, bi, bj, bk, bl, bm, bn,
1846                     ca, cb, cc, cd, ce, cf, cg, ch, ci, cj, ck, cl, cm, cn,
1847                     da, db, dc, dd, de, df, dg, dh, di, dj, dk, dl, dm, dn,
1848                     ea, eb, ec, ed, ee, ef, eg, eh, ei, ej, ek, el, em, en,
1849                     fa, fb, fc, fd, fe, ff, fg, fh, fi, fj, fk, fl, fm, fn,
1850                     ga, gb, gc, gd, ge, gf, gg, gh, gi, gj, gk, gl, gm, gn,
1851                     ha, hb, hc, hd, he, hf, hg, hh, hi, hj, hk, hl, hm, hn,
1852                     ia, ib, ic, id, ie, if, ig, ih, ii, ij, ik, il, im, ix,
1853                     ja, jb, jc, jd, je, jf, jg, jh, ji, jj, jk, jl, jm, jn,
1854                     ka, kb, kc, kd, ke, kf, kg, kh, ki, kj, kk, kl, km, kn,
1855                     la, lb, lc, ld, le, lf, lg, lh, li, lj, lk, ll, lm, ln,
1856                     ma, mb, mc, md, me, mf, mg, mh, mi, mj, mk, ml, mm, mn
1857     );
1858     CREATE TABLE t2(aa, ab, ac, ad, ae, af, ag, ah, ai, aj, ak, al, am, an,
1859                     ba, bb, bc, bd, be, bf, bg, bh, bi, bj, bk, bl, bm, bn,
1860                     ca, cb, cc, cd, ce, cf, cg, ch, ci, cj, ck, cl, cm, cn,
1861                     da, db, dc, dd, de, df, dg, dh, di, dj, dk, dl, dm, dn,
1862                     ea, eb, ec, ed, ee, ef, eg, eh, ei, ej, ek, el, em, en,
1863                     fa, fb, fc, fd, fe, ff, fg, fh, fi, fj, fk, fl, fm, fn,
1864                     ga, gb, gc, gd, ge, gf, gg, gh, gi, gj, gk, gl, gm, gn,
1865                     ha, hb, hc, hd, he, hf, hg, hh, hi, hj, hk, hl, hm, hn,
1866                     ia, ib, ic, id, ie, if, ig, ih, ii, ij, ik, il, im, ix,
1867                     ja, jb, jc, jd, je, jf, jg, jh, ji, jj, jk, jl, jm, jn,
1868                     ka, kb, kc, kd, ke, kf, kg, kh, ki, kj, kk, kl, km, kn,
1869                     la, lb, lc, ld, le, lf, lg, lh, li, lj, lk, ll, lm, ln,
1870                     ma, mb, mc, md, me, mf, mg, mh, mi, mj, mk, ml, mm, mn
1871     );
1872     INSERT INTO t1(aa) VALUES( a_string(100000) );
1873     INSERT INTO t2(aa) VALUES( a_string(100000) );
1874     VACUUM;
1875   }
1876 } {}
1878 #-------------------------------------------------------------------------
1879 # Test a couple of special cases that come up while committing 
1880 # transactions:
1882 #   pager1-20.1.*: Committing an in-memory database transaction when the 
1883 #                  database has not been modified at all.
1885 #   pager1-20.2.*: As above, but with a normal db in exclusive-locking mode.
1887 #   pager1-20.3.*: Committing a transaction in WAL mode where the database has
1888 #                  been modified, but all dirty pages have been flushed to 
1889 #                  disk before the commit.
1891 do_test pager1-20.1.1 {
1892   catch {db close}
1893   sqlite3 db :memory:
1894   execsql {
1895     CREATE TABLE one(two, three);
1896     INSERT INTO one VALUES('a', 'b');
1897   }
1898 } {}
1899 do_test pager1-20.1.2 {
1900   execsql {
1901     BEGIN EXCLUSIVE;
1902     COMMIT;
1903   }
1904 } {}
1906 do_test pager1-20.2.1 {
1907   faultsim_delete_and_reopen
1908   execsql {
1909     PRAGMA locking_mode = exclusive;
1910     PRAGMA journal_mode = persist;
1911     CREATE TABLE one(two, three);
1912     INSERT INTO one VALUES('a', 'b');
1913   }
1914 } {exclusive persist}
1915 do_test pager1-20.2.2 {
1916   execsql {
1917     BEGIN EXCLUSIVE;
1918     COMMIT;
1919   }
1920 } {}
1922 ifcapable wal {
1923   do_test pager1-20.3.1 {
1924     faultsim_delete_and_reopen
1925     db func a_string a_string
1926     execsql {
1927       PRAGMA cache_size = 10;
1928       PRAGMA journal_mode = wal;
1929       BEGIN;
1930         CREATE TABLE t1(x);
1931         CREATE TABLE t2(y);
1932         INSERT INTO t1 VALUES(a_string(800));
1933         INSERT INTO t1 SELECT a_string(800) FROM t1;         /*   2 */
1934         INSERT INTO t1 SELECT a_string(800) FROM t1;         /*   4 */
1935         INSERT INTO t1 SELECT a_string(800) FROM t1;         /*   8 */
1936         INSERT INTO t1 SELECT a_string(800) FROM t1;         /*  16 */
1937         INSERT INTO t1 SELECT a_string(800) FROM t1;         /*  32 */
1938       COMMIT;
1939     }
1940   } {wal}
1941   do_test pager1-20.3.2 {
1942     execsql {
1943       BEGIN;
1944       INSERT INTO t2 VALUES('xxxx');
1945     }
1946     recursive_select 32 t1
1947     execsql COMMIT
1948   } {}
1951 #-------------------------------------------------------------------------
1952 # Test that a WAL database may not be opened if:
1954 #   pager1-21.1.*: The VFS has an iVersion less than 2, or
1955 #   pager1-21.2.*: The VFS does not provide xShmXXX() methods.
1957 ifcapable wal {
1958   do_test pager1-21.0 {
1959     faultsim_delete_and_reopen
1960     execsql {
1961       PRAGMA journal_mode = WAL;
1962       CREATE TABLE ko(c DEFAULT 'abc', b DEFAULT 'def');
1963       INSERT INTO ko DEFAULT VALUES;
1964     }
1965   } {wal}
1966   do_test pager1-21.1 {
1967     testvfs tv -noshm 1
1968     sqlite3 db2 test.db -vfs tv
1969     catchsql { SELECT * FROM ko } db2
1970   } {1 {unable to open database file}}
1971   db2 close
1972   tv delete
1973   do_test pager1-21.2 {
1974     testvfs tv -iversion 1
1975     sqlite3 db2 test.db -vfs tv
1976     catchsql { SELECT * FROM ko } db2
1977   } {1 {unable to open database file}}
1978   db2 close
1979   tv delete
1982 #-------------------------------------------------------------------------
1983 # Test that a "PRAGMA wal_checkpoint":
1985 #   pager1-22.1.*: is a no-op on a non-WAL db, and
1986 #   pager1-22.2.*: does not cause xSync calls with a synchronous=off db.
1988 do_test pager1-22.1.1 {
1989   faultsim_delete_and_reopen
1990   execsql {
1991     CREATE TABLE ko(c DEFAULT 'abc', b DEFAULT 'def');
1992     INSERT INTO ko DEFAULT VALUES;
1993   }
1994   execsql { PRAGMA wal_checkpoint }
1995 } {0 -1 -1}
1996 do_test pager1-22.2.1 {
1997   testvfs tv -default 1
1998   tv filter xSync
1999   tv script xSyncCb
2000   proc xSyncCb {args} {incr ::synccount}
2001   set ::synccount 0
2002   sqlite3 db test.db
2003   execsql {
2004     PRAGMA synchronous = off;
2005     PRAGMA journal_mode = WAL;
2006     INSERT INTO ko DEFAULT VALUES;
2007   }
2008   execsql { PRAGMA wal_checkpoint }
2009   set synccount
2010 } {0}
2011 db close
2012 tv delete
2014 #-------------------------------------------------------------------------
2015 # Tests for changing journal mode.
2017 #   pager1-23.1.*: Test that when changing from PERSIST to DELETE mode,
2018 #                  the journal file is deleted.
2020 #   pager1-23.2.*: Same test as above, but while a shared lock is held
2021 #                  on the database file.
2023 #   pager1-23.3.*: Same test as above, but while a reserved lock is held
2024 #                  on the database file.
2026 #   pager1-23.4.*: And, for fun, while holding an exclusive lock.
2028 #   pager1-23.5.*: Try to set various different journal modes with an
2029 #                  in-memory database (only MEMORY and OFF should work).
2031 #   pager1-23.6.*: Try to set locking_mode=normal on an in-memory database
2032 #                  (doesn't work - in-memory databases always use
2033 #                  locking_mode=exclusive).
2035 do_test pager1-23.1.1 {
2036   faultsim_delete_and_reopen
2037   execsql {
2038     PRAGMA journal_mode = PERSIST;
2039     CREATE TABLE t1(a, b);
2040   }
2041   file exists test.db-journal
2042 } {1}
2043 do_test pager1-23.1.2 {
2044   execsql { PRAGMA journal_mode = DELETE }
2045   file exists test.db-journal
2046 } {0}
2048 do_test pager1-23.2.1 {
2049   execsql {
2050     PRAGMA journal_mode = PERSIST;
2051     INSERT INTO t1 VALUES('Canberra', 'ACT');
2052   }
2053   db eval { SELECT * FROM t1 } {
2054     db eval { PRAGMA journal_mode = DELETE }
2055   }
2056   execsql { PRAGMA journal_mode }
2057 } {delete}
2058 do_test pager1-23.2.2 {
2059   file exists test.db-journal
2060 } {0}
2062 do_test pager1-23.3.1 {
2063   execsql {
2064     PRAGMA journal_mode = PERSIST;
2065     INSERT INTO t1 VALUES('Darwin', 'NT');
2066     BEGIN IMMEDIATE;
2067   }
2068   db eval { PRAGMA journal_mode = DELETE }
2069   execsql { PRAGMA journal_mode }
2070 } {delete}
2071 do_test pager1-23.3.2 {
2072   file exists test.db-journal
2073 } {0}
2074 do_test pager1-23.3.3 {
2075   execsql COMMIT
2076 } {}
2078 do_test pager1-23.4.1 {
2079   execsql {
2080     PRAGMA journal_mode = PERSIST;
2081     INSERT INTO t1 VALUES('Adelaide', 'SA');
2082     BEGIN EXCLUSIVE;
2083   }
2084   db eval { PRAGMA journal_mode = DELETE }
2085   execsql { PRAGMA journal_mode }
2086 } {delete}
2087 do_test pager1-23.4.2 {
2088   file exists test.db-journal
2089 } {0}
2090 do_test pager1-23.4.3 {
2091   execsql COMMIT
2092 } {}
2094 do_test pager1-23.5.1 {
2095   faultsim_delete_and_reopen
2096   sqlite3 db :memory:
2097 } {}
2098 foreach {tn mode possible} {
2099   2  off      1
2100   3  memory   1
2101   4  persist  0
2102   5  delete   0
2103   6  wal      0
2104   7  truncate 0
2105 } {
2106   do_test pager1-23.5.$tn.1 {
2107     execsql "PRAGMA journal_mode = off"
2108     execsql "PRAGMA journal_mode = $mode"
2109   } [if $possible {list $mode} {list off}]
2110   do_test pager1-23.5.$tn.2 {
2111     execsql "PRAGMA journal_mode = memory"
2112     execsql "PRAGMA journal_mode = $mode"
2113   } [if $possible {list $mode} {list memory}]
2115 do_test pager1-23.6.1 {
2116   execsql {PRAGMA locking_mode = normal}
2117 } {exclusive}
2118 do_test pager1-23.6.2 {
2119   execsql {PRAGMA locking_mode = exclusive}
2120 } {exclusive}
2121 do_test pager1-23.6.3 {
2122   execsql {PRAGMA locking_mode}
2123 } {exclusive}
2124 do_test pager1-23.6.4 {
2125   execsql {PRAGMA main.locking_mode}
2126 } {exclusive}
2128 #-------------------------------------------------------------------------
2130 do_test pager1-24.1.1 {
2131   faultsim_delete_and_reopen
2132   db func a_string a_string
2133   execsql {
2134     PRAGMA cache_size = 10;
2135     PRAGMA auto_vacuum = FULL;
2136     CREATE TABLE x1(x, y, z, PRIMARY KEY(y, z));
2137     CREATE TABLE x2(x, y, z, PRIMARY KEY(y, z));
2138     INSERT INTO x2 VALUES(a_string(400), a_string(500), a_string(600));
2139     INSERT INTO x2 SELECT a_string(600), a_string(400), a_string(500) FROM x2;
2140     INSERT INTO x2 SELECT a_string(500), a_string(600), a_string(400) FROM x2;
2141     INSERT INTO x2 SELECT a_string(400), a_string(500), a_string(600) FROM x2;
2142     INSERT INTO x2 SELECT a_string(600), a_string(400), a_string(500) FROM x2;
2143     INSERT INTO x2 SELECT a_string(500), a_string(600), a_string(400) FROM x2;
2144     INSERT INTO x2 SELECT a_string(400), a_string(500), a_string(600) FROM x2;
2145     INSERT INTO x1 SELECT * FROM x2;
2146   }
2147 } {}
2148 do_test pager1-24.1.2 {
2149   execsql {
2150     BEGIN;
2151       DELETE FROM x1 WHERE rowid<32;
2152   }
2153   recursive_select 64 x2
2154 } {}
2155 do_test pager1-24.1.3 {
2156   execsql { 
2157       UPDATE x1 SET z = a_string(300) WHERE rowid>40;
2158     COMMIT;
2159     PRAGMA integrity_check;
2160     SELECT count(*) FROM x1;
2161   }
2162 } {ok 33}
2164 do_test pager1-24.1.4 {
2165   execsql {
2166     DELETE FROM x1;
2167     INSERT INTO x1 SELECT * FROM x2;
2168     BEGIN;
2169       DELETE FROM x1 WHERE rowid<32;
2170       UPDATE x1 SET z = a_string(299) WHERE rowid>40;
2171   }
2172   recursive_select 64 x2 {db eval COMMIT}
2173   execsql {
2174     PRAGMA integrity_check;
2175     SELECT count(*) FROM x1;
2176   }
2177 } {ok 33}
2179 do_test pager1-24.1.5 {
2180   execsql {
2181     DELETE FROM x1;
2182     INSERT INTO x1 SELECT * FROM x2;
2183   }
2184   recursive_select 64 x2 { db eval {CREATE TABLE x3(x, y, z)} }
2185   execsql { SELECT * FROM x3 }
2186 } {}
2188 #-------------------------------------------------------------------------
2190 do_test pager1-25-1 {
2191   faultsim_delete_and_reopen
2192   execsql {
2193     BEGIN;
2194       SAVEPOINT abc;
2195         CREATE TABLE t1(a, b);
2196       ROLLBACK TO abc;
2197     COMMIT;
2198   }
2199   db close
2200 } {}
2201 breakpoint
2202 do_test pager1-25-2 {
2203   faultsim_delete_and_reopen
2204   execsql {
2205     SAVEPOINT abc;
2206       CREATE TABLE t1(a, b);
2207     ROLLBACK TO abc;
2208     COMMIT;
2209   }
2210   db close
2211 } {}
2213 #-------------------------------------------------------------------------
2214 # Sector-size tests.
2216 do_test pager1-26.1 {
2217   testvfs tv -default 1
2218   tv sectorsize 4096
2219   faultsim_delete_and_reopen
2220   db func a_string a_string
2221   execsql {
2222     PRAGMA page_size = 512;
2223     CREATE TABLE tbl(a PRIMARY KEY, b UNIQUE);
2224     BEGIN;
2225       INSERT INTO tbl VALUES(a_string(25), a_string(600));
2226       INSERT INTO tbl SELECT a_string(25), a_string(600) FROM tbl;
2227       INSERT INTO tbl SELECT a_string(25), a_string(600) FROM tbl;
2228       INSERT INTO tbl SELECT a_string(25), a_string(600) FROM tbl;
2229       INSERT INTO tbl SELECT a_string(25), a_string(600) FROM tbl;
2230       INSERT INTO tbl SELECT a_string(25), a_string(600) FROM tbl;
2231       INSERT INTO tbl SELECT a_string(25), a_string(600) FROM tbl;
2232       INSERT INTO tbl SELECT a_string(25), a_string(600) FROM tbl;
2233     COMMIT;
2234   }
2235 } {}
2236 do_execsql_test pager1-26.1 {
2237   UPDATE tbl SET b = a_string(550);
2238 } {}
2239 db close
2240 tv delete
2242 #-------------------------------------------------------------------------
2244 do_test pager1.27.1 {
2245   faultsim_delete_and_reopen
2246   sqlite3_pager_refcounts db
2247   execsql {
2248     BEGIN;
2249       CREATE TABLE t1(a, b);
2250   }
2251   sqlite3_pager_refcounts db
2252   execsql COMMIT
2253 } {}
2255 #-------------------------------------------------------------------------
2256 # Test that attempting to open a write-transaction with 
2257 # locking_mode=exclusive in WAL mode fails if there are other clients on 
2258 # the same database.
2260 catch { db close }
2261 ifcapable wal {
2262   do_multiclient_test tn {
2263     do_test pager1-28.$tn.1 {
2264       sql1 { 
2265         PRAGMA journal_mode = WAL;
2266         CREATE TABLE t1(a, b);
2267         INSERT INTO t1 VALUES('a', 'b');
2268       }
2269     } {wal}
2270     do_test pager1-28.$tn.2 { sql2 { SELECT * FROM t1 } } {a b}
2272     do_test pager1-28.$tn.3 { sql1 { PRAGMA locking_mode=exclusive } } {exclusive}
2273     do_test pager1-28.$tn.4 { 
2274       csql1 { BEGIN; INSERT INTO t1 VALUES('c', 'd'); }
2275     } {1 {database is locked}}
2276     code2 { db2 close ; sqlite3 db2 test.db }
2277     do_test pager1-28.$tn.4 { 
2278       sql1 { INSERT INTO t1 VALUES('c', 'd'); COMMIT }
2279     } {}
2280   }
2283 #-------------------------------------------------------------------------
2284 # Normally, when changing from journal_mode=PERSIST to DELETE the pager
2285 # attempts to delete the journal file. However, if it cannot obtain a
2286 # RESERVED lock on the database file, this step is skipped.
2288 do_multiclient_test tn {
2289   do_test pager1-28.$tn.1 {
2290     sql1 { 
2291       PRAGMA journal_mode = PERSIST;
2292       CREATE TABLE t1(a, b);
2293       INSERT INTO t1 VALUES('a', 'b');
2294     }
2295   } {persist}
2296   do_test pager1-28.$tn.2 { file exists test.db-journal } 1
2297   do_test pager1-28.$tn.3 { sql1 { PRAGMA journal_mode = DELETE } } delete
2298   do_test pager1-28.$tn.4 { file exists test.db-journal } 0
2300   do_test pager1-28.$tn.5 {
2301     sql1 { 
2302       PRAGMA journal_mode = PERSIST;
2303       INSERT INTO t1 VALUES('c', 'd');
2304     }
2305   } {persist}
2306   do_test pager1-28.$tn.6 { file exists test.db-journal } 1
2307   do_test pager1-28.$tn.7 {
2308     sql2 { BEGIN; INSERT INTO t1 VALUES('e', 'f'); }
2309   } {}
2310   do_test pager1-28.$tn.8  { file exists test.db-journal } 1
2311   do_test pager1-28.$tn.9  { sql1 { PRAGMA journal_mode = DELETE } } delete
2312   do_test pager1-28.$tn.10 { file exists test.db-journal } 1
2314   do_test pager1-28.$tn.11 { sql2 COMMIT } {}
2315   do_test pager1-28.$tn.12 { file exists test.db-journal } 0
2317   do_test pager1-28-$tn.13 {
2318     code1 { set channel [db incrblob -readonly t1 a 2] }
2319     sql1 {
2320       PRAGMA journal_mode = PERSIST;
2321       INSERT INTO t1 VALUES('g', 'h');
2322     }
2323   } {persist}
2324   do_test pager1-28.$tn.14 { file exists test.db-journal } 1
2325   do_test pager1-28.$tn.15 {
2326     sql2 { BEGIN; INSERT INTO t1 VALUES('e', 'f'); }
2327   } {}
2328   do_test pager1-28.$tn.16 { sql1 { PRAGMA journal_mode = DELETE } } delete
2329   do_test pager1-28.$tn.17 { file exists test.db-journal } 1
2331   do_test pager1-28.$tn.17 { csql2 { COMMIT } } {1 {database is locked}}
2332   do_test pager1-28-$tn.18 { code1 { read $channel } } c
2333   do_test pager1-28-$tn.19 { code1 { close $channel } } {}
2334   do_test pager1-28.$tn.20 { sql2 { COMMIT } } {}
2337 do_test pager1-29.1 {
2338   faultsim_delete_and_reopen
2339   execsql {
2340     PRAGMA page_size = 1024;
2341     PRAGMA auto_vacuum = full;
2342     PRAGMA locking_mode=exclusive;
2343     CREATE TABLE t1(a, b);
2344     INSERT INTO t1 VALUES(1, 2);
2345   }
2346   file size test.db
2347 } [expr 1024*3]
2348 do_test pager1-29.2 {
2349   execsql {
2350     PRAGMA page_size = 4096;
2351     VACUUM;
2352   }
2353   file size test.db
2354 } [expr 4096*3]
2356 #-------------------------------------------------------------------------
2357 # Test that if an empty database file (size 0 bytes) is opened in 
2358 # exclusive-locking mode, any journal file is deleted from the file-system
2359 # without being rolled back. And that the RESERVED lock obtained while
2360 # doing this is not released.
2362 do_test pager1-30.1 {
2363   db close
2364   file delete test.db
2365   file delete test.db-journal
2366   set fd [open test.db-journal w]
2367   seek $fd [expr 512+1032*2]
2368   puts -nonewline $fd x
2369   close $fd
2371   sqlite3 db test.db
2372   execsql {
2373     PRAGMA locking_mode=EXCLUSIVE;
2374     SELECT count(*) FROM sqlite_master;
2375     PRAGMA lock_status;
2376   }
2377 } {exclusive 0 main reserved temp closed}
2379 #-------------------------------------------------------------------------
2380 # Test that if the "page-size" field in a journal-header is 0, the journal
2381 # file can still be rolled back. This is required for backward compatibility -
2382 # versions of SQLite prior to 3.5.8 always set this field to zero.
2384 do_test pager1-31.1 {
2385   faultsim_delete_and_reopen
2386   execsql {
2387     PRAGMA cache_size = 10;
2388     PRAGMA page_size = 1024;
2389     CREATE TABLE t1(x, y, UNIQUE(x, y));
2390     INSERT INTO t1 VALUES(randomblob(1500), randomblob(1500));
2391     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2392     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2393     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2394     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2395     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2396     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2397     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2398     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2399     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2400     INSERT INTO t1 SELECT randomblob(1500), randomblob(1500) FROM t1;
2401     BEGIN;
2402       UPDATE t1 SET y = randomblob(1499);
2403   }
2404   file copy test.db test.db2
2405   file copy test.db-journal test.db2-journal
2406   
2407   hexio_write test.db2-journal 24 00000000
2408   sqlite3 db2 test.db2
2409   execsql { PRAGMA integrity_check } db2
2410 } {ok}
2414 finish_test