params: safe and efficient async writing parameters (#25912)
* Safe and efficient asynchronous writing parameters * call putNonBlocking in locationd * remove space * ->AsyncWriter * remove semicolon * use member function * asyc write multiple times * add test case for AsyncWriter * merge master * add missing include * public * cleanup * create once * cleanup * update that * explicit waiting * improve test case --------- Co-authored-by: Adeeb Shihadeh <adeebshihadeh@gmail.com>pull/29798/head
parent
0afcf12368
commit
0d797f4e8b
14 changed files with 123 additions and 39 deletions
@ -0,0 +1,27 @@ |
||||
#include "catch2/catch.hpp" |
||||
#define private public |
||||
#include "common/params.h" |
||||
#include "common/util.h" |
||||
|
||||
TEST_CASE("Params/asyncWriter") { |
||||
char tmp_path[] = "/tmp/asyncWriter_XXXXXX"; |
||||
const std::string param_path = mkdtemp(tmp_path); |
||||
Params params(param_path); |
||||
auto param_names = {"CarParams", "IsMetric"}; |
||||
{ |
||||
AsyncWriter async_writer; |
||||
for (const auto &name : param_names) { |
||||
async_writer.queue({param_path, name, "1"}); |
||||
// param is empty
|
||||
REQUIRE(params.get(name).empty()); |
||||
} |
||||
|
||||
// check if thread is running
|
||||
REQUIRE(async_writer.future.valid()); |
||||
REQUIRE(async_writer.future.wait_for(std::chrono::milliseconds(0)) == std::future_status::timeout); |
||||
} |
||||
// check results
|
||||
for (const auto &name : param_names) { |
||||
REQUIRE(params.get(name) == "1"); |
||||
} |
||||
} |
Loading…
Reference in new issue