diff options
author | unknown <monty@hundin.mysql.fi> | 2002-01-02 21:29:41 +0200 |
---|---|---|
committer | unknown <monty@hundin.mysql.fi> | 2002-01-02 21:29:41 +0200 |
commit | f4fee3d90e8456cfd2a4e2f395bd270d0a12c70d (patch) | |
tree | ef8afaf7a0fed42b30ef0d9d38acccc992b5f87d /sql-bench | |
parent | 27f652efefba29bf58f45cbfe21a4228ec6fdb34 (diff) | |
download | mariadb-git-f4fee3d90e8456cfd2a4e2f395bd270d0a12c70d.tar.gz |
Added macros for nice TIMESPEC usage.
Fixes for building MySQL with gcc 3.0
Added SIGNED / UNSIGNED casts
Fixed core dump bug in net_clear() with libmysqld.
Back to using semaphores in query cache.
Added 'Null' and 'Index_type' to SHOW INDEX.
BUILD/FINISH.sh:
Fixes for gcc 3.0
BUILD/SETUP.sh:
Fixes for gcc 3.0
Docs/manual.texi:
Changelog + SIGNED/UNSIGNED casts.
Makefile.am:
include BUILD scripts in source distribution.
client/Makefile.am:
Fixes for gcc 3.0
client/mysql.cc:
Cleanup
client/mysqldump.c:
Changed 'K' to mean 'disable-keys' instead of 'no-disabled-keys'
client/readline.cc:
Cleanup
configure.in:
Include BUILD in source distrbution
extra/my_print_defaults.c:
Cleanup
include/my_global.h:
Fix for HPUX and setrlimit.
Portability fix.
Added macros for nice TIMESPEC usage.
innobase/include/dyn0dyn.h:
Fix for AIX
libmysql/Makefile.shared:
Added strxmov to libmysqld
libmysqld/examples/Makefile.am:
Fixes for gcc 3.0
libmysqld/lib_vio.c:
Cleanup
myisam/ft_dump.c:
Portability fixes
myisam/ftdefs.h:
Portability fixes
mysql-test/r/bdb.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/bigint.result:
New test for SIGNED/UNSIGNED
mysql-test/r/fulltext.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/heap.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/innodb.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/isam.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/key.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/myisam.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/query_cache.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/select.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/show_check.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/r/type_ranges.result:
Cleanup results after adding 2 columns to SHOW KEYS
mysql-test/t/bigint.test:
New test for SIGNED/UNSIGNED
mysql-test/t/key.test:
New test for SIGNED/UNSIGNED
mysql-test/t/query_cache.test:
Test for FOUND_ROWS()
sql-bench/crash-me.sh:
Safety fixes
sql/derror.cc:
Cleanup
sql/ha_berkeley.h:
New test for SIGNED/UNSIGNED
sql/ha_heap.h:
New test for SIGNED/UNSIGNED
sql/ha_innobase.cc:
New test for SIGNED/UNSIGNED
sql/ha_innobase.h:
New test for SIGNED/UNSIGNED
sql/ha_isam.h:
New test for SIGNED/UNSIGNED
sql/ha_myisam.cc:
New test for SIGNED/UNSIGNED
sql/ha_myisam.h:
New test for SIGNED/UNSIGNED
sql/handler.h:
New test for SIGNED/UNSIGNED
sql/item_func.cc:
Cleanup TIMESPEC usage
sql/item_func.h:
Added SIGNED / UNSIGNED casts
sql/lex.h:
Added SIGNED / UNSIGNED casts
sql/mysqld.cc:
Cleanup TIMESPEC usage
sql/net_pkg.cc:
Cleanup
sql/net_serv.cc:
Fixed core dump bug in net_clear()
sql/slave.cc:
Cleanup
sql/sql_cache.cc:
Back to using semaphores
sql/sql_cache.h:
Back to using semaphores
sql/sql_insert.cc:
Cleanup TIMESPEC usage
sql/sql_manager.cc:
Cleanup TIMESPEC usage
sql/sql_parse.cc:
Cleanup
sql/sql_repl.cc:
Cleanup TIMESPEC usage
sql/sql_show.cc:
Added 'Null' and 'Index_type' to SHOW INDEX.
sql/sql_table.cc:
Sort keys in table in a more logical order.
sql/sql_yacc.yy:
Support for SIGNED/UNSIGNED casts.
Diffstat (limited to 'sql-bench')
-rw-r--r-- | sql-bench/crash-me.sh | 33 |
1 files changed, 31 insertions, 2 deletions
diff --git a/sql-bench/crash-me.sh b/sql-bench/crash-me.sh index 434599a1ac4..9572143ae53 100644 --- a/sql-bench/crash-me.sh +++ b/sql-bench/crash-me.sh @@ -143,7 +143,15 @@ $longreadlen=16000000; # For retrieval buffer # use sigtrap; # Must be removed with perl5.005_2 on Win98 $SIG{PIPE} = 'IGNORE'; -$SIG{SEGV} = sub {warn('SEGFAULT')}; +$problem_counter=0; +$SIG{SEGV} = sub { + $problem_counter +=1; + if ($problem_counter >= 100) { + die("Too many problems, try to restart"); + } else { + warn('SEGFAULT'); + }; +}; $dbh=safe_connect(); # @@ -252,6 +260,8 @@ report("Functions",'functions',"select 1+1 $end_query"); report("Group functions",'group_functions',"select count(*) from crash_me"); report("Group functions with distinct",'group_distinct_functions', "select count(distinct a) from crash_me"); +report("Group functions with several distinct",'group_many_distinct_functions', + "select count(distinct a), count(distinct b) from crash_me"); report("Group by",'group_by',"select a from crash_me group by a"); report("Group by position",'group_by_position', "select a from crash_me group by 1"); @@ -1438,6 +1448,14 @@ if (!report("case independent table names","table_name_case", safe_query("drop table crash_q $drop_attr"); } +if (!report("case independent field names","field_name_case", + "create table crash_q (q integer)", + "insert into crash_q(Q) values (1)", + "drop table crash_q $drop_attr")) +{ + 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_attr")) @@ -2450,6 +2468,7 @@ sub report print "$prompt: "; if (!defined($limits{$limit})) { + save_config_data($limit,"incompleted",$prompt); save_config_data($limit,safe_query(\@queries) ? "yes" : "no",$prompt); } print "$limits{$limit}\n"; @@ -2462,6 +2481,7 @@ sub report_fail print "$prompt: "; if (!defined($limits{$limit})) { + save_config_data($limit,"incompleted",$prompt); save_config_data($limit,safe_query(\@queries) ? "no" : "yes",$prompt); } print "$limits{$limit}\n"; @@ -2478,6 +2498,7 @@ sub report_one print "$prompt: "; if (!defined($limits{$limit})) { + save_config_data($limit,"incompleted",$prompt); $result="no"; foreach $query (@$queries) { @@ -2503,6 +2524,7 @@ sub report_result print "$prompt: "; if (!defined($limits{$limit})) { + save_config_data($limit,"incompleted",$prompt); $error=safe_query_result($query,"1",2); save_config_data($limit,$error ? "not supported" : $last_result,$prompt); } @@ -2515,6 +2537,7 @@ sub report_trans my ($limit,$queries,$check,$clear)=@_; if (!defined($limits{$limit})) { + save_config_data($limit,"incompleted",$prompt); eval {undef($dbh->{AutoCommit})}; if (!$@) { @@ -2556,9 +2579,11 @@ sub check_and_report print "$prompt: " if (!defined($skip_prompt)); if (!defined($limits{$limit})) { + save_config_data($limit,"incompleted",$prompt); $tmp=1-safe_query(\@$pre); $tmp=safe_query_result($query,$answer,$string_type) if (!$tmp); safe_query(\@$post); + delete $limits{$limit}; if ($function == 3) # Report error as 'no'. { $function=0; @@ -2587,8 +2612,10 @@ sub try_and_report my ($tmp,$test,$type); print "$prompt: "; + if (!defined($limits{$limit})) { + save_config_data($limit,"incompleted",$prompt); $type="no"; # Not supported foreach $test (@tests) { @@ -2699,7 +2726,7 @@ sub safe_query_result elsif ($result_type == 5) # Result should have given prefix { $result= -1 if (length($row->[0]) < length($answer) && - substring($row->[0],1,length($answer)) ne $answer); + substr($row->[0],1,length($answer)) ne $answer); } elsif ($result_type == 6) # Exact match but ignore errors { @@ -2760,6 +2787,8 @@ sub find_limit() print "$end (cache)\n"; return $end; } + save_config_data($limit,"incompleted",$prompt); + if (defined($query->{'init'}) && !defined($end=$limits{'restart'}{'tohigh'})) { if (!safe_query($query->{'init'})) |