Save for the weekend.
This commit is contained in:
282
worker.h
282
worker.h
@@ -8,13 +8,17 @@
|
||||
#include <QFile>
|
||||
#include <QJsonObject>
|
||||
#include <QHash>
|
||||
#include <QMap>
|
||||
#include <QDebug>
|
||||
|
||||
#include <optional>
|
||||
#include <initializer_list>
|
||||
|
||||
#include "worker_thread.h"
|
||||
#include "update.h"
|
||||
#include "git/git_client.h"
|
||||
#include "ismas/ismas_client.h"
|
||||
#include "utils.h"
|
||||
|
||||
#ifdef PTU5
|
||||
#define SERIAL_PORT "ttymxc2"
|
||||
@@ -65,8 +69,6 @@ struct UpdateStatus {
|
||||
: m_updateStatus(s), m_statusDescription(d) {}
|
||||
};
|
||||
|
||||
QDebug operator<<(QDebug debug, UpdateStatus status);
|
||||
QString& operator<<(QString &str, UpdateStatus status);
|
||||
|
||||
#define ISMAS_UPDATE_REQUESTS (10)
|
||||
|
||||
@@ -109,12 +111,12 @@ class Worker : public QObject {
|
||||
UpdateStatus m_updateStatus;
|
||||
|
||||
QStringList m_filesToUpdate;
|
||||
QStringList m_filesToDownload;
|
||||
bool m_updateProcessRunning;
|
||||
int m_displayIndex;
|
||||
int m_returnCode;
|
||||
|
||||
MainWindow *m_mainWindow;
|
||||
int m_progressValue;
|
||||
bool m_withoutIsmasDirectPort;
|
||||
QString m_apismVersion;
|
||||
|
||||
@@ -135,10 +137,70 @@ class Worker : public QObject {
|
||||
int sendCloneAndCheckoutSuccess();
|
||||
int sendCloneAndCheckoutFailure();
|
||||
int sendIsmasTriggerFailure();
|
||||
int sendPullFailure();
|
||||
int sendFileUpdateFailure();
|
||||
int sendRsyncFailure();
|
||||
int sendLastVersionFailure();
|
||||
int sendSaveLogFilesFailure();
|
||||
int sendCustomerEnvironmentConfigurationFailed();
|
||||
int sendFoundFilesToUpdateSuccess();
|
||||
int sendUpdateSucceededAndActivated();
|
||||
int sendFinalResult();
|
||||
|
||||
static constexpr const int UPDATE_SUCCESS_AND_ACTIVATED = 0;
|
||||
static constexpr const int CLONE_AND_CHECKOUT_SUCCESS = 0;
|
||||
static constexpr const int CLONE_AND_CHECKOUT_FAILURE = -3;
|
||||
static constexpr const int ISMAS_TRIGGER_FAILURE = -5;
|
||||
static constexpr const int ENVIRONMENT_CONFIG_FAILURE = -6;
|
||||
static constexpr const int GIT_PULL_FAILURE = -7;
|
||||
static constexpr const int UPDATE_FILES_FAILURE = -8;
|
||||
static constexpr const int RSYNC_FAILURE = -9;
|
||||
static constexpr const int SEND_LAST_VERSION_FAILURE = -10;
|
||||
static constexpr const int SAVE_LOG_FILES_FAILURE = -11;
|
||||
|
||||
enum class UPDATE_STEP {
|
||||
STARTED = 1,
|
||||
CHECK_REPOSITORY = 2,
|
||||
CHECK_SANITY = 3,
|
||||
CHECK_SANITY_SUCCESS = 4,
|
||||
CHECK_SANITY_FAILURE = 5,
|
||||
CLONE_REPOSITORY = 6,
|
||||
CLONE_REPOSITORY_SUCCESS = 7,
|
||||
CLONE_REPOSITORY_FAILURE = 8,
|
||||
SWITCH_BRANCH = 12,
|
||||
SWITCH_BRANCH_SUCCESS = 13,
|
||||
SWITCH_BRANCH_FAILURE = 14,
|
||||
CHECK_ISMAS_TRIGGER = 15,
|
||||
CHECK_ISMAS_TRIGGER_SUCCESS = 23,
|
||||
CHECK_ISMAS_TRIGGER_FAILURE = 24,
|
||||
UPDATE_REPOSITORY = 25,
|
||||
UPDATE_REPOSITORY_SUCCESS = 28,
|
||||
UPDATE_REPOSITORY_FAILURE = 29,
|
||||
CHECK_FOR_REPOSITORY_CHANGES = 30,
|
||||
CHECK_FOR_REPOSITORY_CHANGES_SUCCESS = 38,
|
||||
CHECK_FOR_REPOSITORY_CHANGES_FAILURE = 39,
|
||||
APPLY_REPOSITORY_CHANGES = 40,
|
||||
DOWNLOAD_CONFIG_FILE = 41,
|
||||
DOWNLOAD_CONFIG_FILE_SUCCESS = 63,
|
||||
DOWNLOAD_CONFIG_FILE_FAILURE = 64,
|
||||
DOWNLOAD_DEVICE_CONTROLLER = 65,
|
||||
DOWNLOAD_DEVICE_CONTROLLER_SUCCESS = 86,
|
||||
DOWNLOAD_DEVICE_CONTROLLER_FAILURE = 87,
|
||||
APPLY_REPOSITORY_CHANGES_SUCCESS = 88,
|
||||
APPLY_REPOSITORY_CHANGES_FAILURE = 89,
|
||||
SYNC_CUSTOMER_REPOSITORY = 90,
|
||||
SYNC_CUSTOMER_REPOSITORY_SUCCESS = 91,
|
||||
SYNC_CUSTOMER_REPOSITORY_FAILURE = 92,
|
||||
SAVE_LOGS = 94,
|
||||
SAVE_LOGS_SUCCESS = 95,
|
||||
SAVE_LOGS_FAILURE = 96,
|
||||
SEND_LAST_VERSION = 97,
|
||||
UPDATE_SUCCEEDED = 98,
|
||||
UPDATE_FAILED = 99,
|
||||
FINISHED = 100
|
||||
};
|
||||
|
||||
static Worker const *instance;
|
||||
|
||||
public:
|
||||
static QString getATBUpdateToolYoctoVersion();
|
||||
@@ -165,6 +227,7 @@ public:
|
||||
hwinf *getPlugin();
|
||||
hwinf const *getPlugin() const;
|
||||
void setProgress(int progress);
|
||||
void displayProgressInMainWindow(int progress);
|
||||
void startProgressLoop();
|
||||
void stopProgressLoop();
|
||||
|
||||
@@ -183,15 +246,6 @@ public:
|
||||
MainWindow *mainWindow() { return m_mainWindow; }
|
||||
MainWindow const *mainWindow() const { return m_mainWindow; }
|
||||
|
||||
//friend QDebug operator<<(QDebug debug, Worker const &w) {
|
||||
// Q_UNUSED(w);
|
||||
// return debug;
|
||||
//}
|
||||
//friend QString& operator<<(QString &str, Worker const &w) {
|
||||
// Q_UNUSED(w);
|
||||
// return str;
|
||||
//}
|
||||
|
||||
signals:
|
||||
void appendText(QString, QString suffix = "");
|
||||
void replaceLast(QString, QString);
|
||||
@@ -209,16 +263,210 @@ public slots:
|
||||
private slots:
|
||||
bool updateTriggerSet(int progress);
|
||||
bool customerEnvironment(int progress);
|
||||
bool filesToUpdate();
|
||||
bool updateFiles(quint8 percent);
|
||||
bool syncCustomerRepositoryAndFS();
|
||||
bool sendIsmasLastVersionNotification();
|
||||
bool saveLogFile();
|
||||
bool filesToUpdate(int progress);
|
||||
bool updateFiles(int percent);
|
||||
bool syncCustomerRepositoryAndFS(int progress);
|
||||
bool sendIsmasLastVersionNotification(int progress);
|
||||
bool saveLogFile(int progress);
|
||||
|
||||
private:
|
||||
PSAInstalled getPSAInstalled();
|
||||
void privateUpdate();
|
||||
std::optional<QString> getApismVersion();
|
||||
void printProgress(UPDATE_STEP step);
|
||||
|
||||
friend QDebug operator<<(QDebug debug, UPDATE_STEP step) {
|
||||
if (!Worker::instance) {
|
||||
return debug;
|
||||
}
|
||||
|
||||
static const QMap<UPDATE_STEP, const char*> smap (
|
||||
std::initializer_list<std::pair<UPDATE_STEP, const char*>>{
|
||||
#define INSERT_ELEMENT(p) std::pair(p, #p)
|
||||
INSERT_ELEMENT(UPDATE_STEP::STARTED),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_REPOSITORY),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_SANITY),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_SANITY_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_SANITY_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CLONE_REPOSITORY),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CLONE_REPOSITORY_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CLONE_REPOSITORY_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SWITCH_BRANCH),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SWITCH_BRANCH_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SWITCH_BRANCH_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_ISMAS_TRIGGER),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_ISMAS_TRIGGER_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_ISMAS_TRIGGER_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::UPDATE_REPOSITORY),
|
||||
INSERT_ELEMENT(UPDATE_STEP::UPDATE_REPOSITORY_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::UPDATE_REPOSITORY_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_FOR_REPOSITORY_CHANGES),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_FOR_REPOSITORY_CHANGES_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::CHECK_FOR_REPOSITORY_CHANGES_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::APPLY_REPOSITORY_CHANGES),
|
||||
INSERT_ELEMENT(UPDATE_STEP::DOWNLOAD_CONFIG_FILE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::DOWNLOAD_CONFIG_FILE_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::DOWNLOAD_CONFIG_FILE_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::DOWNLOAD_DEVICE_CONTROLLER),
|
||||
INSERT_ELEMENT(UPDATE_STEP::DOWNLOAD_DEVICE_CONTROLLER_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::DOWNLOAD_DEVICE_CONTROLLER_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::APPLY_REPOSITORY_CHANGES_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::APPLY_REPOSITORY_CHANGES_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SYNC_CUSTOMER_REPOSITORY),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SYNC_CUSTOMER_REPOSITORY_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SYNC_CUSTOMER_REPOSITORY_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SAVE_LOGS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SAVE_LOGS_SUCCESS),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SAVE_LOGS_FAILURE),
|
||||
INSERT_ELEMENT(UPDATE_STEP::SEND_LAST_VERSION),
|
||||
INSERT_ELEMENT(UPDATE_STEP::UPDATE_SUCCEEDED),
|
||||
INSERT_ELEMENT(UPDATE_STEP::UPDATE_FAILED),
|
||||
INSERT_ELEMENT(UPDATE_STEP::FINISHED)
|
||||
#undef INSERT_ELEMENT
|
||||
});
|
||||
|
||||
switch (step) {
|
||||
case UPDATE_STEP::STARTED:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_REPOSITORY:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_SANITY:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_SANITY_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_SANITY_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::CLONE_REPOSITORY:
|
||||
break;
|
||||
case UPDATE_STEP::CLONE_REPOSITORY_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::CLONE_REPOSITORY_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::SWITCH_BRANCH:
|
||||
break;
|
||||
case UPDATE_STEP::SWITCH_BRANCH_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::SWITCH_BRANCH_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_ISMAS_TRIGGER:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_ISMAS_TRIGGER_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_ISMAS_TRIGGER_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::UPDATE_REPOSITORY:
|
||||
break;
|
||||
case UPDATE_STEP::UPDATE_REPOSITORY_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::UPDATE_REPOSITORY_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_FOR_REPOSITORY_CHANGES:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_FOR_REPOSITORY_CHANGES_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::CHECK_FOR_REPOSITORY_CHANGES_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::APPLY_REPOSITORY_CHANGES:
|
||||
break;
|
||||
case UPDATE_STEP::DOWNLOAD_CONFIG_FILE:
|
||||
break;
|
||||
case UPDATE_STEP::DOWNLOAD_CONFIG_FILE_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::DOWNLOAD_CONFIG_FILE_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::DOWNLOAD_DEVICE_CONTROLLER:
|
||||
break;
|
||||
case UPDATE_STEP::DOWNLOAD_DEVICE_CONTROLLER_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::DOWNLOAD_DEVICE_CONTROLLER_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::APPLY_REPOSITORY_CHANGES_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::APPLY_REPOSITORY_CHANGES_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::SYNC_CUSTOMER_REPOSITORY:
|
||||
break;
|
||||
case UPDATE_STEP::SYNC_CUSTOMER_REPOSITORY_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::SYNC_CUSTOMER_REPOSITORY_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::SAVE_LOGS:
|
||||
break;
|
||||
case UPDATE_STEP::SAVE_LOGS_SUCCESS:
|
||||
break;
|
||||
case UPDATE_STEP::SAVE_LOGS_FAILURE:
|
||||
break;
|
||||
case UPDATE_STEP::SEND_LAST_VERSION:
|
||||
break;
|
||||
case UPDATE_STEP::UPDATE_SUCCEEDED:
|
||||
break;
|
||||
case UPDATE_STEP::UPDATE_FAILED:
|
||||
break;
|
||||
case UPDATE_STEP::FINISHED:
|
||||
break;
|
||||
}
|
||||
#if 0
|
||||
case UPDATE_STEP::CHECK_SANITY:
|
||||
Utils::printUpdateStatusMsg(
|
||||
QStringList()
|
||||
<< QString("STEP 1: CHECKED SANITY OF CUSTOMER REPOSITORY %1 DONE")
|
||||
.arg(instance->m_customerRepository)
|
||||
<< QString("STEP 2: FETCH CUSTOMER REPOSITORY %1...")
|
||||
.arg(instance->m_customerRepository));
|
||||
break;
|
||||
//case UPDATE_STEP::FETCH_REPOSITORY:
|
||||
// Utils::printUpdateStatusMsg(
|
||||
// QStringList()
|
||||
// << QString("STEP 2: FETCHED CUSTOMER REPOSITORY %1 DONE")
|
||||
// .arg(instance->m_customerRepository)
|
||||
// << QString("STEP 3: CHECK ISMAS-UPDATE-TRIGGER FOR WAIT-STATUS..."));
|
||||
// break;
|
||||
case UPDATE_STEP::CHECK_ISMAS_TRIGGER:
|
||||
Utils::printUpdateStatusMsg(
|
||||
QStringList()
|
||||
<< QString("STEP 3: CHECKED ISMAS-UPDATE-TRIGGER FOR WAIT-STATUS. SUCCESS.")
|
||||
<< QString("STEP 4: CHECK-OUT BRANCH %1...").arg(instance->m_gc.branchName()));
|
||||
break;
|
||||
case UPDATE_STEP::CHECKED_OUT_BRANCH:
|
||||
Utils::printUpdateStatusMsg(
|
||||
QStringList()
|
||||
<< QString("STEP 4: CHECKED-OUT BRANCH %1 DONE")
|
||||
.arg(instance->m_gc.branchName())
|
||||
<< QString("STEP 5: COMPUTE FILES-TO-UPDATE..."));
|
||||
break;
|
||||
case UPDATE_STEP::COMPUTE_FILES_TO_UPDATE:
|
||||
Utils::printUpdateStatusMsg(
|
||||
QStringList()
|
||||
<< QString("STEP 5: COMPUTE FILES-TO-UPDATE %1 DONE")
|
||||
.arg(instance->m_filesToUpdate.join(','))
|
||||
<< QString("STEP 6: DOWNLOAD FILES-TO-DOWNLOAD %1 AND EXECUTE OPKG_COMMANDS...")
|
||||
.arg(instance->m_filesToDownload.join(',')));
|
||||
break;
|
||||
case UPDATE_STEP::DOWNLOAD_FILES_TO_UPDATE:
|
||||
Utils::printUpdateStatusMsg(
|
||||
QStringList()
|
||||
<< QString("STEP 6: DOWNLOAD FILES-TO-DOWNLOAD %1 AND EXECUTE OPKG_COMMANDS DONE")
|
||||
.arg(instance->m_filesToDownload.join(','))
|
||||
<< QString("STEP 7: SYNC CUSTOMER REPOSITORY %1 WITH FILESYSTEM...")
|
||||
.arg(instance->m_customerRepository));
|
||||
break;
|
||||
case UPDATE_STEP::SYNC_CUSTOMER_REPOSITORY:
|
||||
Utils::printUpdateStatusMsg(
|
||||
QStringList()
|
||||
<< QString("STEP 7: SYNC CUSTOMER REPOSITORY %1 WITH FILESYSTEM DONE")
|
||||
.arg(instance->m_customerRepository)
|
||||
<< QString("STEP 8: SEND-LAST-VERSION TO ISMAS..."));
|
||||
break;
|
||||
case UPDATE_STEP::UPDATE_SUCCESS:
|
||||
Utils::printUpdateStatusMsg(
|
||||
QStringList()
|
||||
<< QString("STEP 9: SAVE-LOG-FILES (FUTURE USE) DONE")
|
||||
<< QString("STEP 10: MARK UPDATE AS SUCCESSFUL AND ACTIVE..."));
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
return debug;
|
||||
}
|
||||
};
|
||||
|
||||
#endif // WORKER_H_INCLUDED
|
||||
|
Reference in New Issue
Block a user