pager2.test 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. # 2010 June 15
  2. #
  3. # The author disclaims copyright to this source code. In place of
  4. # a legal notice, here is a blessing:
  5. #
  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.
  9. #
  10. #***********************************************************************
  11. #
  12. set testdir [file dirname $argv0]
  13. source $testdir/tester.tcl
  14. source $testdir/lock_common.tcl
  15. source $testdir/malloc_common.tcl
  16. set otn 0
  17. testvfs tv -default 1
  18. foreach code [list {
  19. set s 512
  20. } {
  21. set s 1024
  22. set sql { PRAGMA journal_mode = memory }
  23. } {
  24. set s 1024
  25. set sql {
  26. PRAGMA journal_mode = memory;
  27. PRAGMA locking_mode = exclusive;
  28. }
  29. } {
  30. set s 2048
  31. tv devchar safe_append
  32. } {
  33. set s 4096
  34. } {
  35. set s 4096
  36. set sql { PRAGMA journal_mode = WAL }
  37. } {
  38. set s 4096
  39. set sql { PRAGMA auto_vacuum = 1 }
  40. } {
  41. set s 8192
  42. set sql { PRAGMA synchronous = off }
  43. }] {
  44. incr otn
  45. set sql ""
  46. tv devchar {}
  47. eval $code
  48. tv sectorsize $s
  49. do_test pager2-1.$otn.0 {
  50. faultsim_delete_and_reopen
  51. execsql $sql
  52. execsql {
  53. PRAGMA cache_size = 10;
  54. CREATE TABLE t1(i INTEGER PRIMARY KEY, j blob);
  55. }
  56. } {}
  57. set tn 0
  58. set lowpoint 0
  59. foreach x {
  60. 100 x 0 100
  61. x
  62. 70 22 96 59 96 50 22 56 21 16 37 64 43 40 0 38 22 38 55 0 6
  63. 43 62 32 93 54 18 13 29 45 66 29 25 61 31 53 82 75 25 96 86 10 69
  64. 2 29 6 60 80 95 42 82 85 50 68 96 90 39 78 69 87 97 48 74 65 43
  65. x
  66. 86 34 26 50 41 85 58 44 89 22 6 51 45 46 58 32 97 6 1 12 32 2
  67. 69 39 48 71 33 31 5 58 90 43 24 54 12 9 18 57 4 38 91 42 27 45
  68. 50 38 56 29 10 0 26 37 83 1 78 15 47 30 75 62 46 29 68 5 30 4
  69. 27 96 33 95 79 75 56 10 29 70 32 75 52 88 5 36 50 57 46 63 88 65
  70. x
  71. 44 95 64 20 24 35 69 61 61 2 35 92 42 46 23 98 78 1 38 72 79 35
  72. 94 37 13 59 5 93 27 58 80 75 58 7 67 13 10 76 84 4 8 70 81 45
  73. 8 41 98 5 60 26 92 29 91 90 2 62 40 4 5 22 80 15 83 76 52 88
  74. 29 5 68 73 72 7 54 17 89 32 81 94 51 28 53 71 8 42 54 59 70 79
  75. x
  76. } {
  77. incr tn
  78. set now [db one {SELECT count(i) FROM t1}]
  79. if {$x == "x"} {
  80. execsql { COMMIT ; BEGIN }
  81. set lowpoint $now
  82. do_test pager2.1.$otn.$tn {
  83. sqlite3 db2 test.db
  84. execsql {
  85. SELECT COALESCE(max(i), 0) FROM t1;
  86. PRAGMA integrity_check;
  87. }
  88. } [list $lowpoint ok]
  89. db2 close
  90. } else {
  91. if {$now > $x } {
  92. if { $x>=$lowpoint } {
  93. execsql "ROLLBACK TO sp_$x"
  94. } else {
  95. execsql "DELETE FROM t1 WHERE i>$x"
  96. set lowpoint $x
  97. }
  98. } elseif {$now < $x} {
  99. for {set k $now} {$k < $x} {incr k} {
  100. execsql "SAVEPOINT sp_$k"
  101. execsql { INSERT INTO t1(j) VALUES(randomblob(1500)) }
  102. }
  103. }
  104. do_execsql_test pager2.1.$otn.$tn {
  105. SELECT COALESCE(max(i), 0) FROM t1;
  106. PRAGMA integrity_check;
  107. } [list $x ok]
  108. }
  109. }
  110. }
  111. db close
  112. tv delete
  113. #-------------------------------------------------------------------------
  114. # pager2-2.1: Test a ROLLBACK with journal_mode=off.
  115. # pager2-2.2: Test shrinking the database (auto-vacuum) with
  116. # journal_mode=off
  117. #
  118. do_test pager2-2.1 {
  119. faultsim_delete_and_reopen
  120. execsql {
  121. CREATE TABLE t1(a, b);
  122. PRAGMA journal_mode = off;
  123. BEGIN;
  124. INSERT INTO t1 VALUES(1, 2);
  125. ROLLBACK;
  126. SELECT * FROM t1;
  127. }
  128. } {off}
  129. do_test pager2-2.2 {
  130. faultsim_delete_and_reopen
  131. execsql {
  132. PRAGMA auto_vacuum = incremental;
  133. PRAGMA page_size = 1024;
  134. PRAGMA journal_mode = off;
  135. CREATE TABLE t1(a, b);
  136. INSERT INTO t1 VALUES(zeroblob(5000), zeroblob(5000));
  137. DELETE FROM t1;
  138. PRAGMA incremental_vacuum;
  139. }
  140. file size test.db
  141. } {3072}
  142. #-------------------------------------------------------------------------
  143. # Test that shared in-memory databases seem to work.
  144. #
  145. db close
  146. do_test pager2-3.1 {
  147. forcedelete test.db
  148. sqlite3_shutdown
  149. sqlite3_config_uri 1
  150. sqlite3 db1 {file:test.db?mode=memory&cache=shared}
  151. sqlite3 db2 {file:test.db?mode=memory&cache=shared}
  152. sqlite3 db3 test.db
  153. db1 eval { CREATE TABLE t1(a, b) }
  154. db2 eval { INSERT INTO t1 VALUES(1, 2) }
  155. list [catch { db3 eval { INSERT INTO t1 VALUES(3, 4) } } msg] $msg
  156. } {1 {no such table: t1}}
  157. finish_test