summaryrefslogtreecommitdiff
path: root/sql-bench/crash-me.sh
diff options
context:
space:
mode:
Diffstat (limited to 'sql-bench/crash-me.sh')
-rwxr-xr-xsql-bench/crash-me.sh339
1 files changed, 203 insertions, 136 deletions
diff --git a/sql-bench/crash-me.sh b/sql-bench/crash-me.sh
index 394f64b85ab..5dd49d4d3bf 100755
--- a/sql-bench/crash-me.sh
+++ b/sql-bench/crash-me.sh
@@ -38,8 +38,7 @@
# as such, and clarify ones such as "mediumint" with comments such as
# "3-byte int" or "same as xxx".
-
-$version="1.51";
+$version="1.53";
use DBI;
use Getopt::Long;
@@ -51,6 +50,7 @@ $opt_dir="limits";
$opt_debug=$opt_help=$opt_Information=$opt_restart=$opt_force=$opt_quick=0;
$opt_log_all_queries=$opt_fix_limit_file=$opt_batch_mode=0;
$opt_db_start_cmd=""; # the db server start command
+$opt_check_server=0; # Check if server is alive before each query
$opt_sleep=10; # time to sleep while starting the db server
$limit_changed=0; # For configure file
$reconnect_count=0;
@@ -61,7 +61,7 @@ $limits{'operating_system'}= machine();
$prompts{'operating_system'}='crash-me tested on';
$retry_limit=3;
-GetOptions("Information","help","server=s","debug","user=s","password=s","database=s","restart","force","quick","log-all-queries","comment=s","host=s","fix-limit-file","dir=s","db-start-cmd=s","sleep=s","batch-mode","config-file=s","log-queries-to-file=s") || usage();
+GetOptions("Information","help","server=s","debug","user=s","password=s","database=s","restart","force","quick","log-all-queries","comment=s","host=s","fix-limit-file","dir=s","db-start-cmd=s","sleep=s","batch-mode","config-file=s","log-queries-to-file=s","check-server") || usage();
usage() if ($opt_help || $opt_Information);
$opt_config_file="$pwd/$opt_dir/$opt_server.cfg" if (length($opt_config_file) == 0);
@@ -136,6 +136,7 @@ $max_stacked_expressions="+2000";
$query_size=$max_buffer_size;
$longreadlen=16000000; # For retrieval buffer
+
#
# First do some checks that needed for the rest of the benchmark
#
@@ -143,11 +144,43 @@ use sigtrap; # Must be removed with perl5.005_2 on Win98
$SIG{PIPE} = 'IGNORE';
$SIG{SEGV} = sub {warn('SEGFAULT')};
$dbh=safe_connect();
-$dbh->do("drop table crash_me"); # Remove old run
-$dbh->do("drop table crash_me2"); # Remove old run
-$dbh->do("drop table crash_me3"); # Remove old run
-$dbh->do("drop table crash_q"); # Remove old run
-$dbh->do("drop table crash_q1"); # Remove old run
+
+#
+# Test if the database require RESTRICT/CASCADE after DROP TABLE
+#
+
+# Really remove the crash_me table
+$prompt="drop table require cascade/restrict";
+$drop_attr="";
+$dbh->do("drop table crash_me");
+$dbh->do("drop table crash_me cascade");
+if (!safe_query(["create table crash_me (a integer not null)",
+ "drop table crash_me"]))
+{
+ $dbh->do("drop table crash_me cascade");
+ if (safe_query(["create table crash_me (a integer not null)",
+ "drop table crash_me cascade"]))
+ {
+ save_config_data('drop_requires_cascade',"yes","$prompt");
+ $drop_attr="cascade";
+ }
+ else
+ {
+ die "Can't create and drop table 'crash_me'\n";
+ }
+}
+else
+{
+ save_config_data('drop_requires_cascade',"no","$prompt");
+ $drop_attr="";
+}
+
+# Remove tables from old runs
+$dbh->do("drop table crash_me $drop_attr");
+$dbh->do("drop table crash_me2 $drop_attr");
+$dbh->do("drop table crash_me3 $drop_attr");
+$dbh->do("drop table crash_q $drop_attr");
+$dbh->do("drop table crash_q1 $drop_attr");
$prompt="Tables without primary key";
if (!safe_query(["create table crash_me (a integer not null,b char(10) not null)",
@@ -164,6 +197,7 @@ else
{
save_config_data('no_primary_key',"yes",$prompt);
}
+
#
# Define strings for character NULL and numeric NULL used in expressions
#
@@ -222,28 +256,33 @@ report("Group by position",'group_by_position',
"select a from crash_me group by 1");
report("Group by alias",'group_by_alias',
"select a as ab from crash_me group by ab");
+report("Group on unused column",'group_on_unused',
+ "select count(*) from crash_me group by a");
+
report("Order by",'order_by',"select a from crash_me order by a");
report("Order by position",'order_by_position',
"select a from crash_me order by 1");
report("Order by function","order_by_function",
"select a from crash_me order by a+1");
+report("Order by on unused column",'order_on_unused',
+ "select b from crash_me order by a");
check_and_report("Order by DESC is remembered",'order_by_remember_desc',
["create table crash_q (s int,s1 int)",
"insert into crash_q values(1,1)",
"insert into crash_q values(3,1)",
"insert into crash_q values(2,1)"],
"select s,s1 from crash_q order by s1 DESC,s",
- ["drop table crash_q"],[3,2,1],7,undef(),3);
+ ["drop table crash_q $drop_attr"],[3,2,1],7,undef(),3);
report("Compute",'compute',
"select a from crash_me order by a compute sum(a) by a");
report("Value lists in INSERT",'multi_value_insert',
"create table crash_q (s char(10))",
"insert into crash_q values ('a'),('b')",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("INSERT with set syntax",'insert_with_set',
"create table crash_q (a integer)",
"insert into crash_q SET a=1",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("allows end ';'","end_colon", "select * from crash_me;");
try_and_report("LIMIT number of rows","select_limit",
["with LIMIT",
@@ -253,7 +292,7 @@ try_and_report("LIMIT number of rows","select_limit",
report("SELECT with LIMIT #,#","select_limit2", "select * from crash_me limit 1,1");
# The following alter table commands MUST be kept together!
-if ($dbh->do("create table crash_q (a integer, b integer,c CHAR(10))"))
+if ($dbh->do("create table crash_q (a integer, b integer,c1 CHAR(10))"))
{
report("Alter table add column",'alter_add_col',
"alter table crash_q add d integer");
@@ -266,11 +305,10 @@ if ($dbh->do("create table crash_q (a integer, b integer,c CHAR(10))"))
# informix can only change data type with modify
report_one("Alter table modify column",'alter_modify_col',
- [["alter table crash_q modify c CHAR(20)","yes"],
- ["alter table crash_q alter c CHAR(20)","with alter"]]);
+ [["alter table crash_q modify c1 CHAR(20)","yes"],
+ ["alter table crash_q alter c1 CHAR(20)","with alter"]]);
report("Alter table alter column default",'alter_alter_col',
- "alter table crash_q alter b set default 10",
- "alter table crash_q alter b set default NULL");
+ "alter table crash_q alter b set default 10");
report_one("Alter table drop column",'alter_drop_col',
[["alter table crash_q drop column b","yes"],
["alter table crash_q drop column b restrict","with restrict/cascade"]]);
@@ -278,46 +316,51 @@ if ($dbh->do("create table crash_q (a integer, b integer,c CHAR(10))"))
"alter table crash_q rename to crash_q1");
}
# Make sure both tables will be dropped, even if rename fails.
-$dbh->do("drop table crash_q1");
-$dbh->do("drop table crash_q");
+$dbh->do("drop table crash_q1 $drop_attr");
+$dbh->do("drop table crash_q $drop_attr");
report("rename table","rename_table",
- "create table crash_q (a integer, b integer,c CHAR(10))",
+ "create table crash_q (a integer, b integer,c1 CHAR(10))",
"rename table crash_q to crash_q1",
- "drop table crash_q1");
+ "drop table crash_q1 $drop_attr");
# Make sure both tables will be dropped, even if rename fails.
-$dbh->do("drop table crash_q1");
-$dbh->do("drop table crash_q");
+$dbh->do("drop table crash_q1 $drop_attr");
+$dbh->do("drop table crash_q $drop_attr");
report("truncate","truncate_table",
- "create table crash_q (a integer, b integer,c CHAR(10))",
+ "create table crash_q (a integer, b integer,c1 CHAR(10))",
"truncate crash_q",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
-if ($dbh->do("create table crash_q (a integer, b integer,c CHAR(10))") &&
- $dbh->do("create table crash_q1 (a integer, b integer,c CHAR(10) not null)"))
+if ($dbh->do("create table crash_q (a integer, b integer,c1 CHAR(10))") &&
+ $dbh->do("create table crash_q1 (a integer, b integer,c1 CHAR(10) not null)"))
{
report("Alter table add constraint",'alter_add_constraint',
- "alter table crash_q add constraint c1 check(a > b)");
- report("Alter table drop constraint",'alter_drop_constraint',
- "alter table crash_q drop constraint c1");
+ "alter table crash_q add constraint c2 check(a > b)");
+ report_one("Alter table drop constraint",'alter_drop_constraint',
+ [["alter table crash_q drop constraint c2","yes"],
+ ["alter table crash_q drop constraint c2 restrict","with restrict/cascade"]]);
report("Alter table add unique",'alter_add_unique',
- "alter table crash_q add constraint u1 unique(c)");
+ "alter table crash_q add constraint u1 unique(c1)");
try_and_report("Alter table drop unique",'alter_drop_unique',
["with constraint",
"alter table crash_q drop constraint u1"],
+ ["with constraint and restrict/cascade",
+ "alter table crash_q drop constraint u1 restrict"],
["with drop key",
- "alter table crash_q drop key c"]);
+ "alter table crash_q drop key c1"]);
try_and_report("Alter table add primary key",'alter_add_primary_key',
["with constraint",
- "alter table crash_q1 add constraint p1 primary key(c)"],
+ "alter table crash_q1 add constraint p1 primary key(c1)"],
["with add primary key",
- "alter table crash_q1 add primary key(c)"]);
+ "alter table crash_q1 add primary key(c1)"]);
report("Alter table add foreign key",'alter_add_foreign_key',
- "alter table crash_q add constraint f1 foreign key(c) references crash_q1(c)");
+ "alter table crash_q add constraint f1 foreign key(c1) references crash_q1(c1)");
try_and_report("Alter table drop foreign key",'alter_drop_foreign_key',
["with drop constraint",
"alter table crash_q drop constraint f1"],
+ ["with drop constraint and restrict/cascade",
+ "alter table crash_q drop constraint f1 restrict"],
["with drop foreign key",
"alter table crash_q drop foreign key f1"]);
try_and_report("Alter table drop primary key",'alter_drop_primary_key',
@@ -326,8 +369,8 @@ if ($dbh->do("create table crash_q (a integer, b integer,c CHAR(10))") &&
["drop primary key",
"alter table crash_q1 drop primary key"]);
}
-$dbh->do("drop table crash_q");
-$dbh->do("drop table crash_q1");
+$dbh->do("drop table crash_q $drop_attr");
+$dbh->do("drop table crash_q1 $drop_attr");
check_and_report("case insensitive compare","case_insensitive_strings",
[],"select b from crash_me where b = 'A'",[],'a',1);
@@ -337,8 +380,8 @@ check_and_report("group on column with null values",'group_by_null',
["create table crash_q (s char(10))",
"insert into crash_q values(null)",
"insert into crash_q values(null)"],
- "select count(*) from crash_q group by s",
- ["drop table crash_q"],2,0);
+ "select count(*),s from crash_q group by s",
+ ["drop table crash_q $drop_attr"],2,0);
$prompt="Having";
if (!defined($limits{'having'}))
@@ -563,7 +606,7 @@ foreach $types (@types)
$tmp2 =~ s/_not_null//g;
report("Type $type","type_$types->[0]_$tmp2",
"create table crash_q (q $use_type)",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
}
}
@@ -575,7 +618,7 @@ check_and_report("Remembers end space in char()","remember_end_space",
["create table crash_q (a char(10))",
"insert into crash_q values('hello ')"],
"select a from crash_q where a = 'hello '",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
'hello ',6);
check_and_report("Remembers end space in varchar()",
@@ -583,35 +626,35 @@ check_and_report("Remembers end space in varchar()",
["create table crash_q (a varchar(10))",
"insert into crash_q values('hello ')"],
"select a from crash_q where a = 'hello '",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
'hello ',6);
check_and_report("Supports 0000-00-00 dates","date_zero",
["create table crash_me2 (a date not null)",
"insert into crash_me2 values ('0000-00-00')"],
"select a from crash_me2",
- ["drop table crash_me2"],
+ ["drop table crash_me2 $drop_attr"],
"0000-00-00",1);
check_and_report("Supports 0001-01-01 dates","date_one",
["create table crash_me2 (a date not null)",
"insert into crash_me2 values (DATE '0001-01-01')"],
"select a from crash_me2",
- ["drop table crash_me2"],
+ ["drop table crash_me2 $drop_attr"],
"0001-01-01",1);
check_and_report("Supports 9999-12-31 dates","date_last",
["create table crash_me2 (a date not null)",
"insert into crash_me2 values (DATE '9999-12-31')"],
"select a from crash_me2",
- ["drop table crash_me2"],
+ ["drop table crash_me2 $drop_attr"],
"9999-12-31",1);
check_and_report("Supports 'infinity dates","date_infinity",
["create table crash_me2 (a date not null)",
"insert into crash_me2 values ('infinity')"],
"select a from crash_me2",
- ["drop table crash_me2"],
+ ["drop table crash_me2 $drop_attr"],
"infinity",1);
if (!defined($limits{'date_with_YY'}))
@@ -620,7 +663,7 @@ if (!defined($limits{'date_with_YY'}))
["create table crash_me2 (a date not null)",
"insert into crash_me2 values ('98-03-03')"],
"select a from crash_me2",
- ["drop table crash_me2"],
+ ["drop table crash_me2 $drop_attr"],
"1998-03-03",5);
if ($limits{'date_with_YY'} eq "yes")
{
@@ -630,7 +673,7 @@ if (!defined($limits{'date_with_YY'}))
["create table crash_me2 (a date not null)",
"insert into crash_me2 values ('10-03-03')"],
"select a from crash_me2",
- ["drop table crash_me2"],
+ ["drop table crash_me2 $drop_attr"],
"2010-03-03",5);
}
}
@@ -645,33 +688,33 @@ if (($limits{'type_extra_float(2_arg)'} eq "yes" ||
if (execute_and_check(["create table crash_q (q1 $type)",
"insert into crash_q values(1.14)"],
"select q1 from crash_q",
- ["drop table crash_q"],1.1,0) &&
+ ["drop table crash_q $drop_attr"],1.1,0) &&
execute_and_check(["create table crash_q (q1 $type)",
"insert into crash_q values(1.16)"],
"select q1 from crash_q",
- ["drop table crash_q"],1.1,0))
+ ["drop table crash_q $drop_attr"],1.1,0))
{
$result="truncate";
}
elsif (execute_and_check(["create table crash_q (q1 $type)",
"insert into crash_q values(1.14)"],
"select q1 from crash_q",
- ["drop table crash_q"],1.1,0) &&
+ ["drop table crash_q $drop_attr"],1.1,0) &&
execute_and_check(["create table crash_q (q1 $type)",
"insert into crash_q values(1.16)"],
"select q1 from crash_q",
- ["drop table crash_q"],1.2,0))
+ ["drop table crash_q $drop_attr"],1.2,0))
{
$result="round";
}
elsif (execute_and_check(["create table crash_q (q1 $type)",
"insert into crash_q values(1.14)"],
"select q1 from crash_q",
- ["drop table crash_q"],1.14,0) &&
+ ["drop table crash_q $drop_attr"],1.14,0) &&
execute_and_check(["create table crash_q (q1 $type)",
"insert into crash_q values(1.16)"],
"select q1 from crash_q",
- ["drop table crash_q"],1.16,0))
+ ["drop table crash_q $drop_attr"],1.16,0))
{
$result="exact";
}
@@ -682,20 +725,20 @@ if (($limits{'type_extra_float(2_arg)'} eq "yes" ||
try_and_report("Type for row id", "rowid",
["rowid",
- "create table crash_q (a rowid)","drop table crash_q"],
+ "create table crash_q (a rowid)","drop table crash_q $drop_attr"],
["auto_increment",
- "create table crash_q (a int not null auto_increment, primary key(a))","drop table crash_q"],
+ "create table crash_q (a int not null auto_increment, primary key(a))","drop table crash_q $drop_attr"],
["oid",
- "create table crash_q (a oid, primary key(a))","drop table crash_q"],
+ "create table crash_q (a oid, primary key(a))","drop table crash_q $drop_attr"],
["serial",
- "create table crash_q (a serial, primary key(a))","drop table crash_q"]);
+ "create table crash_q (a serial, primary key(a))","drop table crash_q $drop_attr"]);
try_and_report("Automatic rowid", "automatic_rowid",
["_rowid",
"create table crash_q (a int not null, primary key(a))",
"insert into crash_q values (1)",
"select _rowid from crash_q",
- "drop table crash_q"]);
+ "drop table crash_q $drop_attr"]);
#
# Test functions
@@ -1081,19 +1124,19 @@ report("LIKE on numbers","like_with_number",
"create table crash_q (a int,b int)",
"insert into crash_q values(10,10)",
"select * from crash_q where a like '10'",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("column LIKE column","like_with_column",
"create table crash_q (a char(10),b char(10))",
"insert into crash_q values('abc','abc')",
"select * from crash_q where a like b",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("update of column= -column","NEG",
"create table crash_q (a integer)",
"insert into crash_q values(10)",
"update crash_q set a=-a",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
if ($limits{'func_odbc_left'} eq 'yes' ||
$limits{'func_odbc_substring'} eq 'yes')
@@ -1105,7 +1148,7 @@ if ($limits{'func_odbc_left'} eq 'yes' ||
["create table crash_me2 (a date not null)",
"insert into crash_me2 values ('1998-03-03')"],
"select $type from crash_me2",
- ["drop table crash_me2"],
+ ["drop table crash_me2 $drop_attr"],
"1998",1);
}
@@ -1125,7 +1168,7 @@ if (!defined($limits{'multi_table_update'}))
"insert into crash_q values(1,'c')",
"update crash_q left join crash_me on crash_q.a=crash_me.a set crash_q.b=crash_me.b"],
"select b from crash_q",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
"a",1,undef(),2))
{
check_and_report("Update with many tables","multi_table_update",
@@ -1133,7 +1176,7 @@ if (!defined($limits{'multi_table_update'}))
"insert into crash_q values(1,'c')",
"update crash_q,crash_me set crash_q.b=crash_me.b where crash_q.a=crash_me.a"],
"select b from crash_q",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
"a",1,
1);
}
@@ -1143,14 +1186,14 @@ report("DELETE FROM table1,table2...","multi_table_delete",
"create table crash_q (a integer,b char(10))",
"insert into crash_q values(1,'c')",
"delete crash_q.* from crash_q,crash_me where crash_q.a=crash_me.a",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
check_and_report("Update with sub select","select_table_update",
["create table crash_q (a integer,b char(10))",
"insert into crash_q values(1,'c')",
"update crash_q set b= (select b from crash_me where crash_q.a = crash_me.a)"],
"select b from crash_q",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
"a",1);
check_and_report("Calculate 1--1","minus_neg",[],
@@ -1178,7 +1221,7 @@ if (defined($found))
new query_many(["create table crash_q (q $found)",
"insert into crash_q values ('%s')"],
"select * from crash_q","%s",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
min($max_string_size,$limits{'query_size'}-30)));
}
@@ -1187,8 +1230,8 @@ if (defined($found))
# what can be stored...
find_limit(($prompt="constant string size in where"),"where_string_size",
- new query_repeat([],"select a from crash_me where b <'",
- "","","a","","'"));
+ new query_repeat([],"select a from crash_me where b >='",
+ "","","1","","'"));
if ($limits{'where_string_size'} == 10)
{
save_config_data('where_string_size','nonstandard',$prompt);
@@ -1251,11 +1294,11 @@ find_limit("tables in join", "join_tables",
report("primary key in create table",'primary_key_in_create',
"create table crash_q (q integer not null,primary key (q))",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("unique in create table",'unique_in_create',
"create table crash_q (q integer not null,unique (q))",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
if ($limits{'unique_in_create'} eq 'yes')
{
@@ -1264,29 +1307,29 @@ if ($limits{'unique_in_create'} eq 'yes')
"insert into crash_q (q) values (NULL)",
"insert into crash_q (q) values (NULL)",
"insert into crash_q (q) values (1)",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
}
report("default value for column",'create_default',
"create table crash_q (q integer default 10 not null)",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("default value function for column",'create_default_func',
"create table crash_q (q integer not null,q1 integer default (1+1)",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("temporary tables",'tempoary_table',
"create temporary table crash_q (q integer not null)",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report_one("create table from select",'create_table_select',
[["create table crash_q SELECT * from crash_me","yes"],
["create table crash_q AS SELECT * from crash_me","with AS"]]);
-$dbh->do("drop table crash_q");
+$dbh->do("drop table crash_q $drop_attr");
report("index in create table",'index_in_create',
"create table crash_q (q integer not null,index (q))",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
# The following must be executed as we need the value of end_drop_keyword
# later
@@ -1345,7 +1388,7 @@ check_and_report("null in index","null_in_index",
[create_table("crash_q",["a char(10)"],["(a)"]),
"insert into crash_q values (NULL)"],
"select * from crash_q",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
undef(),4);
if ($limits{'unique_in_create'} eq 'yes')
@@ -1354,7 +1397,12 @@ if ($limits{'unique_in_create'} eq 'yes')
create_table("crash_q",["q integer"],["unique(q)"]),
"insert into crash_q (q) values(NULL)",
"insert into crash_q (q) values(NULL)",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
+ report("null combination in unique index",'nulls_in_unique',
+ create_table("crash_q",["q integer,q1 integer"],["unique(q)"]),
+ "insert into crash_q (q,q1) values(1,NULL)",
+ "insert into crash_q (q,q1) values(1,NULL)",
+ "drop table crash_q $drop_attr");
}
if ($limits{'null_in_unique'} eq 'yes')
@@ -1363,7 +1411,7 @@ if ($limits{'null_in_unique'} eq 'yes')
create_table("crash_q",["q integer, x integer"],["unique(q)"]),
"insert into crash_q(x) values(1)",
"insert into crash_q(x) values(2)",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
}
if ($limits{'create_index'} ne 'no')
@@ -1385,29 +1433,29 @@ if ($limits{'create_index'} ne 'no')
if (!report("case independent table names","table_name_case",
"create table crash_q (q integer)",
- "drop table CRASH_Q"))
+ "drop table CRASH_Q $drop_attr"))
{
- safe_query("drop table crash_q");
+ safe_query("drop table crash_q $drop_attr");
}
if (!report("drop table if exists","drop_if_exists",
"create table crash_q (q integer)",
- "drop table if exists crash_q"))
+ "drop table if exists crash_q $drop_attr"))
{
- safe_query("drop table crash_q");
+ safe_query("drop table crash_q $drop_attr");
}
report("create table if not exists","create_if_not_exists",
"create table crash_q (q integer)",
"create table if not exists crash_q (q integer)");
-safe_query("drop table crash_q");
+safe_query("drop table crash_q $drop_attr");
#
# test of different join types
#
-assert("create table crash_me2 (a integer not null,b char(10) not null, c integer)");
-assert("insert into crash_me2 (a,b,c) values (1,'b',1)");
+assert("create table crash_me2 (a integer not null,b char(10) not null, c1 integer)");
+assert("insert into crash_me2 (a,b,c1) values (1,'b',1)");
assert("create table crash_me3 (a integer not null,b char(10) not null)");
assert("insert into crash_me3 (a,b) values (1,'b')");
@@ -1416,9 +1464,9 @@ report("inner join","inner_join",
report("left outer join","left_outer_join",
"select crash_me.a from crash_me left join crash_me2 ON crash_me.a=crash_me2.a");
report("natural left outer join","natural_left_outer_join",
- "select c from crash_me natural left join crash_me2");
+ "select c1 from crash_me natural left join crash_me2");
report("left outer join using","left_outer_join_using",
- "select c from crash_me left join crash_me2 using (a)");
+ "select c1 from crash_me left join crash_me2 using (a)");
report("left outer join odbc style","odbc_left_outer_join",
"select crash_me.a from { oj crash_me left outer join crash_me2 ON crash_me.a=crash_me2.a }");
report("right outer join","right_outer_join",
@@ -1449,7 +1497,7 @@ report("minus","minus",
"select * from crash_me minus select * from crash_me3"); # oracle ...
report("natural join (incompatible lists)","natural_join_incompat",
- "select c from crash_me natural join crash_me2");
+ "select c1 from crash_me natural join crash_me2");
report("union (incompatible lists)","union_incompat",
"select * from crash_me union select a,b from crash_me2");
report("union all (incompatible lists)","union_all_incompat",
@@ -1469,8 +1517,8 @@ report("except all (incompatible lists)","except_all_incompat",
report("minus (incompatible lists)","minus_incompat",
"select * from crash_me minus select * from crash_me2"); # oracle ...
-assert("drop table crash_me2");
-assert("drop table crash_me3");
+assert("drop table crash_me2 $drop_attr");
+assert("drop table crash_me3 $drop_attr");
# somethings to be added here ....
# FOR UNION - INTERSECT - EXCEPT -> CORRESPONDING [ BY ]
@@ -1489,13 +1537,13 @@ if (report("subqueries","subqueries",
report("insert INTO ... SELECT ...","insert_select",
"create table crash_q (a int)",
"insert into crash_q (a) SELECT crash_me.a from crash_me",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report_trans("transactions","transactions",
[create_table("crash_q",["a integer not null"],[]),
"insert into crash_q values (1)"],
"select * from crash_q",
- "drop table crash_q"
+ "drop table crash_q $drop_attr"
);
report("atomic updates","atomic_updates",
@@ -1504,7 +1552,7 @@ report("atomic updates","atomic_updates",
"insert into crash_q values (3)",
"insert into crash_q values (1)",
"update crash_q set a=a+1",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
if ($limits{'atomic_updates'} eq 'yes')
{
@@ -1515,14 +1563,14 @@ if ($limits{'atomic_updates'} eq 'yes')
"insert into crash_q values (3)",
"insert into crash_q values (1)",
"update crash_q set a=a+1 where a < 3",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
}
# To add with the views:
# DROP VIEW - CREAT VIEW *** [ WITH [ CASCADE | LOCAL ] CHECK OPTION ]
report("views","views",
"create view crash_q as select a from crash_me",
- "drop view crash_q");
+ "drop view crash_q $drop_attr");
report("foreign key syntax","foreign_key_syntax",
create_table("crash_q",["a integer not null"],["primary key (a)"]),
@@ -1531,8 +1579,8 @@ report("foreign key syntax","foreign_key_syntax",
[]),
"insert into crash_q values (1)",
"insert into crash_q2 values (1)",
- "drop table crash_q2",
- "drop table crash_q");
+ "drop table crash_q2 $drop_attr",
+ "drop table crash_q $drop_attr");
if ($limits{'foreign_key_syntax'} eq 'yes')
{
@@ -1544,8 +1592,8 @@ if ($limits{'foreign_key_syntax'} eq 'yes')
[]),
"insert into crash_q values (1)",
"insert into crash_q2 values (2)",
- "drop table crash_q2",
- "drop table crash_q");
+ "drop table crash_q2 $drop_attr",
+ "drop table crash_q $drop_attr");
}
report("Create SCHEMA","create_schema",
@@ -1564,40 +1612,40 @@ if ($limits{'foreign_key'} eq 'yes')
report("Column constraints","constraint_check",
"create table crash_q (a int check (a>0))",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("Table constraints","constraint_check_table",
"create table crash_q (a int ,b int, check (a>b))",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("Named constraints","constraint_check",
"create table crash_q (a int ,b int, constraint abc check (a>b))",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("NULL constraint (SyBase style)","constraint_null",
"create table crash_q (a int null)",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("Triggers (ANSI SQL)","psm_trigger",
"create table crash_q (a int ,b int)",
"create trigger crash_trigger after insert on crash_q referencing new table as new_a when (localtime > time '18:00:00') begin atomic end",
"insert into crash_q values(1,2)",
"drop trigger crash_trigger",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("PSM procedures (ANSI SQL)","psm_procedures",
"create table crash_q (a int,b int)",
"create procedure crash_proc(in a1 int, in b1 int) language sql modifies sql data begin declare c1 int; set c1 = a1 + b1; insert into crash_q(a,b) values (a1,c1); end",
"call crash_proc(1,10)",
"drop procedure crash_proc",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("PSM modules (ANSI SQL)","psm_modules",
"create table crash_q (a int,b int)",
"create module crash_m declare procedure crash_proc(in a1 int, in b1 int) language sql modifies sql data begin declare c1 int; set c1 = a1 + b1; insert into crash_q(a,b) values (a1,c1); end; declare procedure crash_proc2(INOUT a int, in b int) contains sql set a = b + 10; end module",
"call crash_proc(1,10)",
"drop module crash_m cascade",
- "drop table crash_q cascade");
+ "drop table crash_q cascade $drop_attr");
report("PSM functions (ANSI SQL)","psm_functions",
"create table crash_q (a int)",
@@ -1605,14 +1653,14 @@ report("PSM functions (ANSI SQL)","psm_functions",
"insert into crash_q values(crash_func(2,4))",
"select a,crash_func(a,2) from crash_q",
"drop function crash_func cascade",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("Domains (ANSI SQL)","domains",
"create domain crash_d as varchar(10) default 'Empty' check (value <> 'abcd')",
"create table crash_q(a crash_d, b int)",
"insert into crash_q(a,b) values('xyz',10)",
"insert into crash_q(b) values(10)",
- "drop table crash_q",
+ "drop table crash_q $drop_attr",
"drop domain crash_d");
@@ -1632,10 +1680,17 @@ if (!defined($limits{'lock_tables'}))
if (!report("many tables to drop table","multi_drop",
"create table crash_q (a int)",
"create table crash_q2 (a int)",
- "drop table crash_q,crash_q2"))
+ "drop table crash_q,crash_q2 $drop_attr"))
{
- $dbh->do("drop table crash_q");
- $dbh->do("drop table crash_q2");
+ $dbh->do("drop table crash_q $drop_attr");
+ $dbh->do("drop table crash_q2 $drop_attr");
+}
+
+if (!report("drop table with cascade/restrict","drop_restrict",
+ "create table crash_q (a int)",
+ "drop table crash_q restrict"))
+{
+ $dbh->do("drop table crash_q $drop_attr");
}
@@ -1656,13 +1711,13 @@ report("/* */ as comment","comment_/**/",
report("insert empty string","insert_empty_string",
create_table("crash_q",["a char(10) not null,b char(10)"],[]),
"insert into crash_q values ('','')",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
report("Having with alias","having_with_alias",
create_table("crash_q",["a integer"],[]),
"insert into crash_q values (10)",
"select sum(a) as b from crash_q group by a having b > 0",
- "drop table crash_q");
+ "drop table crash_q $drop_attr");
#
# test name limits
@@ -1672,14 +1727,14 @@ find_limit("table name length","max_table_name",
new query_many(["create table crash_q%s (q integer)",
"insert into crash_q%s values(1)"],
"select * from crash_q%s",1,
- ["drop table crash_q%s"],
+ ["drop table crash_q%s $drop_attr"],
$max_name_length,7,1));
find_limit("column name length","max_column_name",
new query_many(["create table crash_q (q%s integer)",
"insert into crash_q (q%s) values(1)"],
"select q%s from crash_q",1,
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
$max_name_length,1));
if ($limits{'column_alias'} eq 'yes')
@@ -1714,7 +1769,7 @@ find_limit("max char() size","max_char_size",
new query_many(["create table crash_q (q char(%d))",
"insert into crash_q values ('%s')"],
"select * from crash_q","%s",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
min($max_string_size,$limits{'query_size'})));
if ($limits{'type_sql_varchar(1_arg)'} eq 'yes')
@@ -1723,7 +1778,7 @@ if ($limits{'type_sql_varchar(1_arg)'} eq 'yes')
new query_many(["create table crash_q (q varchar(%d))",
"insert into crash_q values ('%s')"],
"select * from crash_q","%s",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
min($max_string_size,$limits{'query_size'})));
}
@@ -1743,13 +1798,13 @@ if (defined($found))
new query_many(["create table crash_q (q $found)",
"insert into crash_q values ('%s')"],
"select * from crash_q","%s",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
min($max_string_size,$limits{'query_size'}-30)));
}
$tmp=new query_repeat([],"create table crash_q (a integer","","",
- ",a%d integer","",")",["drop table crash_q"],
+ ",a%d integer","",")",["drop table crash_q $drop_attr"],
$max_columns);
$tmp->{'offset'}=1;
find_limit("Columns in table","max_columns",$tmp);
@@ -1773,7 +1828,7 @@ if ($limits{'unique_in_create'} eq 'yes')
",q%d integer not null,unique (q%d)",")",
["insert into crash_q (q,%f) values (1,%v)"],
"select q from crash_q",1,
- "drop table crash_q",
+ "drop table crash_q $drop_attr",
$max_keys,0));
find_limit("index parts","max_index_parts",
@@ -1781,14 +1836,14 @@ if ($limits{'unique_in_create'} eq 'yes')
",q%d","))",
["insert into crash_q ($key_fields) values ($key_values)"],
"select q0 from crash_q",1,
- "drop table crash_q",
+ "drop table crash_q $drop_attr",
$max_keys,1));
find_limit("max index part length","max_index_part_length",
new query_many(["create table crash_q (q char(%d) not null,unique(q))",
"insert into crash_q (q) values ('%s')"],
"select q from crash_q","%s",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
$limits{'max_char_size'},0));
if ($limits{'type_sql_varchar(1_arg)'} eq 'yes')
@@ -1797,7 +1852,7 @@ if ($limits{'unique_in_create'} eq 'yes')
new query_many(["create table crash_q (q varchar(%d) not null,unique(q))",
"insert into crash_q (q) values ('%s')"],
"select q from crash_q","%s",
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
$limits{'max_varchar_size'},0));
}
}
@@ -1829,7 +1884,7 @@ if ($limits{'create_index'} ne 'no')
$end_drop =~ s/%t/crash_q/;
assert($end_drop);
}
- assert("drop table crash_q");
+ assert("drop table crash_q $drop_attr");
}
print "indexs: $limits{'max_index'}\n";
if (!defined($limits{'max_unique_index'}))
@@ -1848,7 +1903,7 @@ if ($limits{'create_index'} ne 'no')
$end_drop =~ s/%t/crash_q/;
assert($end_drop);
}
- assert("drop table crash_q");
+ assert("drop table crash_q $drop_attr");
}
print "unique indexes: $limits{'max_unique_index'}\n";
if (!defined($limits{'max_index_parts'}))
@@ -1864,7 +1919,7 @@ if ($limits{'create_index'} ne 'no')
undef,undef,
$end_drop,
$max_keys,1));
- assert("drop table crash_q");
+ assert("drop table crash_q $drop_attr");
}
else
{
@@ -1881,20 +1936,20 @@ if ($limits{'create_index'} ne 'no')
"select q from crash_q",
"%s",
[ $end_drop,
- "drop table crash_q"],
+ "drop table crash_q $drop_attr"],
min($limits{'max_char_size'},"+8192")));
}
}
find_limit("index length","max_index_length",
new query_index_length("create table crash_q ",
- "drop table crash_q",
+ "drop table crash_q $drop_attr",
$max_key_length));
find_limit("max table row length (without blobs)","max_row_length",
new query_row_length("crash_q ",
"not null",
- "drop table crash_q",
+ "drop table crash_q $drop_attr",
min($max_row_length,
$limits{'max_columns'}*
min($limits{'max_char_size'},255))));
@@ -1903,7 +1958,7 @@ find_limit("table row length with nulls (without blobs)",
"max_row_length_with_null",
new query_row_length("crash_q ",
"",
- "drop table crash_q",
+ "drop table crash_q $drop_attr",
$limits{'max_row_length'}*2));
find_limit("number of columns in order by","columns_in_order_by",
@@ -1912,7 +1967,7 @@ find_limit("number of columns in order by","columns_in_order_by",
"insert into crash_q values(%v)"],
"select * from crash_q order by %f",
undef(),
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
$max_order_by));
find_limit("number of columns in group by","columns_in_group_by",
@@ -1921,14 +1976,14 @@ find_limit("number of columns in group by","columns_in_group_by",
"insert into crash_q values(%v)"],
"select %f from crash_q group by %f",
undef(),
- ["drop table crash_q"],
+ ["drop table crash_q $drop_attr"],
$max_order_by));
#
# End of test
#
-$dbh->do("drop table crash_me"); # Remove temporary table
+$dbh->do("drop table crash_me $drop_attr"); # Remove temporary table
print "crash-me safe: $limits{'crash_me_safe'}\n";
print "reconnected $reconnect_count times\n";
@@ -1971,6 +2026,11 @@ $0 takes the following options:
--comment='some comment'
Add this comment to the crash-me limit file
+--check-server
+ Do a new connection to the server every time crash-me checks if the server
+ is alive. This can help in cases where the server starts returning wrong
+ data because of an earlier select.
+
--database='database' (Default $opt_database)
Create test tables in this database.
@@ -2014,7 +2074,7 @@ $0 takes the following options:
User name to log into the SQL server.
--start-cmd='command to restart server'
- Automaticly restarts server with this command if the server dies.
+ Automaticly restarts server with this command if the database server dies.
--sleep='time in seconds' (Default $opt_sleep)
Wait this long before restarting server.
@@ -2213,6 +2273,13 @@ sub check_connect
my ($sth);
print "Checking connection\n" if ($opt_log_all_queries);
# The following line will not work properly with interbase
+ if ($opt_check_server && defined($check_connect) && $dbh->{AutoCommit} != 0)
+ {
+
+ $dbh->disconnect;
+ $dbh=safe_connect($object);
+ return;
+ }
return if (defined($check_connect) && defined($dbh->do($check_connect)));
$dbh->disconnect || warn $dbh->errstr;
print "\nreconnecting\n" if ($opt_debug);