mirror of
https://github.com/MariaDB/server.git
synced 2025-01-19 13:32:33 +01:00
Merge tulin@bk-internal.mysql.com:/home/bk/mysql-5.0-ndb
into poseidon.ndb.mysql.com:/home/tomas/mysql-5.0-ndb
This commit is contained in:
commit
04cd65b91a
3 changed files with 77 additions and 1 deletions
|
@ -5344,7 +5344,8 @@ void Dbtc::execTC_COMMITREQ(Signal* signal)
|
|||
const Uint32 transId1 = regApiPtr->transid[0];
|
||||
const Uint32 transId2 = regApiPtr->transid[1];
|
||||
Uint32 errorCode = 0;
|
||||
|
||||
|
||||
regApiPtr->m_exec_flag = 1;
|
||||
switch (regApiPtr->apiConnectstate) {
|
||||
case CS_STARTED:
|
||||
tcConnectptr.i = regApiPtr->firstTcConnect;
|
||||
|
|
|
@ -344,6 +344,71 @@ err:
|
|||
return NDBT_FAILED;
|
||||
}
|
||||
|
||||
int runLateCommit(NDBT_Context* ctx, NDBT_Step* step){
|
||||
int result = NDBT_OK;
|
||||
int loops = ctx->getNumLoops();
|
||||
int records = ctx->getNumRecords();
|
||||
NdbRestarter restarter;
|
||||
HugoOperations hugoOps(*ctx->getTab());
|
||||
Ndb* pNdb = GETNDB(step);
|
||||
|
||||
int i = 0;
|
||||
while(i<loops && result != NDBT_FAILED && !ctx->isTestStopped()){
|
||||
g_info << i << ": ";
|
||||
|
||||
if(hugoOps.startTransaction(pNdb) != 0)
|
||||
return NDBT_FAILED;
|
||||
|
||||
if(hugoOps.pkUpdateRecord(pNdb, 1) != 0)
|
||||
return NDBT_FAILED;
|
||||
|
||||
if(hugoOps.execute_NoCommit(pNdb) != 0)
|
||||
return NDBT_FAILED;
|
||||
|
||||
Uint32 transNode= hugoOps.getTransaction()->getConnectedNodeId();
|
||||
int id = i % restarter.getNumDbNodes();
|
||||
int nodeId;
|
||||
while((nodeId = restarter.getDbNodeId(id)) == transNode)
|
||||
id = (id + 1) % restarter.getNumDbNodes();
|
||||
|
||||
ndbout << "Restart node " << nodeId << endl;
|
||||
|
||||
restarter.restartOneDbNode(nodeId,
|
||||
/** initial */ false,
|
||||
/** nostart */ true,
|
||||
/** abort */ true);
|
||||
|
||||
restarter.waitNodesNoStart(&nodeId, 1);
|
||||
|
||||
int res;
|
||||
if(i & 1)
|
||||
res= hugoOps.execute_Commit(pNdb);
|
||||
else
|
||||
res= hugoOps.execute_Rollback(pNdb);
|
||||
|
||||
ndbout_c("res= %d", res);
|
||||
|
||||
hugoOps.closeTransaction(pNdb);
|
||||
|
||||
restarter.startNodes(&nodeId, 1);
|
||||
restarter.waitNodesStarted(&nodeId, 1);
|
||||
|
||||
if(i & 1)
|
||||
{
|
||||
if(res != 286)
|
||||
return NDBT_FAILED;
|
||||
}
|
||||
else
|
||||
{
|
||||
if(res != 0)
|
||||
return NDBT_FAILED;
|
||||
}
|
||||
i++;
|
||||
}
|
||||
|
||||
return NDBT_OK;
|
||||
}
|
||||
|
||||
NDBT_TESTSUITE(testNodeRestart);
|
||||
TESTCASE("NoLoad",
|
||||
"Test that one node at a time can be stopped and then restarted "\
|
||||
|
@ -600,6 +665,12 @@ TESTCASE("CommittedRead",
|
|||
STEP(runDirtyRead);
|
||||
FINALIZER(runClearTable);
|
||||
}
|
||||
TESTCASE("LateCommit",
|
||||
"Test commit after node failure"){
|
||||
INITIALIZER(runLoadTable);
|
||||
STEP(runLateCommit);
|
||||
FINALIZER(runClearTable);
|
||||
}
|
||||
NDBT_TESTSUITE_END(testNodeRestart);
|
||||
|
||||
int main(int argc, const char** argv){
|
||||
|
|
|
@ -69,6 +69,10 @@ max-time: 2500
|
|||
cmd: testNodeRestart
|
||||
args: -n CommittedRead T1
|
||||
|
||||
max-time: 2500
|
||||
cmd: testNodeRestart
|
||||
args: -n LateCommit T1
|
||||
|
||||
max-time: 2500
|
||||
cmd: testNodeRestart
|
||||
args: -n Terror T6 T13
|
||||
|
|
Loading…
Reference in a new issue