Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
5fa2cea1
Commit
5fa2cea1
authored
Sep 07, 2005
by
msvensson@neptunus.(none)
Browse files
Options
Browse Files
Download
Plain Diff
Merge bk-internal.mysql.com:/home/bk/mysql-4.1
into neptunus.(none):/home/msvensson/mysql/mysql-4.1
parents
81948e62
5c8d457e
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
52 additions
and
27 deletions
+52
-27
client/mysqltest.c
client/mysqltest.c
+51
-26
mysql-test/t/mysqltest.test
mysql-test/t/mysqltest.test
+1
-1
No files found.
client/mysqltest.c
View file @
5fa2cea1
...
...
@@ -456,6 +456,7 @@ my_bool mysql_rpl_probe(MYSQL *mysql __attribute__((unused))) { return 1; }
#endif
static
void
replace_dynstr_append_mem
(
DYNAMIC_STRING
*
ds
,
const
char
*
val
,
int
len
);
static
int
handle_no_error
(
struct
st_query
*
q
);
static
void
do_eval
(
DYNAMIC_STRING
*
query_eval
,
const
char
*
query
)
{
...
...
@@ -2907,22 +2908,9 @@ static int run_query_normal(MYSQL* mysql, struct st_query* q, int flags)
}
if
(
q
->
expected_errno
[
0
].
type
==
ERR_ERRNO
&&
q
->
expected_errno
[
0
].
code
.
errnum
!=
0
)
if
(
handle_no_error
(
q
))
{
/* Error code we wanted was != 0, i.e. not an expected success */
verbose_msg
(
"query '%s' succeeded - should have failed with errno %d..."
,
q
->
query
,
q
->
expected_errno
[
0
].
code
.
errnum
);
error
=
1
;
goto
end
;
}
else
if
(
q
->
expected_errno
[
0
].
type
==
ERR_SQLSTATE
&&
strcmp
(
q
->
expected_errno
[
0
].
code
.
sqlstate
,
"00000"
)
!=
0
)
{
/* SQLSTATE we wanted was != "00000", i.e. not an expected success */
verbose_msg
(
"query '%s' succeeded - should have failed with sqlstate %s..."
,
q
->
query
,
q
->
expected_errno
[
0
].
code
.
sqlstate
);
error
=
1
;
error
=
1
;
goto
end
;
}
...
...
@@ -3102,10 +3090,8 @@ static int run_query_stmt(MYSQL *mysql, struct st_query *q, int flags)
{
if
(
q
->
abort_on_error
)
{
die
(
"unable to prepare statement '%s': "
"%s (mysql_stmt_errno=%d returned=%d)"
,
query
,
mysql_stmt_error
(
stmt
),
mysql_stmt_errno
(
stmt
),
err
);
die
(
"query '%s' failed: %d: %s"
,
query
,
mysql_stmt_errno
(
stmt
),
mysql_stmt_error
(
stmt
));
}
else
{
...
...
@@ -3186,12 +3172,8 @@ static int run_query_stmt(MYSQL *mysql, struct st_query *q, int flags)
}
/* If we got here the statement was both executed and read succeesfully */
if
(
q
->
expected_errno
[
0
].
type
==
ERR_ERRNO
&&
q
->
expected_errno
[
0
].
code
.
errnum
!=
0
)
if
(
handle_no_error
(
q
))
{
verbose_msg
(
"query '%s' succeeded - should have failed with errno %d..."
,
q
->
query
,
q
->
expected_errno
[
0
].
code
.
errnum
);
error
=
1
;
goto
end
;
}
...
...
@@ -3518,8 +3500,14 @@ static int run_query_stmt_handle_error(char *query, struct st_query *q,
dynstr_append_mem
(
ds
,
"
\n
"
,
1
);
if
(
i
)
{
verbose_msg
(
"query '%s' failed with wrong errno %d instead of %d..."
,
q
->
query
,
mysql_stmt_errno
(
stmt
),
q
->
expected_errno
[
0
]);
if
(
q
->
expected_errno
[
0
].
type
==
ERR_ERRNO
)
verbose_msg
(
"query '%s' failed with wrong errno %d instead of %d..."
,
q
->
query
,
mysql_stmt_errno
(
stmt
),
q
->
expected_errno
[
0
].
code
.
errnum
);
else
verbose_msg
(
"query '%s' failed with wrong sqlstate %s instead of %s..."
,
q
->
query
,
mysql_stmt_sqlstate
(
stmt
),
q
->
expected_errno
[
0
].
code
.
sqlstate
);
return
1
;
/* Error */
}
verbose_msg
(
"query '%s' failed: %d: %s"
,
q
->
query
,
mysql_stmt_errno
(
stmt
),
...
...
@@ -3534,6 +3522,43 @@ static int run_query_stmt_handle_error(char *query, struct st_query *q,
return
0
;
}
/*
Handle absence of errors after execution
SYNOPSIS
handle_no_error()
q - context of query
RETURN VALUE
0 - OK
1 - Some error was expected from this query.
*/
static
int
handle_no_error
(
struct
st_query
*
q
)
{
DBUG_ENTER
(
"handle_no_error"
);
if
(
q
->
expected_errno
[
0
].
type
==
ERR_ERRNO
&&
q
->
expected_errno
[
0
].
code
.
errnum
!=
0
)
{
/* Error code we wanted was != 0, i.e. not an expected success */
verbose_msg
(
"query '%s' succeeded - should have failed with errno %d..."
,
q
->
query
,
q
->
expected_errno
[
0
].
code
.
errnum
);
DBUG_RETURN
(
1
);
}
else
if
(
q
->
expected_errno
[
0
].
type
==
ERR_SQLSTATE
&&
strcmp
(
q
->
expected_errno
[
0
].
code
.
sqlstate
,
"00000"
)
!=
0
)
{
/* SQLSTATE we wanted was != "00000", i.e. not an expected success */
verbose_msg
(
"query '%s' succeeded - should have failed with sqlstate %s..."
,
q
->
query
,
q
->
expected_errno
[
0
].
code
.
sqlstate
);
DBUG_RETURN
(
1
);
}
DBUG_RETURN
(
0
);
}
/****************************************************************************\
* Functions to match SQL statements that can be prepared
\****************************************************************************/
...
...
mysql-test/t/mysqltest.test
View file @
5fa2cea1
...
...
@@ -592,7 +592,7 @@ while ($num)
--
source
var
/
tmp
/
sourced1
.
sql
dec
$num
;
}
--
enable_abort_on_error
;
--
enable_abort_on_error
--
enable_query_log
# ----------------------------------------------------------------------------
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment