replay/route: adds retry on network failures (#31948)

pull/32063/head
Dean Lee 2 years ago committed by GitHub
parent 90a59de144
commit b8f5f50d39
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
  1. 25
      tools/replay/route.cc
  2. 2
      tools/replay/route.h

@ -59,18 +59,27 @@ bool Route::load() {
return !segments_.empty(); return !segments_.empty();
} }
bool Route::loadFromServer() { bool Route::loadFromServer(int retries) {
for (int i = 1; i <= retries; ++i) {
QString result;
QEventLoop loop; QEventLoop loop;
HttpRequest http(nullptr, !Hardware::PC()); HttpRequest http(nullptr, !Hardware::PC());
QObject::connect(&http, &HttpRequest::requestDone, [&](const QString &json, bool success, QNetworkReply::NetworkError error) { QObject::connect(&http, &HttpRequest::requestDone, [&loop, &result](const QString &json, bool success, QNetworkReply::NetworkError err) {
if (error == QNetworkReply::ContentAccessDenied || error == QNetworkReply::AuthenticationRequiredError) { result = json;
qWarning() << ">> Unauthorized. Authenticate with tools/lib/auth.py <<"; loop.exit((int)err);
}
loop.exit(success ? loadFromJson(json) : 0);
}); });
http.sendRequest(CommaApi::BASE_URL + "/v1/route/" + route_.str + "/files"); http.sendRequest(CommaApi::BASE_URL + "/v1/route/" + route_.str + "/files");
return loop.exec(); auto err = (QNetworkReply::NetworkError)loop.exec();
if (err == QNetworkReply::NoError) {
return loadFromJson(result);
} else if (err == QNetworkReply::ContentAccessDenied || err == QNetworkReply::AuthenticationRequiredError) {
rWarning(">> Unauthorized. Authenticate with tools/lib/auth.py <<");
return false;
}
rWarning("Retrying %d/%d", i, retries);
util::sleep_for(500);
}
return false;
} }
bool Route::loadFromJson(const QString &json) { bool Route::loadFromJson(const QString &json) {

@ -42,7 +42,7 @@ public:
protected: protected:
bool loadFromLocal(); bool loadFromLocal();
bool loadFromServer(); bool loadFromServer(int retries = 3);
bool loadFromJson(const QString &json); bool loadFromJson(const QString &json);
void addFileToSegment(int seg_num, const QString &file); void addFileToSegment(int seg_num, const QString &file);
RouteIdentifier route_ = {}; RouteIdentifier route_ = {};

Loading…
Cancel
Save