Changeset: 1481eb763890 for MonetDB
URL: http://dev.monetdb.org/hg/MonetDB?cmd=changeset;node=1481eb763890
Modified Files:
        sql/src/test/BugTracker-2010/Tests/All
        
sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.sql
        
sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.stable.err
        
sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.stable.out
Branch: Jun2010
Log Message:

added test for bug 2599:

as reported, with
create table tt (a int, b int);

the following two prepare statements appear to work fine:
prepare select * from tt where a>1+?;
prepare select * from tt where a>2*?+1;

but these two crash the server with a segfault:
prepare select * from tt where a>?+1;
prepare select * from tt where a>1+?*2;


diffs (162 lines):

diff -r 1a1630dd4caa -r 1481eb763890 sql/src/test/BugTracker-2010/Tests/All
--- a/sql/src/test/BugTracker-2010/Tests/All    Thu Jul 08 15:37:44 2010 +0200
+++ b/sql/src/test/BugTracker-2010/Tests/All    Thu Jul 08 15:46:13 2010 +0200
@@ -20,3 +20,4 @@
 keycheck_crash.Bug-2583
 in_query_with_constants_fails.Bug-2582
 prepare_on_boolean_bug.Bug-2581
+prepare_statements_crash_server.Bug-2599
diff -r 1a1630dd4caa -r 1481eb763890 
sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.sql
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ 
b/sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.sql
   Thu Jul 08 15:46:13 2010 +0200
@@ -0,0 +1,9 @@
+create table t_2599 (a int, b int);
+-- work:
+prepare select * from t_2599 where a>1+?;
+prepare select * from t_2599 where a>2*?+1;
+-- crash:
+prepare select * from t_2599 where a>?+1;
+prepare select * from t_2599 where a>1+?*2;
+-- cleanup:
+drop table t_2599;
diff -r 1a1630dd4caa -r 1481eb763890 
sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.stable.err
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ 
b/sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.stable.err
    Thu Jul 08 15:46:13 2010 +0200
@@ -0,0 +1,78 @@
+stderr of test 'prepare_statements_crash_server.Bug-2599` in directory 
'src/test/BugTracker-2010` itself:
+
+
+# 15:33:49 >  
+# 15:33:49 >   mserver5 
"--config=/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/etc/monetdb5.conf"
 --debug=10 --set gdk_nr_threads=0 --set 
"monet_mod_path=/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5:/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5/lib:/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5/bin"
 --set 
"gdk_dbfarm=/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/var/MonetDB5/dbfarm"
  --set mapi_open=true --set xrpc_open=true --set mapi_port=35649 --set 
xrpc_port=42384 --set monet_prompt= --set mal_listing=2 --trace  
"--dbname=mTests_src_test_BugTracker-2010" --set mal_listing=0 ; echo ; echo
  Over..
+# 15:33:49 >  
+
+# builtin opt  gdk_arch = 64bitx86_64-unknown-linux-gnu
+# builtin opt  gdk_version = 1.38.1
+# builtin opt  prefix = 
/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert
+# builtin opt  exec_prefix = ${prefix}
+# builtin opt  gdk_dbname = demo
+# builtin opt  gdk_dbfarm = ${prefix}/var/MonetDB/dbfarm
+# builtin opt  gdk_debug = 0
+# builtin opt  gdk_alloc_map = no
+# builtin opt  gdk_vmtrim = yes
+# builtin opt  monet_admin = adm
+# builtin opt  monet_prompt = >
+# builtin opt  monet_welcome = yes
+# builtin opt  monet_mod_path = ${exec_prefix}/lib64/MonetDB
+# builtin opt  monet_daemon = no
+# builtin opt  host = localhost
+# builtin opt  mapi_port = 50000
+# builtin opt  mapi_clients = 2
+# builtin opt  mapi_open = false
+# builtin opt  mapi_autosense = false
+# builtin opt  sql_debug = 0
+# builtin opt  standoff_ns = 
+# builtin opt  standoff_start = start
+# builtin opt  standoff_end = end
+# config opt   prefix = 
/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert
+# config opt   config = ${prefix}/etc/monetdb5.conf
+# config opt   prefix = 
/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert
+# config opt   exec_prefix = ${prefix}
+# config opt   gdk_dbfarm = ${prefix}/var/MonetDB5/dbfarm
+# config opt   monet_mod_path = 
${exec_prefix}/lib64/MonetDB5:${exec_prefix}/lib64/MonetDB5/lib:${exec_prefix}/lib64/MonetDB5/bin
+# config opt   mero_pidfile = ${prefix}/var/run/MonetDB/merovingian.pid
+# config opt   mero_controlport = 50001
+# config opt   sql_optimizer = default_pipe
+# config opt   minimal_pipe = inline,remap,deadcode,multiplex,garbageCollector
+# config opt   default_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mitosis,mergetable,deadcode,commonTerms,joinPath,reorder,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   nov2009_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   replication_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,replication,multiplex,garbageCollector
+# config opt   accumulator_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,accumulators,dataflow,history,multiplex,garbageCollector
+# config opt   recycler_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,deadcode,constants,commonTerms,joinPath,deadcode,recycle,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   cracker_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,selcrack,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   sidcrack_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,sidcrack,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   datacell_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,deadcode,constants,commonTerms,joinPath,datacell,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   octopus_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mitosis,mergetable,deadcode,constants,commonTerms,joinPath,octopus,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   mapreduce_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mapreduce,mergetable,deadcode,commonTerms,joinPath,reorder,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   datacyclotron_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,datacyclotron,mergetable,deadcode,constants,commonTerms,joinPath,reorder,deadcode,reduce,dataflow,history,replication,multiplex,garbageCollector
+# config opt   derive_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,derivePath,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   dictionary_pipe = 
inline,remap,dictionary,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   compression_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,compression,dataflow,history,multiplex,garbageCollector
+# cmdline opt  config = 
/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/etc/monetdb5.conf
+# cmdline opt  gdk_nr_threads = 0
+# cmdline opt  monet_mod_path = 
/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5:/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5/lib:/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5/bin
+# cmdline opt  gdk_dbfarm = 
/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/var/MonetDB5/dbfarm
+# cmdline opt  mapi_open = true
+# cmdline opt  xrpc_open = true
+# cmdline opt  mapi_port = 35649
+# cmdline opt  xrpc_port = 42384
+# cmdline opt  monet_prompt = 
+# cmdline opt  mal_listing = 2
+# cmdline opt  gdk_dbname = mTests_src_test_BugTracker-2010
+# cmdline opt  mal_listing = 0
+#warning: please don't forget to set your vault key!
+#(see 
/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/etc/monetdb5.conf)
+
+# 15:33:49 >  
+# 15:33:49 >  mclient -lsql -ftest -i -e --host=rig --port=35649 
+# 15:33:49 >  
+
+
+# 15:33:49 >  
+# 15:33:49 >  Done.
+# 15:33:49 >  
+
diff -r 1a1630dd4caa -r 1481eb763890 
sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.stable.out
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ 
b/sql/src/test/BugTracker-2010/Tests/prepare_statements_crash_server.Bug-2599.stable.out
    Thu Jul 08 15:46:13 2010 +0200
@@ -0,0 +1,55 @@
+stdout of test 'prepare_statements_crash_server.Bug-2599` in directory 
'src/test/BugTracker-2010` itself:
+
+
+# 15:33:49 >  
+# 15:33:49 >   mserver5 
"--config=/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/etc/monetdb5.conf"
 --debug=10 --set gdk_nr_threads=0 --set 
"monet_mod_path=/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5:/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5/lib:/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/lib64/MonetDB5/bin"
 --set 
"gdk_dbfarm=/ufs/manegold/_/scratch0/Monet/HG/Jun2010/prefix.--enable-strict_--disable-optimize_--enable-debug_--enable-assert/var/MonetDB5/dbfarm"
  --set mapi_open=true --set xrpc_open=true --set mapi_port=35649 --set 
xrpc_port=42384 --set monet_prompt= --set mal_listing=2 --trace  
"--dbname=mTests_src_test_BugTracker-2010" --set mal_listing=0 ; echo ; echo
  Over..
+# 15:33:49 >  
+
+# MonetDB server v5.20.2, based on kernel v1.38.2
+# Serving database 'mTests_src_test_BugTracker-2010', using 4 threads
+# Compiled for x86_64-unknown-linux-gnu/64bit with 64bit OIDs dynamically 
linked
+# Found 7.751 GiB available main-memory.
+# Copyright (c) 1993-July 2008 CWI.
+# Copyright (c) August 2008-2010 MonetDB B.V., all rights reserved
+# Visit http://monetdb.cwi.nl/ for further information
+# Listening for connection requests on mapi:monetdb://rig.ins.cwi.nl:35649/
+# MonetDB/SQL module v2.38.3 loaded
+# MonetDB/GIS module v0.18.1 loaded
+
+Ready.
+
+Over..
+
+# 15:41:23 >  
+# 15:41:23 >  mclient -lsql -ftest -i -e --host=rig --port=38276 
+# 15:41:23 >  
+
+#prepare select * from t_2599 where a>1+?;
+% .prepare,    .prepare,       .prepare # table_name
+% type,        digits, scale # name
+% varchar,     int,    int # type
+% 0,   0,      0 # length
+[ "tinyint",   8,      0       ]
+#prepare select * from t_2599 where a>2*?+1;
+% .prepare,    .prepare,       .prepare # table_name
+% type,        digits, scale # name
+% varchar,     int,    int # type
+% 0,   0,      0 # length
+[ "tinyint",   8,      0       ]
+#prepare select * from t_2599 where a>?+1;
+% .prepare,    .prepare,       .prepare # table_name
+% type,        digits, scale # name
+% varchar,     int,    int # type
+% 0,   0,      0 # length
+[ "tinyint",   8,      0       ]
+#prepare select * from t_2599 where a>1+?*2;
+% .prepare,    .prepare,       .prepare # table_name
+% type,        digits, scale # name
+% varchar,     int,    int # type
+% 0,   0,      0 # length
+[ "tinyint",   8,      0       ]
+
+# 15:41:23 >  
+# 15:41:23 >  Done.
+# 15:41:23 >  
+
_______________________________________________
Checkin-list mailing list
Checkin-list@monetdb.org
http://mail.monetdb.org/mailman/listinfo/checkin-list

Reply via email to