mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
MENT-2038 Assert WSREP(thd) fails in wsrep_restore_kill_after_commit
Fix wrong assertion: function wsrep_restore_kill_after_commit() asserts `WSREP(thd)`, however for the caller (wsrep_after_statement()) it is enough that the THD has an active transaction. Fixed the assertion accordingly. Signed-off-by: Julius Goryavsky <julius.goryavsky@mariadb.com>
This commit is contained in:
committed by
Julius Goryavsky
parent
479a5832f0
commit
c43db43a7c
7
mysql-test/suite/galera_sr/r/MENT-2038.result
Normal file
7
mysql-test/suite/galera_sr/r/MENT-2038.result
Normal file
@@ -0,0 +1,7 @@
|
||||
connection node_2;
|
||||
connection node_1;
|
||||
SET SESSION wsrep_on=OFF;
|
||||
BEGIN;
|
||||
BEGIN;
|
||||
COMMIT;
|
||||
SET SESSION wsrep_on=ON;
|
12
mysql-test/suite/galera_sr/t/MENT-2038.test
Normal file
12
mysql-test/suite/galera_sr/t/MENT-2038.test
Normal file
@@ -0,0 +1,12 @@
|
||||
#
|
||||
# MENT-2038: Assertion `(thd && (WSREP_PROVIDER_EXISTS_ && thd->variables.wsrep_on))'
|
||||
# failed in void wsrep_restore_kill_after_commit(THD*)
|
||||
#
|
||||
|
||||
--source include/galera_cluster.inc
|
||||
|
||||
SET SESSION wsrep_on=OFF;
|
||||
BEGIN;
|
||||
BEGIN; # If bug is present, assertion triggers during implicit commit
|
||||
COMMIT;
|
||||
SET SESSION wsrep_on=ON;
|
@@ -496,7 +496,7 @@ void wsrep_backup_kill_for_commit(THD *thd)
|
||||
|
||||
void wsrep_restore_kill_after_commit(THD *thd)
|
||||
{
|
||||
DBUG_ASSERT(WSREP(thd));
|
||||
DBUG_ASSERT(wsrep_is_active(thd));
|
||||
mysql_mutex_assert_owner(&thd->LOCK_thd_kill);
|
||||
thd->killed= thd->wsrep_abort_by_kill;
|
||||
my_free(thd->killed_err);
|
||||
|
Reference in New Issue
Block a user