common/params: support nonblocking write (#29808)
* 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
* pass prefix to asywriter
* move to params
* assert(queue.empty())
* add comment
* add todo
* test_power_monitoring: remove patch
* rm laikad.py
* fix import
---------
Co-authored-by: Adeeb Shihadeh <adeebshihadeh@gmail.com>
old-commit-hash: 3c4c4d1f7f
chrysler-long2
parent
995c951dae
commit
1d7d7b89b2
14 changed files with 111 additions and 42 deletions
@ -0,0 +1,27 @@ |
||||
#include "catch2/catch.hpp" |
||||
#define private public |
||||
#include "common/params.h" |
||||
#include "common/util.h" |
||||
|
||||
TEST_CASE("params_nonblocking_put") { |
||||
char tmp_path[] = "/tmp/asyncWriter_XXXXXX"; |
||||
const std::string param_path = mkdtemp(tmp_path); |
||||
auto param_names = {"CarParams", "IsMetric"}; |
||||
{ |
||||
Params params(param_path); |
||||
for (const auto &name : param_names) { |
||||
params.putNonBlocking(name, "1"); |
||||
// param is empty
|
||||
REQUIRE(params.get(name).empty()); |
||||
} |
||||
|
||||
// check if thread is running
|
||||
REQUIRE(params.future.valid()); |
||||
REQUIRE(params.future.wait_for(std::chrono::milliseconds(0)) == std::future_status::timeout); |
||||
} |
||||
// check results
|
||||
Params p(param_path); |
||||
for (const auto &name : param_names) { |
||||
REQUIRE(p.get(name) == "1"); |
||||
} |
||||
} |
Loading…
Reference in new issue