From cfd4300da7cff949ee28e3b9f86287322f9d2efe Mon Sep 17 00:00:00 2001 From: Egor Pugin Date: Wed, 6 Mar 2024 02:27:13 +0300 Subject: [PATCH] [command][service] Set short timeout explicitly. --- src/sw/client/common/cl.yml | 3 +++ src/sw/client/common/command/service.cpp | 21 +++++++++++++++++---- 2 files changed, 20 insertions(+), 4 deletions(-) diff --git a/src/sw/client/common/cl.yml b/src/sw/client/common/cl.yml index 5585e0ba..6d3a3b95 100644 --- a/src/sw/client/common/cl.yml +++ b/src/sw/client/common/cl.yml @@ -967,6 +967,9 @@ command_line: run: type: bool desc: run upgrade commands immediately + short_timeouts: + type: bool + desc: do not wait for http responses for a default amount of time git_sources: type: path desc: "Specify git sources file to read from. Each file specifies as follow: \"source url\" \"tag\"." diff --git a/src/sw/client/common/command/service.cpp b/src/sw/client/common/command/service.cpp index e9ef1de2..de34a9b0 100644 --- a/src/sw/client/common/command/service.cpp +++ b/src/sw/client/common/command/service.cpp @@ -23,6 +23,7 @@ DECLARE_STATIC_LOGGER(logger, "service"); namespace { bool has_prefix; +bool short_timeouts; } struct http_request_cache { @@ -38,7 +39,10 @@ struct http_request_cache { data &test_url1(auto &&key_url, std::string additional_url, HttpRequest &request, bool exception = false) { auto &source_id = key_url; // d.source has real tag so it is now useful if (new_versions[source_id].http_code == 0) { - request.connect_timeout = 1; + if (short_timeouts) + { + request.connect_timeout = 1; + } request.url = key_url + additional_url; try { @@ -50,7 +54,10 @@ struct http_request_cache { { std::string err = e.what(); boost::to_lower(err); - new_versions[source_id].http_code = err.contains("timeout") ? 1 : 2; + if (short_timeouts) + { + new_versions[source_id].http_code = err.contains("timeout") ? 1 : 2; + } if (exception) { throw; } @@ -301,7 +308,10 @@ void update_packages(SwClientContext &swctx) { LOG_INFO(logger, "remote: " << remote->url); auto &source_id = remote->url; // d.source has real tag so it is now useful HttpRequest request{httpSettings}; - request.timeout = 1; + if (short_timeouts) + { + request.timeout = 1; + } if (auto &ret = cache.test_url1(source_id, {}, request); ret.http_code != 200) { LOG_WARN(logger, "http " << ret.http_code << ": " << resolved.begin()->second.toString()); @@ -592,7 +602,10 @@ struct package_updater { continue; } HttpRequest request{httpSettings}; - request.timeout = 1; + if (short_timeouts) + { + request.timeout = 1; + } try { auto &cache_record = cache.test_url1(rf2.url, {}, request); if (cache_record.http_code != 200 && cache_record.http_code != 1) {