Added: #1440 Build task finished result handling

--HG--
branch : build_pipeline_v3
hg/feature/build_pipeline_v3
kaetemi 13 years ago
parent 11038a8832
commit 70c7dd27cd

@ -39,6 +39,27 @@
namespace PIPELINE { namespace PIPELINE {
enum TProcessResult
{
/// Invalid state.
FINISH_NOT = 0,
/// Successfully built.
FINISH_SUCCESS = 1,
/// Built successfully with warnings.
FINISH_WARNING = 2,
/// Build failed.
FINISH_ERROR = 3,
/// Task aborted by slave. For internal usage only.
FINISH_ABORT = 4,
/// Task rejected by slave. For internal usage only.
FINISH_REJECT = 5,
};
/** /**
* \brief IPipelineProcess * \brief IPipelineProcess
* \date 2012-03-03 09:22GMT * \date 2012-03-03 09:22GMT

@ -48,11 +48,11 @@ namespace PIPELINE {
enum TFileState enum TFileState
{ {
Unknown = 0, STATE_UNKNOWN = 0,
Success = 1, STATE_SUCCESS = 1,
Warning = 2, STATE_WARNING = 2,
Error = 3, STATE_ERROR = 3,
Removal = 4, STATE_REMOVAL = 4,
}; };
/// Suffix for metafiles that contain the CRC32 etc /// Suffix for metafiles that contain the CRC32 etc

@ -44,6 +44,7 @@
#include "database_status.h" #include "database_status.h"
#include "build_task_queue.h" #include "build_task_queue.h"
#include "pipeline_workspace.h" #include "pipeline_workspace.h"
#include "../plugin_library/pipeline_process.h"
using namespace std; using namespace std;
using namespace NLMISC; using namespace NLMISC;
@ -425,43 +426,62 @@ public:
/////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////
/// When the slave task finishes, with or without error /// When the slave task finishes, with or without error
virtual void slaveFinishedBuildTask(NLNET::IModuleProxy *sender, uint8 errorLevel) virtual void slaveFinishedBuildTask(NLNET::IModuleProxy *sender, uint8 errorLevel, const std::string &errorMessage)
{ {
// TODO //m_SlavesMutex.lock();
TSlaveMap::iterator slaveIt = m_Slaves.find(sender);
if (slaveIt == m_Slaves.end()) { nlerror("Received 'slaveFinishedBuildTask' from unknown slave at '%s'", sender->getModuleName().c_str()); m_Slaves.erase(sender); /*m_SlavesMutex.unlock();*/ return; }
CSlave *slave = slaveIt->second;
//m_SlavesMutex.unlock();
switch ((TProcessResult)errorLevel)
{
case FINISH_WARNING:
case FINISH_SUCCESS:
m_BuildTaskQueue.successTask(slave->ActiveTaskId);
break;
case FINISH_ERROR:
m_BuildTaskQueue.erroredTask(slave->ActiveTaskId);
break;
default:
nlerror("Slave returned bad error level");
break;
}
notifyTerminalTaskState(slave->ActiveTaskId, (TProcessResult)errorLevel, errorMessage);
slave->ActiveTaskId = 0;
} }
/// When the user aborts slave-side, when slave-side exits, etc (assume the master requested abort or the slave crashed) /// When the user aborts slave-side, when slave-side exits, etc (assume the master requested abort or the slave crashed)
virtual void slaveAbortedBuildTask(NLNET::IModuleProxy *sender) virtual void slaveAbortedBuildTask(NLNET::IModuleProxy *sender)
{ {
// TODO
//m_SlavesMutex.lock(); //m_SlavesMutex.lock();
TSlaveMap::iterator slaveIt = m_Slaves.find(sender); TSlaveMap::iterator slaveIt = m_Slaves.find(sender);
if (slaveIt == m_Slaves.end()) { nlerror("Received 'slaveAbortedBuildTask' from unknown slave at '%s'", sender->getModuleName().c_str()); m_Slaves.erase(sender); /*m_SlavesMutex.unlock();*/ return; } if (slaveIt == m_Slaves.end()) { nlerror("Received 'slaveAbortedBuildTask' from unknown slave at '%s'", sender->getModuleName().c_str()); m_Slaves.erase(sender); /*m_SlavesMutex.unlock();*/ return; }
CSlave *slave = slaveIt->second; CSlave *slave = slaveIt->second;
//m_SlavesMutex.unlock(); //m_SlavesMutex.unlock();
m_BuildTaskQueue.abortedTask(slave->ActiveTaskId); m_BuildTaskQueue.abortedTask(slave->ActiveTaskId);
notifyTerminalTaskState(slave->ActiveTaskId, FINISH_ABORT, "The task has been aborted");
slave->ActiveTaskId = 0; slave->ActiveTaskId = 0;
// --slave->SaneBehaviour; // legal behaviour
// slave->TimeOutStamp = NLMISC::CTime::getSecondsSince1970() + 30; // timeout for 30 seconds on this slave // no timeout
// CInfoFlags::getInstance()->addFlag(PIPELINE_INFO_SLAVE_ABORTED); // don't keep a count
// TODO
} }
// in fact slaves are not allowed to refuse tasks, but they may do this if the user is toying around with the slave service // in fact slaves are not allowed to refuse tasks, but they may do this if the user is toying around with the slave service
virtual void slaveRefusedBuildTask(NLNET::IModuleProxy *sender) virtual void slaveRefusedBuildTask(NLNET::IModuleProxy *sender)
{ {
// TODO
//m_SlavesMutex.lock(); //m_SlavesMutex.lock();
TSlaveMap::iterator slaveIt = m_Slaves.find(sender); TSlaveMap::iterator slaveIt = m_Slaves.find(sender);
if (slaveIt == m_Slaves.end()) { nlerror("Received 'slaveRefusedBuildTask' from unknown slave at '%s'", sender->getModuleName().c_str()); m_Slaves.erase(sender); /*m_SlavesMutex.unlock();*/ return; } if (slaveIt == m_Slaves.end()) { nlerror("Received 'slaveRefusedBuildTask' from unknown slave at '%s'", sender->getModuleName().c_str()); m_Slaves.erase(sender); /*m_SlavesMutex.unlock();*/ return; }
CSlave *slave = slaveIt->second; CSlave *slave = slaveIt->second;
//m_SlavesMutex.unlock(); //m_SlavesMutex.unlock();
m_BuildTaskQueue.rejectedTask(slave->ActiveTaskId); m_BuildTaskQueue.rejectedTask(slave->ActiveTaskId);
notifyTerminalTaskState(slave->ActiveTaskId, FINISH_REJECT, "The slave service has rejected the task. This is a programming error");
slave->ActiveTaskId = 0; slave->ActiveTaskId = 0;
--slave->SaneBehaviour; --slave->SaneBehaviour;
slave->TimeOutStamp = NLMISC::CTime::getSecondsSince1970() + 3; // timeout for 3 seconds on this slave slave->TimeOutStamp = NLMISC::CTime::getSecondsSince1970() + 3; // timeout for 3 seconds on this slave
CInfoFlags::getInstance()->addFlag(PIPELINE_INFO_SLAVE_REJECTED); CInfoFlags::getInstance()->addFlag(PIPELINE_INFO_SLAVE_REJECTED);
// TODO
} }
virtual void slaveReloadedSheets(NLNET::IModuleProxy *sender) virtual void slaveReloadedSheets(NLNET::IModuleProxy *sender)
@ -512,6 +532,16 @@ public:
/////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////
void notifyTerminalTaskState(uint32 taskId, TProcessResult errorLevel, const std::string &errorMessage)
{
nlinfo("taskId: %i, errorLevel: %i, errorMessage: %s", taskId, (uint32)errorLevel, errorMessage.c_str());
// TODO NOTIFY TERMINAL (send errorlevel as uint8 as usual)
}
///////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////
class CUpdateDatabaseStatusSlaveCallback : public CDelayedCallback class CUpdateDatabaseStatusSlaveCallback : public CDelayedCallback
{ {
public: public:

@ -8,6 +8,7 @@
<doc line=""/> <doc line=""/>
<param type="uint8" name="errorLevel" /> <param type="uint8" name="errorLevel" />
<param type="std::string" name="errorMessage" byref="true" />
</method> </method>
<method name="slaveAbortedBuildTask" msg="RE_BT_ABORTED"> <method name="slaveAbortedBuildTask" msg="RE_BT_ABORTED">
@ -33,7 +34,7 @@
<method name="vectorPushString" msg="VEC_PUSH_STR"> <method name="vectorPushString" msg="VEC_PUSH_STR">
<doc line=""/> <doc line=""/>
<param type="std::string" name="str" byref="true"/> <param type="std::string" name="str" byref="true" />
</method> </method>
<method name="updateDatabaseStatusByVector" msg="UPD_DB_ST"> <method name="updateDatabaseStatusByVector" msg="UPD_DB_ST">

@ -251,6 +251,7 @@ public:
} }
if (bothReady) if (bothReady)
{ {
m_SlaveTaskState = SOMEWHERE_INBETWEEN;
if (m_AbortRequested) if (m_AbortRequested)
{ {
nlinfo("Aborted slave task after status update"); nlinfo("Aborted slave task after status update");
@ -259,15 +260,17 @@ public:
else else
{ {
nlinfo("Slave task: Status update done"); nlinfo("Slave task: Status update done");
m_SlaveTaskState = SOMEWHERE_INBETWEEN;
// Done with the status updating, now do something fancey // Done with the status updating, now do something fancey
// ... TODO ... // ... TODO ...
// not implemented, so abort. // not implemented, so abort.
abortBuildTask(NULL); // abortBuildTask(NULL);
} }
} }
} }
break; break;
default:
finishedTask(FINISH_ERROR, "Task got lost somewhere inbetween the code of the slave service. This is a programming error. Implementation may be incomplete.");
break;
} }
// Nothing to do here, move along // Nothing to do here, move along
@ -377,6 +380,16 @@ public:
CInfoFlags::getInstance()->removeFlag(PIPELINE_INFO_BUILD_TASK); CInfoFlags::getInstance()->removeFlag(PIPELINE_INFO_BUILD_TASK);
} }
void finishedTask(TProcessResult errorLevel, const std::string &errorMessage)
{
m_ActiveProject = NULL;
m_ActiveProcess = NULL;
m_SlaveTaskState = IDLE_WAIT_MASTER;
if (m_Master) // else was disconnect
m_Master->slaveFinishedBuildTask(this, (uint8)errorLevel, errorMessage);
CInfoFlags::getInstance()->removeFlag(PIPELINE_INFO_BUILD_TASK);
}
/// Master or user request to abort. /// Master or user request to abort.
virtual void abortBuildTask(NLNET::IModuleProxy *sender) virtual void abortBuildTask(NLNET::IModuleProxy *sender)
{ {

@ -24,6 +24,7 @@
</method> </method>
<method name="reloadSheets" msg="RELOAD_SHEETS"> <method name="reloadSheets" msg="RELOAD_SHEETS">
<doc line=""/>
</method> </method>
<method name="enterBuildReadyState" msg="BRT_ENTER"> <method name="enterBuildReadyState" msg="BRT_ENTER">

Loading…
Cancel
Save