66 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # 2015-05-11
 | |
| #
 | |
| # 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.
 | |
| #
 | |
| #***********************************************************************
 | |
| #
 | |
| # Quick tests for the sqldiff tool
 | |
| #
 | |
| set testdir [file dirname $argv0]
 | |
| source $testdir/tester.tcl
 | |
| 
 | |
| if {$tcl_platform(platform)=="windows"} {
 | |
|   set PROG "sqldiff.exe"
 | |
| } else {
 | |
|   set PROG "./sqldiff"
 | |
| }
 | |
| if {![file exe $PROG]} {
 | |
|   puts "sqldiff cannot run because $PROG is not available"
 | |
|   finish_test
 | |
|   return
 | |
| }
 | |
| db close
 | |
| forcedelete test.db test2.db
 | |
| sqlite3 db test.db
 | |
| 
 | |
| do_test sqldiff-1.0 {
 | |
|   db eval {
 | |
|     CREATE TABLE t1(a INTEGER PRIMARY KEY, b);
 | |
|     CREATE TABLE t2(a INT PRIMARY KEY, b) WITHOUT ROWID;
 | |
|     WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT x+1 FROM c WHERE x<100)
 | |
|     INSERT INTO t1(a,b) SELECT x, printf('abc-%d-xyz',x) FROM c;
 | |
|     INSERT INTO t2(a,b) SELECT a, b FROM t1;
 | |
|   }
 | |
|   db backup test2.db
 | |
|   db eval {
 | |
|     ATTACH 'test2.db' AS x2;
 | |
|     DELETE FROM x2.t1 WHERE a=49;
 | |
|     DELETE FROM x2.t2 WHERE a=48;
 | |
|     INSERT INTO x2.t1(a,b) VALUES(1234,'hello');
 | |
|     INSERT INTO x2.t2(a,b) VALUES(50.5,'xyzzy');
 | |
|     CREATE TABLE x2.t3(a,b,c);
 | |
|     INSERT INTO x2.t3 VALUES(111,222,333);
 | |
|     CREATE TABLE main.t4(x,y,z);
 | |
|     INSERT INTO t4 SELECT * FROM t3;
 | |
|   }
 | |
|   set line "exec $PROG test.db test2.db"
 | |
|   unset -nocomplain ::MSG
 | |
|   catch {eval $line} ::MSG
 | |
| } {0}
 | |
| do_test sqldiff-1.1 {
 | |
|   set ::MSG
 | |
| } {DELETE FROM t1 WHERE a=49;
 | |
| INSERT INTO t1(a,b) VALUES(1234,'hello');
 | |
| DELETE FROM t2 WHERE a=48;
 | |
| INSERT INTO t2(a,b) VALUES(50.5,'xyzzy');
 | |
| CREATE TABLE t3(a,b,c);
 | |
| INSERT INTO t3(rowid,a,b,c) VALUES(1,111,222,333);
 | |
| DROP TABLE t4;}
 | |
| 
 | |
| finish_test
 | 
