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

📄 server1.test

📁 sqlite-3.4.1,嵌入式数据库.是一个功能强大的开源数据库,给学习和研发以及小型公司的发展带来了全所未有的好处.
💻 TEST
字号:
# 2006 January 09## 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 testing the server mode of SQLite.## This file is derived from thread1.test## $Id: server1.test,v 1.4 2006/01/15 00:13:16 drh Exp $set testdir [file dirname $argv0]source $testdir/tester.tcl# Skip this whole file if the server testing code is not enabled#if {[llength [info command client_step]]==0 || [sqlite3 -has-codec]} {  finish_test  return}# The sample server implementation does not work right when memory# management is enabled.#ifcapable memorymanage {  finish_test  return}# Create some data to work with#do_test server1-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#do_test server1-1.2 {  client_create A test.db  client_create B test.db  client_create C test.db  client_compile A {SELECT a FROM t1}  client_step A  client_result A} SQLITE_ROWdo_test server1-1.3 {  client_argc A} 1do_test server1-1.4 {  client_argv A 0} 1do_test server1-1.5 {  client_compile B {SELECT b FROM t1}  client_step B  client_result B} SQLITE_ROWdo_test server1-1.6 {  client_argc B} 1do_test server1-1.7 {  client_argv B 0} abcdefghdo_test server1-1.8 {  client_finalize A  client_result A} SQLITE_OKdo_test server1-1.9 {  client_finalize B  client_result B} SQLITE_OKdo_test server1-1.10 {  client_compile C {CREATE TABLE t2(x,y)}  client_step C  client_result C} SQLITE_DONEdo_test server1-1.11 {  client_finalize C  client_result C} SQLITE_OKdo_test server1-1.12 {  catchsql {SELECT name FROM sqlite_master}  execsql {SELECT name FROM sqlite_master}} {t1 t2}# Read from table t1.  Do not finalize the statement.  This# will leave the lock pending.#do_test server1-2.1 {  client_halt *  client_create A test.db  client_compile A {SELECT a FROM t1}  client_step A  client_result A} SQLITE_ROW# Read from the same table from another thread.  This is allows.#do_test server1-2.2 {  client_create B test.db  client_compile B {SELECT b FROM t1}  client_step B  client_result B} SQLITE_ROW# Write to a different table from another thread.  This is allowed# becaus in server mode with a shared cache we have table-level locking.#do_test server1-2.3 {  client_create C test.db  client_compile C {INSERT INTO t2 VALUES(98,99)}  client_step C  client_result C  client_finalize C  client_result C} SQLITE_OK# But we cannot insert into table t1 because threads A and B have it locked.#do_test server1-2.4 {  client_compile C {INSERT INTO t1 VALUES(98,99)}  client_step C  client_result C  client_finalize C  client_result C} SQLITE_LOCKEDdo_test server1-2.5 {  client_finalize B  client_wait B  client_compile C {INSERT INTO t1 VALUES(98,99)}  client_step C  client_result C  client_finalize C  client_result C} SQLITE_LOCKED# Insert into t1 is successful after finishing the other two threads.do_test server1-2.6 {  client_finalize A  client_wait A  client_compile C {INSERT INTO t1 VALUES(98,99)}  client_step C  client_result C  client_finalize C  client_result C} SQLITE_OKclient_halt *   finish_test

⌨️ 快捷键说明

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