1# 2007 May 8 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# This file contains tests to verify that the limits defined in 13# sqlite source file limits.h are enforced. 14# 15# $Id: sqllimits1.test,v 1.33 2009/06/25 01:47:12 drh Exp $ 16 17set testdir [file dirname $argv0] 18source $testdir/tester.tcl 19 20# Verify that the default per-connection limits are the same as 21# the compile-time hard limits. 22# 23sqlite3 db2 :memory: 24do_test sqllimits1-1.1 { 25 sqlite3_limit db SQLITE_LIMIT_LENGTH -1 26} $SQLITE_MAX_LENGTH 27do_test sqllimits1-1.2 { 28 sqlite3_limit db SQLITE_LIMIT_SQL_LENGTH -1 29} $SQLITE_MAX_SQL_LENGTH 30do_test sqllimits1-1.3 { 31 sqlite3_limit db SQLITE_LIMIT_COLUMN -1 32} $SQLITE_MAX_COLUMN 33do_test sqllimits1-1.4 { 34 sqlite3_limit db SQLITE_LIMIT_EXPR_DEPTH -1 35} $SQLITE_MAX_EXPR_DEPTH 36do_test sqllimits1-1.5 { 37 sqlite3_limit db SQLITE_LIMIT_COMPOUND_SELECT -1 38} $SQLITE_MAX_COMPOUND_SELECT 39do_test sqllimits1-1.6 { 40 sqlite3_limit db SQLITE_LIMIT_VDBE_OP -1 41} $SQLITE_MAX_VDBE_OP 42do_test sqllimits1-1.7 { 43 sqlite3_limit db SQLITE_LIMIT_FUNCTION_ARG -1 44} $SQLITE_MAX_FUNCTION_ARG 45do_test sqllimits1-1.8 { 46 sqlite3_limit db SQLITE_LIMIT_ATTACHED -1 47} $SQLITE_MAX_ATTACHED 48do_test sqllimits1-1.9 { 49 sqlite3_limit db SQLITE_LIMIT_LIKE_PATTERN_LENGTH -1 50} $SQLITE_MAX_LIKE_PATTERN_LENGTH 51do_test sqllimits1-1.10 { 52 sqlite3_limit db SQLITE_LIMIT_VARIABLE_NUMBER -1 53} $SQLITE_MAX_VARIABLE_NUMBER 54do_test sqllimits1-1.11 { 55 sqlite3_limit db SQLITE_LIMIT_TRIGGER_DEPTH -1 56} $SQLITE_MAX_TRIGGER_DEPTH 57do_test sqllimits1-1.12 { 58 sqlite3_limit db SQLITE_LIMIT_WORKER_THREADS 99999 59 sqlite3_limit db SQLITE_LIMIT_WORKER_THREADS -1 60} $SQLITE_MAX_WORKER_THREADS 61 62# Limit parameters out of range. 63# 64do_test sqllimits1-1.20 { 65 sqlite3_limit db SQLITE_LIMIT_TOOSMALL 123 66} {-1} 67do_test sqllimits1-1.21 { 68 sqlite3_limit db SQLITE_LIMIT_TOOSMALL 123 69} {-1} 70do_test sqllimits1-1.22 { 71 sqlite3_limit db SQLITE_LIMIT_TOOBIG 123 72} {-1} 73do_test sqllimits1-1.23 { 74 sqlite3_limit db SQLITE_LIMIT_TOOBIG 123 75} {-1} 76 77 78# Decrease all limits by half. Verify that the new limits take. 79# 80if {$SQLITE_MAX_LENGTH>=2} { 81 do_test sqllimits1-2.1.1 { 82 sqlite3_limit db SQLITE_LIMIT_LENGTH \ 83 [expr {$::SQLITE_MAX_LENGTH/2}] 84 } $SQLITE_MAX_LENGTH 85 do_test sqllimits1-2.1.2 { 86 sqlite3_limit db SQLITE_LIMIT_LENGTH -1 87 } [expr {$SQLITE_MAX_LENGTH/2}] 88} 89if {$SQLITE_MAX_SQL_LENGTH>=2} { 90 do_test sqllimits1-2.2.1 { 91 sqlite3_limit db SQLITE_LIMIT_SQL_LENGTH \ 92 [expr {$::SQLITE_MAX_SQL_LENGTH/2}] 93 } $SQLITE_MAX_SQL_LENGTH 94 do_test sqllimits1-2.2.2 { 95 sqlite3_limit db SQLITE_LIMIT_SQL_LENGTH -1 96 } [expr {$SQLITE_MAX_SQL_LENGTH/2}] 97} 98if {$SQLITE_MAX_COLUMN>=2} { 99 do_test sqllimits1-2.3.1 { 100 sqlite3_limit db SQLITE_LIMIT_COLUMN \ 101 [expr {$::SQLITE_MAX_COLUMN/2}] 102 } $SQLITE_MAX_COLUMN 103 do_test sqllimits1-2.3.2 { 104 sqlite3_limit db SQLITE_LIMIT_COLUMN -1 105 } [expr {$SQLITE_MAX_COLUMN/2}] 106} 107if {$SQLITE_MAX_EXPR_DEPTH>=2} { 108 do_test sqllimits1-2.4.1 { 109 sqlite3_limit db SQLITE_LIMIT_EXPR_DEPTH \ 110 [expr {$::SQLITE_MAX_EXPR_DEPTH/2}] 111 } $SQLITE_MAX_EXPR_DEPTH 112 do_test sqllimits1-2.4.2 { 113 sqlite3_limit db SQLITE_LIMIT_EXPR_DEPTH -1 114 } [expr {$SQLITE_MAX_EXPR_DEPTH/2}] 115} 116if {$SQLITE_MAX_COMPOUND_SELECT>=2} { 117 do_test sqllimits1-2.5.1 { 118 sqlite3_limit db SQLITE_LIMIT_COMPOUND_SELECT \ 119 [expr {$::SQLITE_MAX_COMPOUND_SELECT/2}] 120 } $SQLITE_MAX_COMPOUND_SELECT 121 do_test sqllimits1-2.5.2 { 122 sqlite3_limit db SQLITE_LIMIT_COMPOUND_SELECT -1 123 } [expr {$SQLITE_MAX_COMPOUND_SELECT/2}] 124} 125if {$SQLITE_MAX_VDBE_OP>=2} { 126 do_test sqllimits1-2.6.1 { 127 sqlite3_limit db SQLITE_LIMIT_VDBE_OP \ 128 [expr {$::SQLITE_MAX_VDBE_OP/2}] 129 } $SQLITE_MAX_VDBE_OP 130 do_test sqllimits1-2.6.2 { 131 sqlite3_limit db SQLITE_LIMIT_VDBE_OP -1 132 } [expr {$SQLITE_MAX_VDBE_OP/2}] 133} 134if {$SQLITE_MAX_FUNCTION_ARG>=2} { 135 do_test sqllimits1-2.7.1 { 136 sqlite3_limit db SQLITE_LIMIT_FUNCTION_ARG \ 137 [expr {$::SQLITE_MAX_FUNCTION_ARG/2}] 138 } $SQLITE_MAX_FUNCTION_ARG 139 do_test sqllimits1-2.7.2 { 140 sqlite3_limit db SQLITE_LIMIT_FUNCTION_ARG -1 141 } [expr {$SQLITE_MAX_FUNCTION_ARG/2}] 142} 143if {$SQLITE_MAX_ATTACHED>=2} { 144 do_test sqllimits1-2.8.1 { 145 sqlite3_limit db SQLITE_LIMIT_ATTACHED \ 146 [expr {$::SQLITE_MAX_ATTACHED/2}] 147 } $SQLITE_MAX_ATTACHED 148 do_test sqllimits1-2.8.2 { 149 sqlite3_limit db SQLITE_LIMIT_ATTACHED -1 150 } [expr {$SQLITE_MAX_ATTACHED/2}] 151} 152if {$SQLITE_MAX_LIKE_PATTERN_LENGTH>=2} { 153 do_test sqllimits1-2.9.1 { 154 sqlite3_limit db SQLITE_LIMIT_LIKE_PATTERN_LENGTH \ 155 [expr {$::SQLITE_MAX_LIKE_PATTERN_LENGTH/2}] 156 } $SQLITE_MAX_LIKE_PATTERN_LENGTH 157 do_test sqllimits1-2.9.2 { 158 sqlite3_limit db SQLITE_LIMIT_LIKE_PATTERN_LENGTH -1 159 } [expr {$SQLITE_MAX_LIKE_PATTERN_LENGTH/2}] 160} 161if {$SQLITE_MAX_VARIABLE_NUMBER>=2} { 162 do_test sqllimits1-2.10.1 { 163 sqlite3_limit db SQLITE_LIMIT_VARIABLE_NUMBER \ 164 [expr {$::SQLITE_MAX_VARIABLE_NUMBER/2}] 165 } $SQLITE_MAX_VARIABLE_NUMBER 166 do_test sqllimits1-2.10.2 { 167 sqlite3_limit db SQLITE_LIMIT_VARIABLE_NUMBER -1 168 } [expr {$SQLITE_MAX_VARIABLE_NUMBER/2}] 169} 170 171# In a separate database connection, verify that the limits are unchanged. 172# 173do_test sqllimits1-3.1 { 174 sqlite3_limit db2 SQLITE_LIMIT_LENGTH -1 175} $SQLITE_MAX_LENGTH 176do_test sqllimits1-3.2 { 177 sqlite3_limit db2 SQLITE_LIMIT_SQL_LENGTH -1 178} $SQLITE_MAX_SQL_LENGTH 179do_test sqllimits1-3.3 { 180 sqlite3_limit db2 SQLITE_LIMIT_COLUMN -1 181} $SQLITE_MAX_COLUMN 182do_test sqllimits1-3.4 { 183 sqlite3_limit db2 SQLITE_LIMIT_EXPR_DEPTH -1 184} $SQLITE_MAX_EXPR_DEPTH 185do_test sqllimits1-3.5 { 186 sqlite3_limit db2 SQLITE_LIMIT_COMPOUND_SELECT -1 187} $SQLITE_MAX_COMPOUND_SELECT 188do_test sqllimits1-3.6 { 189 sqlite3_limit db2 SQLITE_LIMIT_VDBE_OP -1 190} $SQLITE_MAX_VDBE_OP 191do_test sqllimits1-3.7 { 192 sqlite3_limit db2 SQLITE_LIMIT_FUNCTION_ARG -1 193} $SQLITE_MAX_FUNCTION_ARG 194do_test sqllimits1-3.8 { 195 sqlite3_limit db2 SQLITE_LIMIT_ATTACHED -1 196} $SQLITE_MAX_ATTACHED 197do_test sqllimits1-3.9 { 198 sqlite3_limit db2 SQLITE_LIMIT_LIKE_PATTERN_LENGTH -1 199} $SQLITE_MAX_LIKE_PATTERN_LENGTH 200do_test sqllimits1-3.10 { 201 sqlite3_limit db2 SQLITE_LIMIT_VARIABLE_NUMBER -1 202} $SQLITE_MAX_VARIABLE_NUMBER 203db2 close 204 205# Attempt to set all limits to the maximum 32-bit integer. Verify 206# that the limit does not exceed the compile-time upper bound. 207# 208do_test sqllimits1-4.1.1 { 209 sqlite3_limit db SQLITE_LIMIT_LENGTH 0x7fffffff 210 sqlite3_limit db SQLITE_LIMIT_LENGTH -1 211} $SQLITE_MAX_LENGTH 212do_test sqllimits1-4.2.1 { 213 sqlite3_limit db SQLITE_LIMIT_SQL_LENGTH 0x7fffffff 214 sqlite3_limit db SQLITE_LIMIT_SQL_LENGTH -1 215} $SQLITE_MAX_SQL_LENGTH 216do_test sqllimits1-4.3.1 { 217 sqlite3_limit db SQLITE_LIMIT_COLUMN 0x7fffffff 218 sqlite3_limit db SQLITE_LIMIT_COLUMN -1 219} $SQLITE_MAX_COLUMN 220do_test sqllimits1-4.4.1 { 221 sqlite3_limit db SQLITE_LIMIT_EXPR_DEPTH 0x7fffffff 222 sqlite3_limit db SQLITE_LIMIT_EXPR_DEPTH -1 223} $SQLITE_MAX_EXPR_DEPTH 224do_test sqllimits1-4.5.1 { 225 sqlite3_limit db SQLITE_LIMIT_COMPOUND_SELECT 0x7fffffff 226 sqlite3_limit db SQLITE_LIMIT_COMPOUND_SELECT -1 227} $SQLITE_MAX_COMPOUND_SELECT 228do_test sqllimits1-4.6.1 { 229 sqlite3_limit db SQLITE_LIMIT_VDBE_OP 0x7fffffff 230 sqlite3_limit db SQLITE_LIMIT_VDBE_OP -1 231} $SQLITE_MAX_VDBE_OP 232do_test sqllimits1-4.7.1 { 233 sqlite3_limit db SQLITE_LIMIT_FUNCTION_ARG 0x7fffffff 234 sqlite3_limit db SQLITE_LIMIT_FUNCTION_ARG -1 235} $SQLITE_MAX_FUNCTION_ARG 236do_test sqllimits1-4.8.1 { 237 sqlite3_limit db SQLITE_LIMIT_ATTACHED 0x7fffffff 238 sqlite3_limit db SQLITE_LIMIT_ATTACHED -1 239} $SQLITE_MAX_ATTACHED 240do_test sqllimits1-4.9.1 { 241 sqlite3_limit db SQLITE_LIMIT_LIKE_PATTERN_LENGTH 0x7fffffff 242 sqlite3_limit db SQLITE_LIMIT_LIKE_PATTERN_LENGTH -1 243} $SQLITE_MAX_LIKE_PATTERN_LENGTH 244do_test sqllimits1-4.10.1 { 245 sqlite3_limit db SQLITE_LIMIT_VARIABLE_NUMBER 0x7fffffff 246 sqlite3_limit db SQLITE_LIMIT_VARIABLE_NUMBER -1 247} $SQLITE_MAX_VARIABLE_NUMBER 248 249#-------------------------------------------------------------------- 250# Test cases sqllimits1-5.* test that the SQLITE_MAX_LENGTH limit 251# is enforced. 252# 253# EVIDENCE-OF: R-61987-00541 SQLITE_LIMIT_LENGTH The maximum size of any 254# string or BLOB or table row, in bytes. 255# 256db close 257sqlite3 db test.db 258set LARGESIZE 99999 259set SQLITE_LIMIT_LENGTH 100000 260sqlite3_limit db SQLITE_LIMIT_LENGTH $SQLITE_LIMIT_LENGTH 261 262do_test sqllimits1-5.1.1 { 263 catchsql { SELECT randomblob(2147483647) } 264} {1 {string or blob too big}} 265do_test sqllimits1-5.1.2 { 266 catchsql { SELECT zeroblob(2147483647) } 267} {1 {string or blob too big}} 268 269do_test sqllimits1-5.2 { 270 catchsql { SELECT LENGTH(randomblob($::LARGESIZE)) } 271} [list 0 $LARGESIZE] 272 273do_test sqllimits1-5.3 { 274 catchsql { SELECT quote(randomblob($::LARGESIZE)) } 275} {1 {string or blob too big}} 276 277do_test sqllimits1-5.4 { 278 catchsql { SELECT LENGTH(zeroblob($::LARGESIZE)) } 279} [list 0 $LARGESIZE] 280 281do_test sqllimits1-5.5 { 282 catchsql { SELECT quote(zeroblob($::LARGESIZE)) } 283} {1 {string or blob too big}} 284 285do_test sqllimits1-5.6 { 286 catchsql { SELECT zeroblob(-1) } 287} {0 {{}}} 288 289do_test sqllimits1-5.9 { 290 set ::str [string repeat A 65537] 291 set ::rep [string repeat B 65537] 292 catchsql { SELECT replace($::str, 'A', $::rep) } 293} {1 {string or blob too big}} 294 295do_test sqllimits1-5.10 { 296 # Prior to 3.37.0 strftime() allocated a large static buffer into 297 # which to format its output. Using that strategy, 2100 repeats was 298 # enough to exceed 100KiB and provoke the error. As of 3.37.0 strftime() 299 # uses the StrAccum functions, so it requires 12100 to fail. 300 # 301 # set ::str [string repeat %J 2100] 302 set ::str [string repeat %J 12100] 303 catchsql { SELECT length(strftime($::str, '2003-10-31')) } 304} {1 {string or blob too big}} 305 306do_test sqllimits1-5.11 { 307 set ::str1 [string repeat A [expr {$SQLITE_LIMIT_LENGTH - 10}]] 308 set ::str2 [string repeat B [expr {$SQLITE_LIMIT_LENGTH - 10}]] 309 catchsql { SELECT $::str1 || $::str2 } 310} {1 {string or blob too big}} 311 312do_test sqllimits1-5.12 { 313 set ::str1 [string repeat ' [expr {$SQLITE_LIMIT_LENGTH - 10}]] 314 catchsql { SELECT quote($::str1) } 315} {1 {string or blob too big}} 316 317do_test sqllimits1-5.13 { 318 set ::str1 [string repeat ' [expr {$SQLITE_LIMIT_LENGTH - 10}]] 319 catchsql { SELECT hex($::str1) } 320} {1 {string or blob too big}} 321 322do_test sqllimits1-5.14.1 { 323 set ::STMT [sqlite3_prepare db "SELECT ?" -1 TAIL] 324 sqlite3_bind_zeroblob $::STMT 1 [expr {$SQLITE_LIMIT_LENGTH + 1}] 325} {} 326do_test sqllimits1-5.14.2 { 327 sqlite3_step $::STMT 328} {SQLITE_ERROR} 329do_test sqllimits1-5.14.3 { 330 sqlite3_reset $::STMT 331} {SQLITE_TOOBIG} 332do_test sqllimits1-5.14.4 { 333 set np1 [expr {$SQLITE_LIMIT_LENGTH + 1}] 334 set ::str1 [string repeat A $np1] 335 catch {sqlite3_bind_text $::STMT 1 $::str1 -1} res 336 set res 337} {SQLITE_TOOBIG} 338ifcapable utf16 { 339 do_test sqllimits1-5.14.5 { 340 catch {sqlite3_bind_text16 $::STMT 1 $::str1 -1} res 341 set res 342 } {SQLITE_TOOBIG} 343} 344do_test sqllimits1-5.14.6 { 345 catch {sqlite3_bind_text $::STMT 1 $::str1 $np1} res 346 set res 347} {SQLITE_TOOBIG} 348ifcapable utf16 { 349 do_test sqllimits1-5.14.7 { 350 catch {sqlite3_bind_text16 $::STMT 1 $::str1 $np1} res 351 set res 352 } {SQLITE_TOOBIG} 353} 354do_test sqllimits1-5.14.8 { 355 set n [expr {$np1-1}] 356 catch {sqlite3_bind_text $::STMT 1 $::str1 $n} res 357 set res 358} {} 359do_test sqllimits1-5.14.9 { 360 catch {sqlite3_bind_text16 $::STMT 1 $::str1 $n} res 361 set res 362} {} 363sqlite3_finalize $::STMT 364 365do_test sqllimits1-5.15 { 366 execsql { 367 CREATE TABLE t4(x); 368 INSERT INTO t4 VALUES(1); 369 INSERT INTO t4 VALUES(2); 370 INSERT INTO t4 SELECT 2+x FROM t4; 371 } 372 catchsql { 373 SELECT group_concat(hex(randomblob(20000))) FROM t4; 374 } 375} {1 {string or blob too big}} 376db eval {DROP TABLE t4} 377 378sqlite3_limit db SQLITE_LIMIT_SQL_LENGTH 0x7fffffff 379set strvalue [string repeat A $::SQLITE_LIMIT_LENGTH] 380do_test sqllimits1-5.16 { 381 catchsql "SELECT '$strvalue' AS x" 382} [list 0 $strvalue] 383do_test sqllimits1-5.17.1 { 384 catchsql "SELECT 'A$strvalue'" 385} [list 1 {string or blob too big}] 386do_test sqllimits1-5.17.2 { 387 sqlite3_limit db SQLITE_LIMIT_LENGTH 0x7fffffff 388 catchsql {SELECT 'A' || $::strvalue} 389} [list 0 A$strvalue] 390do_test sqllimits1-5.17.3 { 391 sqlite3_limit db SQLITE_LIMIT_LENGTH $SQLITE_LIMIT_LENGTH 392 catchsql {SELECT 'A' || $::strvalue} 393} [list 1 {string or blob too big}] 394set blobvalue [string repeat 41 $::SQLITE_LIMIT_LENGTH] 395do_test sqllimits1-5.18 { 396 catchsql "SELECT x'$blobvalue' AS x" 397} [list 0 $strvalue] 398do_test sqllimits1-5.19 { 399 catchsql "SELECT '41$blobvalue'" 400} [list 1 {string or blob too big}] 401unset blobvalue 402 403ifcapable datetime { 404 set strvalue [string repeat D [expr {$SQLITE_LIMIT_LENGTH-11}]] 405 do_test sqllimits1-5.20 { 406 catchsql {SELECT strftime('%Y ' || $::strvalue, '2008-01-02')} 407 } [list 0 [list "2008 $strvalue"]] 408 do_test sqllimits1-5.21 { 409 catchsql {SELECT strftime('%Y-%m-%d ' || $::strvalue, '2008-01-02')} 410 } {1 {string or blob too big}} 411} 412unset strvalue 413 414#-------------------------------------------------------------------- 415# Test cases sqllimits1-6.* test that the SQLITE_MAX_SQL_LENGTH limit 416# is enforced. 417# 418# EVIDENCE-OF: R-09808-17554 SQLITE_LIMIT_SQL_LENGTH The maximum length 419# of an SQL statement, in bytes. 420# 421do_test sqllimits1-6.1 { 422 sqlite3_limit db SQLITE_LIMIT_SQL_LENGTH 50000 423 set sql "SELECT 1 WHERE 1==1" 424 set tail " /* A comment to take up space in order to make the string\ 425 longer without increasing the expression depth */\ 426 AND 1 == 1" 427 set N [expr {(50000 / [string length $tail])+1}] 428 append sql [string repeat $tail $N] 429 catchsql $sql 430} {1 {string or blob too big}} 431do_test sqllimits1-6.3 { 432 sqlite3_limit db SQLITE_LIMIT_SQL_LENGTH 50000 433 set sql "SELECT 1 WHERE 1==1" 434 set tail " /* A comment to take up space in order to make the string\ 435 longer without increasing the expression depth */\ 436 AND 1 == 1" 437 set N [expr {(50000 / [string length $tail])+1}] 438 append sql [string repeat $tail $N] 439 set nbytes [string length $sql] 440 append sql { AND 0} 441 set rc [catch {sqlite3_prepare db $sql $nbytes TAIL} STMT] 442 lappend rc $STMT 443} {1 {(18) statement too long}} 444do_test sqllimits1-6.4 { 445 sqlite3_errmsg db 446} {statement too long} 447 448#-------------------------------------------------------------------- 449# Test cases sqllimits1-7.* test that the limit set using the 450# max_page_count pragma. 451# 452do_test sqllimits1-7.1 { 453 execsql { 454 PRAGMA max_page_count = 1000; 455 } 456} {1000} 457do_test sqllimits1-7.2 { 458 execsql { CREATE TABLE trig (a INTEGER, b INTEGER); } 459 460 # Set up a tree of triggers to fire when a row is inserted 461 # into table "trig". 462 # 463 # INSERT -> insert_b -> update_b -> insert_a -> update_a (chain 1) 464 # -> update_a -> insert_a -> update_b (chain 2) 465 # -> insert_a -> update_b -> insert_b -> update_a (chain 3) 466 # -> update_a -> insert_b -> update_b (chain 4) 467 # 468 # Table starts with N rows. 469 # 470 # Chain 1: insert_b (update N rows) 471 # -> update_b (insert 1 rows) 472 # -> insert_a (update N rows) 473 # -> update_a (insert 1 rows) 474 # 475 # chains 2, 3 and 4 are similar. Each inserts more than N^2 rows, where 476 # N is the number of rows at the conclusion of the previous chain. 477 # 478 # Therefore, a single insert adds (N^16 plus some) rows to the database. 479 # A really long loop... 480 # 481 execsql { 482 CREATE TRIGGER update_b BEFORE UPDATE ON trig 483 FOR EACH ROW BEGIN 484 INSERT INTO trig VALUES (65, 'update_b'); 485 END; 486 487 CREATE TRIGGER update_a AFTER UPDATE ON trig 488 FOR EACH ROW BEGIN 489 INSERT INTO trig VALUES (65, 'update_a'); 490 END; 491 492 CREATE TRIGGER insert_b BEFORE INSERT ON trig 493 FOR EACH ROW BEGIN 494 UPDATE trig SET a = 1; 495 END; 496 497 CREATE TRIGGER insert_a AFTER INSERT ON trig 498 FOR EACH ROW BEGIN 499 UPDATE trig SET a = 1; 500 END; 501 } 502} {} 503 504do_test sqllimits1-7.3 { 505 execsql { 506 INSERT INTO trig VALUES (1,1); 507 } 508} {} 509 510do_test sqllimits1-7.4 { 511 execsql { 512 SELECT COUNT(*) FROM trig; 513 } 514} {7} 515 516# This tries to insert so many rows it fills up the database (limited 517# to 1MB, so not that noteworthy an achievement). 518# 519do_test sqllimits1-7.5 { 520 catchsql { 521 INSERT INTO trig VALUES (1,10); 522 } 523} {1 {database or disk is full}} 524 525do_test sqllimits1-7.6 { 526 catchsql { 527 SELECT COUNT(*) FROM trig; 528 } 529} {0 7} 530 531# Now check the response of the library to opening a file larger than 532# the current max_page_count value. The response is to change the 533# internal max_page_count value to match the actual size of the file. 534if {[db eval {PRAGMA auto_vacuum}]} { 535 set fsize 1700 536} else { 537 set fsize 1691 538} 539do_test sqllimits1-7.7.1 { 540 execsql { 541 PRAGMA max_page_count = 1000000; 542 CREATE TABLE abc(a, b, c); 543 INSERT INTO abc VALUES(1, 2, 3); 544 INSERT INTO abc SELECT a||b||c, b||c||a, c||a||b FROM abc; 545 INSERT INTO abc SELECT a||b||c, b||c||a, c||a||b FROM abc; 546 INSERT INTO abc SELECT a||b||c, b||c||a, c||a||b FROM abc; 547 INSERT INTO abc SELECT a||b||c, b||c||a, c||a||b FROM abc; 548 INSERT INTO abc SELECT a||b||c, b||c||a, c||a||b FROM abc; 549 INSERT INTO abc SELECT a||b||c, b||c||a, c||a||b FROM abc; 550 INSERT INTO abc SELECT a||b||c, b||c||a, c||a||b FROM abc; 551 INSERT INTO abc SELECT a||b||c, b||c||a, c||a||b FROM abc; 552 INSERT INTO abc SELECT a, b, c FROM abc; 553 INSERT INTO abc SELECT b, a, c FROM abc; 554 INSERT INTO abc SELECT c, b, a FROM abc; 555 } 556 expr [file size test.db] / 1024 557} $fsize 558do_test sqllimits1-7.7.2 { 559 db close 560 sqlite3 db test.db 561 execsql { 562 PRAGMA max_page_count = 1000; 563 } 564 execsql { 565 SELECT count(*) FROM sqlite_master; 566 } 567} {6} 568do_test sqllimits1-7.7.3 { 569 execsql { 570 PRAGMA max_page_count; 571 } 572} $fsize 573do_test sqllimits1-7.7.4 { 574 execsql { 575 DROP TABLE abc; 576 } 577} {} 578 579#-------------------------------------------------------------------- 580# Test cases sqllimits1-8.* test the SQLITE_MAX_COLUMN limit. 581# 582# EVIDENCE-OF: R-43996-29471 SQLITE_LIMIT_COLUMN The maximum number of 583# columns in a table definition or in the result set of a SELECT or the 584# maximum number of columns in an index or in an ORDER BY or GROUP BY 585# clause. 586# 587set SQLITE_LIMIT_COLUMN 200 588sqlite3_limit db SQLITE_LIMIT_COLUMN $SQLITE_LIMIT_COLUMN 589do_test sqllimits1-8.1 { 590 # Columns in a table. 591 set cols [list] 592 for {set i 0} {$i <= $SQLITE_LIMIT_COLUMN} {incr i} { 593 lappend cols "c$i" 594 } 595 catchsql "CREATE TABLE t([join $cols ,])" 596} {1 {too many columns on t}} 597 598do_test sqllimits1-8.2 { 599 # Columns in the result-set of a SELECT. 600 set cols [list] 601 for {set i 0} {$i <= $SQLITE_LIMIT_COLUMN} {incr i} { 602 lappend cols "sql AS sql$i" 603 } 604 catchsql "SELECT [join $cols ,] FROM sqlite_master" 605} {1 {too many columns in result set}} 606 607do_test sqllimits1-8.3 { 608 # Columns in the result-set of a sub-SELECT. 609 set cols [list] 610 for {set i 0} {$i <= $SQLITE_LIMIT_COLUMN} {incr i} { 611 lappend cols "sql AS sql$i" 612 } 613 catchsql "SELECT sql4 FROM (SELECT [join $cols ,] FROM sqlite_master)" 614} {1 {too many columns in result set}} 615 616do_test sqllimits1-8.4 { 617 # Columns in an index. 618 set cols [list] 619 for {set i 0} {$i <= $SQLITE_LIMIT_COLUMN} {incr i} { 620 lappend cols c 621 } 622 set sql1 "CREATE TABLE t1(c);" 623 set sql2 "CREATE INDEX i1 ON t1([join $cols ,]);" 624 catchsql "$sql1 ; $sql2" 625} {1 {too many columns in index}} 626 627do_test sqllimits1-8.5 { 628 # Columns in a GROUP BY clause. 629 catchsql "SELECT * FROM t1 GROUP BY [join $cols ,]" 630} {1 {too many terms in GROUP BY clause}} 631 632do_test sqllimits1-8.6 { 633 # Columns in an ORDER BY clause. 634 catchsql "SELECT * FROM t1 ORDER BY [join $cols ,]" 635} {1 {too many terms in ORDER BY clause}} 636 637do_test sqllimits1-8.7 { 638 # Assignments in an UPDATE statement. 639 set cols [list] 640 for {set i 0} {$i <= $SQLITE_LIMIT_COLUMN} {incr i} { 641 lappend cols "c = 1" 642 } 643 catchsql "UPDATE t1 SET [join $cols ,];" 644} {1 {too many columns in set list}} 645 646do_test sqllimits1-8.8 { 647 # Columns in a view definition: 648 set cols [list] 649 for {set i 0} {$i <= $SQLITE_LIMIT_COLUMN} {incr i} { 650 lappend cols "c$i" 651 } 652 execsql "CREATE VIEW v1 AS SELECT [join $cols ,] FROM t1;" 653 catchsql {SELECT * FROM v1} 654} {1 {too many columns in result set}} 655 656do_test sqllimits1-8.9 { 657 # Columns in a view definition (testing * expansion): 658 set cols [list] 659 for {set i 0} {$i < $SQLITE_LIMIT_COLUMN} {incr i} { 660 lappend cols "c$i" 661 } 662 execsql {DROP VIEW IF EXISTS v1} 663 catchsql "CREATE TABLE t2([join $cols ,])" 664 catchsql "CREATE VIEW v1 AS SELECT *, c1 AS o FROM t2;" 665 catchsql "SELECT * FROM v1" 666} {1 {too many columns in result set}} 667 668do_test sqllimits1-8.10 { 669 # ORDER BY columns 670 set cols [list] 671 for {set i 0} {$i <= $SQLITE_LIMIT_COLUMN} {incr i} { 672 lappend cols c 673 } 674 set sql "SELECT c FROM t1 ORDER BY [join $cols ,]" 675 catchsql $sql 676} {1 {too many terms in ORDER BY clause}} 677do_test sqllimits1-8.11 { 678 # ORDER BY columns 679 set cols [list] 680 for {set i 0} {$i <= $SQLITE_LIMIT_COLUMN} {incr i} { 681 lappend cols [expr {$i%3 + 1}] 682 } 683 set sql "SELECT c, c+1, c+2 FROM t1 UNION SELECT c-1, c-2, c-3 FROM t1" 684 append sql " ORDER BY [join $cols ,]" 685 catchsql $sql 686} {1 {too many terms in ORDER BY clause}} 687 688 689#-------------------------------------------------------------------- 690# These tests - sqllimits1-9.* - test that the SQLITE_LIMIT_EXPR_DEPTH 691# limit is enforced. The limit refers to the number of terms in 692# the expression. 693# 694# EVIDENCE-OF: R-12723-08526 SQLITE_LIMIT_EXPR_DEPTH The maximum depth 695# of the parse tree on any expression. 696# 697if {$SQLITE_MAX_EXPR_DEPTH==0} { 698 puts -nonewline stderr "WARNING: Compile with -DSQLITE_MAX_EXPR_DEPTH to run " 699 puts stderr "tests sqllimits1-9.X" 700} else { 701 do_test sqllimits1-9.1 { 702 set max $::SQLITE_MAX_EXPR_DEPTH 703 set expr "(1 [string repeat {AND 1 } $max])" 704 catchsql [subst { 705 SELECT $expr 706 }] 707 } "1 {Expression tree is too large (maximum depth $::SQLITE_MAX_EXPR_DEPTH)}" 708 709 # Attempting to beat the expression depth limit using nested SELECT 710 # queries causes a parser stack overflow. 711 do_test sqllimits1-9.2 { 712 set max $::SQLITE_MAX_EXPR_DEPTH 713 set expr "SELECT 1" 714 for {set i 0} {$i <= $max} {incr i} { 715 set expr "SELECT ($expr)" 716 } 717 catchsql [subst { $expr }] 718 } "1 {parser stack overflow}" 719 720if 0 { 721 do_test sqllimits1-9.3 { 722 execsql { 723 PRAGMA max_page_count = 1000000; -- 1 GB 724 CREATE TABLE v0(a); 725 INSERT INTO v0 VALUES(1); 726 } 727 db transaction { 728 for {set i 1} {$i < 200} {incr i} { 729 set expr "(a [string repeat {AND 1 } 50]) AS a" 730 execsql [subst { 731 CREATE VIEW v${i} AS SELECT $expr FROM v[expr {$i-1}] 732 }] 733 } 734 } 735 } {} 736 737 do_test sqllimits1-9.4 { 738 catchsql { 739 SELECT a FROM v199 740 } 741 } "1 {Expression tree is too large (maximum depth $::SQLITE_MAX_EXPR_DEPTH)}" 742} 743} 744 745#-------------------------------------------------------------------- 746# Test cases sqllimits1-10.* test that the SQLITE_MAX_VDBE_OP 747# limit works as expected. The limit refers to the number of opcodes 748# in a single VDBE program. 749# 750# TODO 751 752#-------------------------------------------------------------------- 753# Test the SQLITE_LIMIT_FUNCTION_ARG limit works. Test case names 754# match the pattern "sqllimits1-11.*". 755# 756# EVIDENCE-OF: R-59001-45278 SQLITE_LIMIT_FUNCTION_ARG The maximum 757# number of arguments on a function. 758# 759for {set max 5} {$max<=$SQLITE_MAX_FUNCTION_ARG} {incr max} { 760 do_test sqllimits1-11.$max.1 { 761 set vals [list] 762 sqlite3_limit db SQLITE_LIMIT_FUNCTION_ARG $::max 763 for {set i 0} {$i < $::max} {incr i} { 764 lappend vals $i 765 } 766 catchsql "SELECT max([join $vals ,])" 767 } "0 [expr {$::max - 1}]" 768 do_test sqllimits1-11.$max.2 { 769 set vals [list] 770 for {set i 0} {$i <= $::max} {incr i} { 771 lappend vals $i 772 } 773 catchsql "SELECT max([join $vals ,])" 774 } {1 {too many arguments on function max}} 775 776 # Test that it is SQLite, and not the implementation of the 777 # user function that is throwing the error. 778 proc myfunc {args} {error "I don't like to be called!"} 779 do_test sqllimits1-11.$max.2 { 780 db function myfunc myfunc 781 set vals [list] 782 for {set i 0} {$i <= $::max} {incr i} { 783 lappend vals $i 784 } 785 catchsql "SELECT myfunc([join $vals ,])" 786 } {1 {too many arguments on function myfunc}} 787} 788 789#-------------------------------------------------------------------- 790# Test cases sqllimits1-12.*: Test the SQLITE_MAX_ATTACHED limit. 791# 792# EVIDENCE-OF: R-41778-26203 SQLITE_LIMIT_ATTACHED The maximum number of 793# attached databases. 794# 795ifcapable attach { 796 do_test sqllimits1-12.1 { 797 set max $::SQLITE_MAX_ATTACHED 798 for {set i 0} {$i < ($max)} {incr i} { 799 forcedelete test${i}.db test${i}.db-journal 800 } 801 for {set i 0} {$i < ($max)} {incr i} { 802 execsql "ATTACH 'test${i}.db' AS aux${i}" 803 } 804 catchsql "ATTACH 'test${i}.db' AS aux${i}" 805 } "1 {too many attached databases - max $::SQLITE_MAX_ATTACHED}" 806 do_test sqllimits1-12.2 { 807 set max $::SQLITE_MAX_ATTACHED 808 for {set i 0} {$i < ($max)} {incr i} { 809 execsql "DETACH aux${i}" 810 } 811 } {} 812} 813 814#-------------------------------------------------------------------- 815# Test cases sqllimits1-13.*: Check that the SQLITE_MAX_VARIABLE_NUMBER 816# limit works. 817# 818# EVIDENCE-OF: R-42363-29104 SQLITE_LIMIT_VARIABLE_NUMBER The maximum 819# index number of any parameter in an SQL statement. 820# 821do_test sqllimits1-13.1 { 822 set max $::SQLITE_MAX_VARIABLE_NUMBER 823 catchsql "SELECT ?[expr {$max+1}] FROM t1" 824} "1 {variable number must be between ?1 and ?$::SQLITE_MAX_VARIABLE_NUMBER}" 825do_test sqllimits1-13.2 { 826 set max $::SQLITE_MAX_VARIABLE_NUMBER 827 set vals [list] 828 for {set i 0} {$i < ($max+3)} {incr i} { 829 lappend vals ? 830 } 831 catchsql "SELECT [join $vals ,] FROM t1" 832} "1 {too many SQL variables}" 833 834 835#-------------------------------------------------------------------- 836# Test cases sqllimits1-15.* verify that the 837# SQLITE_MAX_LIKE_PATTERN_LENGTH limit is enforced. This limit only 838# applies to the built-in LIKE operator, supplying an external 839# implementation by overriding the like() scalar function bypasses 840# this limitation. 841# 842# EVIDENCE-OF: R-12940-37052 SQLITE_LIMIT_LIKE_PATTERN_LENGTH The 843# maximum length of the pattern argument to the LIKE or GLOB operators. 844# 845# These tests check that the limit is not incorrectly applied to 846# the left-hand-side of the LIKE operator (the string being tested 847# against the pattern). 848# 849set SQLITE_LIMIT_LIKE_PATTERN 1000 850sqlite3_limit db SQLITE_LIMIT_LIKE_PATTERN_LENGTH $SQLITE_LIMIT_LIKE_PATTERN 851do_test sqllimits1-15.1 { 852 set max $::SQLITE_LIMIT_LIKE_PATTERN 853 set ::pattern [string repeat "A%" [expr $max/2]] 854 set ::string [string repeat "A" [expr {$max*2}]] 855 execsql { 856 SELECT $::string LIKE $::pattern; 857 } 858} {1} 859do_test sqllimits1-15.2 { 860 set max $::SQLITE_LIMIT_LIKE_PATTERN 861 set ::pattern [string repeat "A%" [expr {($max/2) + 1}]] 862 set ::string [string repeat "A" [expr {$max*2}]] 863 catchsql { 864 SELECT $::string LIKE $::pattern; 865 } 866} {1 {LIKE or GLOB pattern too complex}} 867 868#-------------------------------------------------------------------- 869# This test case doesn't really belong with the other limits tests. 870# It is in this file because it is taxing to run, like the limits tests. 871# 872# Update for 3.37.0: strftime() used to allocate a large static buffer 873# into which it would write its result. With that implementation, the 874# following would trigger an SQLITE_TOOBIG error. But strftime() now 875# uses the StrAccum functions, causing this test to fail. 876# 877#do_test sqllimits1-16.1 { 878# set ::N [expr int(([expr pow(2,32)]/50) + 1)] 879# expr (($::N*50) & 0xffffffff)<55 880#} {1} 881#do_test sqllimits1-16.2 { 882# set ::format "[string repeat A 60][string repeat "%J" $::N]" 883# catchsql { 884# SELECT strftime($::format, 1); 885# } 886#} {1 {string or blob too big}} 887 888do_catchsql_test sqllimits1.17.0 { 889 SELECT *,*,*,*,*,*,*,* FROM ( 890 SELECT *,*,*,*,*,*,*,* FROM ( 891 SELECT *,*,*,*,*,*,*,* FROM ( 892 SELECT *,*,*,*,*,*,*,* FROM ( 893 SELECT *,*,*,*,*,*,*,* FROM ( 894 SELECT 1,2,3,4,5,6,7,8,9,10 895 ) 896 )))) 897} "1 {too many columns in result set}" 898 899 900foreach {key value} [array get saved] { 901 catch {set $key $value} 902} 903 904#------------------------------------------------------------------------- 905# At one point the following caused an assert() to fail. 906# 907sqlite3_limit db SQLITE_LIMIT_LENGTH 10000 908set nm [string repeat x 10000] 909do_catchsql_test sqllimits1-17.1 " 910 CREATE TABLE $nm (x PRIMARY KEY) 911" {1 {string or blob too big}} 912 913#------------------------------------------------------------------------- 914# 915sqlite3_limit db SQLITE_LIMIT_COMPOUND_SELECT 10 916do_catchsql_test sqllimits1-18.1 { 917 CREATE TABLE b1(x); 918 INSERT INTO b1 VALUES(1), (2), (3), (4), (5), (6), (7), (8), (9), (10), (11); 919} {0 {}} 920 921do_catchsql_test sqllimits1-18.2 { 922 INSERT INTO b1 VALUES(1), (2), (3), (4), (5), (6), (7), (8), (9), (10) 923 UNION VALUES(11); 924} {1 {too many terms in compound SELECT}} 925 926finish_test 927