Commit 361067e9 authored by monty@donna.mysql.com's avatar monty@donna.mysql.com
Browse files

Extended mysqltest with --commands and 'require'

Fixed test results.
Added mysqld variable 'have_isam'
parent 988a98c3
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -183,3 +183,4 @@ mysqld.S
mysqld.sym
.snprj/*
sql-bench/output/*
sql-bench/Results-linux/ATIS-mysql_bdb-Linux_2.2.14_my_SMP_i686
+5 −5
Original line number Diff line number Diff line
@@ -20271,7 +20271,7 @@ differ somewhat:
| flush                   | OFF                       |
| flush_time              | 0                         |
| have_bdb                | YES                       |
| have_gemeni             | NO                        |
| have_gemini             | NO                        |
| have_innobase           | YES                       |
| have_raid               | YES                       |
| have_ssl                | NO                        |
@@ -20449,9 +20449,9 @@ very little resources.
@item @code{have_bdb}
@code{YES} if @code{mysqld} supports Berkeley DB tables. @code{DISABLED}
if @code{--skip-bdb} is used.
@item @code{have_gemeni}
@code{YES} if @code{mysqld} supports Gemeni tables. @code{DISABLED}
if @code{--skip-gemeni} is used.
@item @code{have_gemini}
@code{YES} if @code{mysqld} supports Gemini tables. @code{DISABLED}
if @code{--skip-gemini} is used.
@item @code{have_innobase}
@code{YES} if @code{mysqld} supports Innobase tables. @code{DISABLED}
if @code{--skip-innobase} is used.
@@ -40052,7 +40052,7 @@ though, so Version 3.23 is not released as a stable version yet.
@item
Added option @code{--safe-show-databases}.
@item
Added @code{have_bdb}, @code{have_gemeni}, @code{have_innobase},
Added @code{have_bdb}, @code{have_gemini}, @code{have_innobase},
@code{have_raid} and @code{have_ssl} to @code{SHOW VARIABLES} to make it
easy to test for supported extensions.
@item
+482 −456
Original line number Diff line number Diff line
@@ -23,7 +23,7 @@
 *
 **/

#define MTEST_VERSION "1.0"
#define MTEST_VERSION "1.1"

#include "global.h"
#include "my_sys.h"
@@ -104,17 +104,27 @@ struct connection* cur_con, *next_con, *cons_end;
struct query
{
  char q[MAX_QUERY];
  int has_result_set;
  int first_word_len;
  int abort_on_error;
  my_bool abort_on_error, require_file;
  uint expected_errno;
  char record_file[FN_REFLEN];
  enum {Q_CONNECTION, Q_QUERY, Q_CONNECT,
  /* Add new commands before Q_UNKNOWN */
  enum { Q_CONNECTION=1, Q_QUERY, Q_CONNECT,
	 Q_SLEEP, Q_INC, Q_DEC,Q_SOURCE,
	 Q_DISCONNECT,Q_LET, Q_ECHO, Q_WHILE, Q_END_BLOCK,
	Q_SYSTEM, Q_UNKNOWN} type;
	 Q_SYSTEM, Q_RESULT, Q_REQUIRE,
	 Q_UNKNOWN, Q_COMMENT, Q_COMMENT_WITH_COMMAND} type;
};

const char *command_names[] = {
"connection", "query","connect","sleep","inc","dec","source","disconnect",
"let","echo","while","end","system","result", "require",0
};

TYPELIB command_typelib= {array_elements(command_names),"",
			  command_names};


#define DS_CHUNK   16384

typedef struct dyn_string
@@ -131,11 +141,53 @@ void dyn_string_append(DYN_STRING* ds, const char* str, int len);
int dyn_string_cmp(DYN_STRING* ds, const char* fname);
void reject_dump(const char* record_file, char* buf, int size);


static void die(const char* fmt, ...);
int close_connection(struct query* q);
VAR* var_get(char* var_name, char* var_name_end, int raw);
void verbose_msg(const char* fmt, ...);

static void close_cons()
{
  for(--next_con; next_con >= cons; --next_con)
    {
      mysql_close(&next_con->mysql);
      my_free(next_con->name, MYF(MY_ALLOW_ZERO_PTR));
    }
}

static void die(const char* fmt, ...)
{
  va_list args;
  va_start(args, fmt);
  fprintf(stderr, "%s: ", my_progname);
  vfprintf(stderr, fmt, args);
  fprintf(stderr, "\n");
  va_end(args);
  close_cons();
  exit(1);
}

static void abort_not_supported_test()
{
  fprintf(stderr, "This test is not supported by this installation\n");
  if (!silent)
    printf("skipped\n");
  close_cons();
  exit(2);
}

static void verbose_msg(const char* fmt, ...)
{
  va_list args;

  if (!verbose) return;

  va_start(args, fmt);

  fprintf(stderr, "%s: ", my_progname);
  vfprintf(stderr, fmt, args);
  fprintf(stderr, "\n");
  va_end(args);
}


void init_parser()
{
@@ -192,6 +244,8 @@ void dyn_string_append(DYN_STRING* ds, const char* str, int len)
      ds->len += len;
    }
}


int dyn_string_cmp(DYN_STRING* ds, const char* fname)
{
  MY_STAT stat_info;
@@ -214,10 +268,15 @@ int dyn_string_cmp(DYN_STRING* ds, const char* fname)
  return res;
}

int check_result(DYN_STRING* ds, const char* fname)
static int check_result(DYN_STRING* ds, const char* fname,
			my_bool require_option)
{
  int error = 0;
  switch(dyn_string_cmp(ds, fname))
  int res=dyn_string_cmp(ds, fname);

  if (res && require_option)
    abort_not_supported_test();
  switch (res)
  {
  case 0:
    break; /* ok */
@@ -304,7 +363,7 @@ int open_file(const char* name)
{
  if (*cur_file && ++cur_file == file_stack_end)
    die("Source directives are nesting too deep");
  if(!(*cur_file = fopen(name, "r")))
  if (!(*cur_file = my_fopen(name, O_RDONLY, MYF(MY_WME))))
    die("Could not read '%s': errno %d\n", name, errno);

  return 0;
@@ -438,7 +497,7 @@ int do_sleep(struct query* q)
  p = (char*)q->q + q->first_word_len;
  while(*p && isspace(*p)) p++;
  if (!*p)
    die("Missing agument in sleep\n");
    die("Missing argument in sleep\n");
  arg = p;
  t.tv_sec = atoi(arg);
  t.tv_usec = 0;
@@ -468,6 +527,17 @@ int do_sleep(struct query* q)
  return select(0,0,0,0, &t);
}

static void get_file_name(char *filename, struct query* q)
{
  char *p = (char*) q->q + q->first_word_len;
  while(*p && isspace(*p)) p++;
  strnmov(filename, p, FN_REFLEN);
  /* Remove end space */
  while (p > filename && isspace(p[-1]))
    p--;
  p[0]=0;
}


int select_connection(struct query* q)
{
@@ -619,14 +689,6 @@ int do_while(struct query* q)
  return 0;
}

void close_cons()
{
  for(--next_con; next_con >= cons; --next_con)
    {
      mysql_close(&next_con->mysql);
      my_free(next_con->name, MYF(MY_ALLOW_ZERO_PTR));
    }
}

int safe_copy_unescape(char* dest, char* src, int size)
{
@@ -683,7 +745,7 @@ int safe_copy_unescape(char* dest, char* src, int size)
int read_line(char* buf, int size)
{
  int c;
  char* p = buf, *buf_end = buf + size;
  char* p = buf, *buf_end = buf + size-1;
  int no_save = 0;
  enum {R_NORMAL, R_Q1, R_ESC_Q_Q1, R_ESC_Q_Q2,
	R_ESC_SLASH_Q1, R_ESC_SLASH_Q2,
@@ -695,7 +757,7 @@ int read_line(char* buf, int size)
    c = fgetc(*cur_file);
    if (feof(*cur_file))
    {
          fclose(*cur_file);
      my_fclose(*cur_file,MYF(0));

      if (cur_file == file_stack)
	return 1;
@@ -706,8 +768,7 @@ int read_line(char* buf, int size)
      }
    }

      switch(state)
	{
    switch(state) {
    case R_NORMAL:
      if (c == ';' || c == '{') /*  '{' allows some interesting syntax
				 *  but we don't care, as long as the
@@ -725,16 +786,16 @@ int read_line(char* buf, int size)

      break;
    case R_COMMENT:
	  no_save = 1;
      if (c == '\n')
	    state = R_LINE_START;
      {
	*p=0;
	return 0;
      }
      break;

    case R_LINE_START:
	  if(c == '#')
      if (c == '#' || c == '-')
      {
	state = R_COMMENT;
	     no_save = 1;
      }
      else if (isspace(c))
	no_save = 1;
@@ -795,6 +856,7 @@ int read_line(char* buf, int size)
    if (!no_save)
      *p++ = c;
  }
  *p=0;						/* Always end with \0 */
  return feof(*cur_file);
}

@@ -815,13 +877,25 @@ int read_query(struct query** q_ptr)
    die("Out of memory");

  q->record_file[0] = 0;
  q->require_file=0;
  q->abort_on_error = 1;
  q->has_result_set = 0;
  q->first_word_len = 0;
  q->expected_errno = 0;
  q->type = Q_UNKNOWN;
  if (read_line(buf, sizeof(buf)))
    return 1;

  if (*p == '#')
  {
    q->type = Q_COMMENT;
  }
  else if (p[0] == '-' && p[1] == '-')
  {
    q->type = Q_COMMENT_WITH_COMMAND;
    p+=2;					/* To calculate first word */
  }
  else
  {
    if (*p == '!')
    {
      q->abort_on_error = 0;
@@ -839,23 +913,22 @@ int read_query(struct query** q_ptr)
    while(*p && isspace(*p)) p++ ;
    if (*p == '@')
    {
      q->has_result_set = 1;
      p++;
      p1 = q->record_file;
      while(!isspace(c = *p) &&
	    p1 < q->record_file + sizeof(q->record_file) - 1)
	*p1++ = *p++;
      *p1 = 0;

    }

  }
  while(*p && isspace(*p)) p++;
  /* Calculate first word */
  p1 = q->q;
  while(*p && !isspace(*p))
    *p1++ = *p++;

  q->first_word_len = p1 - q->q;
  strcpy(p1, p);
  strmov(p1, p);
  parser.read_lines++;
  return 0;
}
@@ -878,31 +951,6 @@ struct option long_options[] =
  {0, 0,0,0}
};

void die(const char* fmt, ...)
{
  va_list args;
  va_start(args, fmt);
  fprintf(stderr, "%s: ", my_progname);
  vfprintf(stderr, fmt, args);
  fprintf(stderr, "\n");
  va_end(args);
  close_cons();
  exit(1);
}

void verbose_msg(const char* fmt, ...)
{
  va_list args;

  if(!verbose) return;

  va_start(args, fmt);

  fprintf(stderr, "%s: ", my_progname);
  vfprintf(stderr, fmt, args);
  fprintf(stderr, "\n");
  va_end(args);
}

static void print_version(void)
{
@@ -990,7 +1038,7 @@ int parse_args(int argc, char **argv)
	  exit(0);
	default:
	  usage();
	  exit(0);
	  exit(1);
	}
    }

@@ -1002,10 +1050,7 @@ int parse_args(int argc, char **argv)
    exit(1);
  }
  if (argc == 1)
    {
      my_free(db,MYF(MY_ALLOW_ZERO_PTR));
      db=my_strdup(*argv,MYF(MY_WME));
    }
    db= *argv;
  if (tty_password)
    pass=get_tty_password(NullS);

@@ -1042,6 +1087,7 @@ void reject_dump(const char* record_file, char* buf, int size)
  str_to_file(reject_file, buf, size);
}


int run_query(MYSQL* mysql, struct query* q)
{
  MYSQL_RES* res = 0;
@@ -1060,10 +1106,10 @@ int run_query(MYSQL* mysql, struct query* q)
    ds = &ds_tmp;
  }



  if (mysql_query(mysql, q->q))
  {
    if (q->require_file)
      abort_not_supported_test();
    if (q->abort_on_error)
      die("query '%s' failed: %s", q->q, mysql_error(mysql));
    else
@@ -1096,6 +1142,8 @@ int run_query(MYSQL* mysql, struct query* q)

  if (!(res = mysql_store_result(mysql)) && mysql_field_count(mysql))
  {
    if (q->require_file)
      abort_not_supported_test();
    if (q->abort_on_error)
      die("failed in mysql_store_result for query '%s'", q->q);
    else
@@ -1112,8 +1160,9 @@ int run_query(MYSQL* mysql, struct query* q)
  num_fields =	mysql_num_fields(res);
  for( i = 0; i < num_fields; i++)
  {
      dyn_string_append(ds, fields[i].name, 0);
    if (i)
      dyn_string_append(ds, "\t", 1);
    dyn_string_append(ds, fields[i].name, 0);
  }

  dyn_string_append(ds, "\n", 1);
@@ -1133,8 +1182,9 @@ int run_query(MYSQL* mysql, struct query* q)
	len = 4;
      }

	dyn_string_append(ds, val, len);
      if (i)
	dyn_string_append(ds, "\t", 1);
      dyn_string_append(ds, val, len);
    }

    dyn_string_append(ds, "\n", 1);
@@ -1149,7 +1199,7 @@ int run_query(MYSQL* mysql, struct query* q)
  }
  else if (q->record_file[0])
  {
      error = check_result(ds, q->record_file);
    error = check_result(ds, q->record_file, q->require_file);
  }

end:
@@ -1157,77 +1207,36 @@ int run_query(MYSQL* mysql, struct query* q)
  return error;
}

int check_first_word(struct query* q, const char* word, int len)
{
  const char* p, *p1, *end;

  if(len != q->first_word_len)
    return 0;


  p = word;
  end = p + len;
  p1 = q->q;

  for(; p < end; p++, p1++)
    if(tolower(*p) != tolower(*p1))
      return 0;

  return 1;
}

void get_query_type(struct query* q)
{
  char save;
  uint type;
  if (*q->q == '}')
  {
    q->type = Q_END_BLOCK;
    return;
  }
  if (q->type != Q_COMMENT_WITH_COMMAND)
    q->type = Q_QUERY;
  switch(q->first_word_len)
    {
    case 3:
      if(check_first_word(q, "inc", 3))
	q->type = Q_INC;
      else if(check_first_word(q, "dec", 3))
	q->type = Q_DEC;
      else if(check_first_word(q, "let", 3))
	q->type = Q_LET;
      break;
    case 4:
      if(check_first_word(q, "echo", 4))
	q->type = Q_ECHO;
      break;
    case 5:
      if(check_first_word(q, "sleep", 5))
	q->type = Q_SLEEP;
      else if(check_first_word(q, "while", 5))
	q->type = Q_WHILE;
      break;
    case 6:
      if(check_first_word(q, "source", 6))
	q->type = Q_SOURCE;
      else if(check_first_word(q, "system", 6))
	q->type = Q_SYSTEM;
      break;
    case 7:
      if(check_first_word(q, "connect", 7))
	q->type = Q_CONNECT;
      break;
    case 10:
      if(check_first_word(q, "connection", 10))
	q->type = Q_CONNECTION;
      else if(check_first_word(q, "disconnect", 10))
	q->type = Q_DISCONNECT;
      break;

  save=q->q[q->first_word_len];
  q->q[q->first_word_len]=0;
  type=find_type(q->q, &command_typelib, 0);
  q->q[q->first_word_len]=save;
  if (type > 0)
    q->type=type;				/* Found command */
}
}



int main(int argc, char** argv)
{
  int error = 0;
  struct query* q;
  my_bool require_file=0;
  char save_file[FN_REFLEN];
  save_file[0]=0;

  MY_INIT(argv[0]);
  memset(cons, 0, sizeof(cons));
@@ -1249,7 +1258,6 @@ int main(int argc, char** argv)
    *cur_file = stdin;



  if (!( mysql_init(&cur_con->mysql)))
    die("Failed in mysql_init()");

@@ -1267,13 +1275,12 @@ int main(int argc, char** argv)
  for(;!read_query(&q);)
  {
    int current_line_inc = 1, processed = 0;
      if(q->type == Q_UNKNOWN)
    if (q->type == Q_UNKNOWN || q->type == Q_COMMENT_WITH_COMMAND)
      get_query_type(q);
    if (block_ok)
    {
      processed = 1;
	  switch(q->type)
	    {
      switch (q->type) {
      case Q_CONNECT: do_connect(q); break;
      case Q_CONNECTION: select_connection(q); break;
      case Q_DISCONNECT: close_connection(q); break;
@@ -1284,7 +1291,26 @@ int main(int argc, char** argv)
      case Q_ECHO: do_echo(q); break;
      case Q_SYSTEM: do_system(q); break;
      case Q_LET: do_let(q); break;
	    case Q_QUERY: error |= run_query(&cur_con->mysql, q); break;
      case Q_QUERY:
      {
	if (save_file[0])
	{
	  strmov(q->record_file,save_file);
	  q->require_file=require_file;
	  save_file[0]=0;
	}
	error |= run_query(&cur_con->mysql, q); break;
      }
      case Q_RESULT:
	get_file_name(save_file,q);
	require_file=0;
	break;
      case Q_REQUIRE:
	get_file_name(save_file,q);
	require_file=1;
	break;
      case Q_COMMENT:				/* Ignore row */
      case Q_COMMENT_WITH_COMMAND:
      default: processed = 0; break;
      }
    }
@@ -1308,7 +1334,7 @@ int main(int argc, char** argv)
  if (result_file && ds_res.len)
  {
    if(!record)
	error |= check_result(&ds_res, result_file);
      error |= check_result(&ds_res, result_file, q->require_file);
    else
      str_to_file(result_file, ds_res.str, ds_res.len);
  }
+1 −1
Original line number Diff line number Diff line
@@ -4,7 +4,7 @@ dnl Process this file with autoconf to produce a configure script.
AC_INIT(sql/mysqld.cc)
AC_CANONICAL_SYSTEM
# The Docs Makefile.am parses this line!
AM_INIT_AUTOMAKE(mysql, 3.23.29a-gamma)
AM_INIT_AUTOMAKE(mysql, 3.23.30-gamma)
AM_CONFIG_HEADER(config.h)

PROTOCOL_VERSION=10
+1 −1
Original line number Diff line number Diff line
@@ -393,7 +393,7 @@ static int examine_log(my_string file_name, char **table_names)
	char *pos,*to;

	/* Fix if old DOS files to new format */
	for (pos=file_info.name; pos=strchr(pos,'\\') ; pos++)
	for (pos=file_info.name; (pos=strchr(pos,'\\')) ; pos++)
	  *pos= '/';

	pos=file_info.name;
Loading