⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 thread1.test

📁 sqlite-3.4.1,嵌入式数据库.是一个功能强大的开源数据库,给学习和研发以及小型公司的发展带来了全所未有的好处.
💻 TEST
字号:
# 2003 December 18## The author disclaims copyright to this source code.  In place of# a legal notice, here is a blessing:##    May you do good and not evil.#    May you find forgiveness for yourself and forgive others.#    May you share freely, never taking more than you give.##***********************************************************************# This file implements regression tests for SQLite library.  The# focus of this script is multithreading behavior## $Id: thread1.test,v 1.7 2004/06/19 00:16:31 drh Exp $set testdir [file dirname $argv0]source $testdir/tester.tcl# Skip this whole file if the thread testing code is not enabled#if {[llength [info command thread_step]]==0 || [sqlite3 -has-codec]} {  finish_test  return}# Create some data to work with#do_test thread1-1.1 {  execsql {    CREATE TABLE t1(a,b);    INSERT INTO t1 VALUES(1,'abcdefgh');    INSERT INTO t1 SELECT a+1, b||b FROM t1;    INSERT INTO t1 SELECT a+2, b||b FROM t1;    INSERT INTO t1 SELECT a+4, b||b FROM t1;    SELECT count(*), max(length(b)) FROM t1;  }} {8 64}# Interleave two threads on read access.  Then make sure a third# thread can write the database.  In other words:##    read-lock A#    read-lock B#    unlock A#    unlock B#    write-lock C## At one point, the write-lock of C would fail on Linux. #do_test thread1-1.2 {  thread_create A test.db  thread_create B test.db  thread_create C test.db  thread_compile A {SELECT a FROM t1}  thread_step A  thread_result A} SQLITE_ROWdo_test thread1-1.3 {  thread_argc A} 1do_test thread1-1.4 {  thread_argv A 0} 1do_test thread1-1.5 {  thread_compile B {SELECT b FROM t1}  thread_step B  thread_result B} SQLITE_ROWdo_test thread1-1.6 {  thread_argc B} 1do_test thread1-1.7 {  thread_argv B 0} abcdefghdo_test thread1-1.8 {  thread_finalize A  thread_result A} SQLITE_OKdo_test thread1-1.9 {  thread_finalize B  thread_result B} SQLITE_OKdo_test thread1-1.10 {  thread_compile C {CREATE TABLE t2(x,y)}  thread_step C  thread_result C} SQLITE_DONEdo_test thread1-1.11 {  thread_finalize C  thread_result C} SQLITE_OKdo_test thread1-1.12 {  catchsql {SELECT name FROM sqlite_master}  execsql {SELECT name FROM sqlite_master}} {t1 t2}## The following tests - thread1-2.* - test the following scenario:## 1:  Read-lock thread A# 2:  Read-lock thread B# 3:  Attempt to write in thread C -> SQLITE_BUSY# 4:  Check db write failed from main thread.# 5:  Unlock from thread A.# 6:  Attempt to write in thread C -> SQLITE_BUSY# 7:  Check db write failed from main thread.# 8:  Unlock from thread B.# 9:  Attempt to write in thread C -> SQLITE_DONE# 10: Finalize the write from thread C# 11: Check db write succeeded from main thread.#do_test thread1-2.1 {  thread_halt *  thread_create A test.db  thread_compile A {SELECT a FROM t1}  thread_step A  thread_result A} SQLITE_ROWdo_test thread1-2.2 {  thread_create B test.db  thread_compile B {SELECT b FROM t1}  thread_step B  thread_result B} SQLITE_ROWdo_test thread1-2.3 {  thread_create C test.db  thread_compile C {INSERT INTO t2 VALUES(98,99)}  thread_step C  thread_result C  thread_finalize C  thread_result C} SQLITE_BUSYdo_test thread1-2.4 {  execsql {SELECT * FROM t2}} {}do_test thread1-2.5 {  thread_finalize A  thread_result A} SQLITE_OKdo_test thread1-2.6 {  thread_compile C {INSERT INTO t2 VALUES(98,99)}  thread_step C  thread_result C  thread_finalize C  thread_result C} SQLITE_BUSYdo_test thread1-2.7 {  execsql {SELECT * FROM t2}} {}do_test thread1-2.8 {  thread_finalize B  thread_result B} SQLITE_OKdo_test thread1-2.9 {  thread_compile C {INSERT INTO t2 VALUES(98,99)}  thread_step C  thread_result C} SQLITE_DONEdo_test thread1-2.10 {  thread_finalize C  thread_result C} SQLITE_OKdo_test thread1-2.11 {  execsql {SELECT * FROM t2}} {98 99}thread_halt *   finish_test

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -