mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2025-10-15 09:31:45 +00:00
SDK: Add test for timeout, concurrent call. Implement TODOs
This commit is contained in:
committed by
Dennis Klein
parent
dc55272317
commit
5d535163f1
@@ -21,26 +21,24 @@ TEST_F(Topology, Construction)
|
||||
fair::mq::sdk::Topology topo(mDDSTopo, mDDSSession);
|
||||
}
|
||||
|
||||
TEST_F(Topology, ChangeState_async1)
|
||||
TEST_F(Topology, ChangeStateAsync)
|
||||
{
|
||||
using fair::mq::sdk::Topology;
|
||||
using fair::mq::sdk::TopologyTransition;
|
||||
|
||||
Topology topo(mDDSTopo, mDDSSession);
|
||||
fair::mq::tools::Semaphore blocker;
|
||||
topo.ChangeState(TopologyTransition::Stop, [&blocker](Topology::ChangeStateResult result) {
|
||||
topo.ChangeState(TopologyTransition::Stop, [&blocker, &topo](Topology::ChangeStateResult result) {
|
||||
LOG(info) << result;
|
||||
EXPECT_EQ(result.rc, fair::mq::AsyncOpResultCode::Ok);
|
||||
// TODO add the helper to check state consistency
|
||||
for (const auto& e : result.state) {
|
||||
EXPECT_EQ(e.second.state, fair::mq::sdk::DeviceState::Ready);
|
||||
}
|
||||
EXPECT_NO_THROW(fair::mq::sdk::AggregateState(result.state));
|
||||
EXPECT_EQ(fair::mq::sdk::StateEqualsTo(result.state, fair::mq::sdk::DeviceState::Ready), true);
|
||||
blocker.Signal();
|
||||
});
|
||||
blocker.Wait();
|
||||
}
|
||||
|
||||
TEST_F(Topology, ChangeState_sync)
|
||||
TEST_F(Topology, ChangeStateSync)
|
||||
{
|
||||
using fair::mq::sdk::Topology;
|
||||
using fair::mq::sdk::TopologyTransition;
|
||||
@@ -49,27 +47,41 @@ TEST_F(Topology, ChangeState_sync)
|
||||
auto result(topo.ChangeState(TopologyTransition::Stop));
|
||||
|
||||
EXPECT_EQ(result.rc, fair::mq::AsyncOpResultCode::Ok);
|
||||
// TODO add the helper to check state consistency
|
||||
for (const auto& e : result.state) {
|
||||
EXPECT_EQ(e.second.state, fair::mq::sdk::DeviceState::Ready);
|
||||
}
|
||||
EXPECT_NO_THROW(fair::mq::sdk::AggregateState(result.state));
|
||||
EXPECT_EQ(fair::mq::sdk::StateEqualsTo(result.state, fair::mq::sdk::DeviceState::Ready), true);
|
||||
}
|
||||
// TEST_F(Topology, Timeout)
|
||||
// {
|
||||
// using fair::mq::sdk::Topology;
|
||||
// using fair::mq::sdk::TopologyTransition;
|
||||
|
||||
// Topology topo(mDDSTopo, mDDSSession);
|
||||
// Topology::ChangeStateResult r;
|
||||
// fair::mq::tools::Semaphore blocker;
|
||||
// topo.ChangeState(TopologyTransition::End, [&](Topology::ChangeStateResult result) {
|
||||
// LOG(info) << result;
|
||||
// blocker.Signal();
|
||||
// }, std::chrono::milliseconds(100));
|
||||
// blocker.Wait();
|
||||
// for (const auto& e : r.rc) {
|
||||
// EXPECT_EQ(e.second.state, fair::mq::sdk::DeviceState::Ok);
|
||||
// }
|
||||
// }
|
||||
TEST_F(Topology, ChangeStateConcurrent)
|
||||
{
|
||||
using fair::mq::sdk::Topology;
|
||||
using fair::mq::sdk::TopologyTransition;
|
||||
|
||||
Topology topo(mDDSTopo, mDDSSession);
|
||||
fair::mq::tools::Semaphore blocker;
|
||||
topo.ChangeState(TopologyTransition::Stop, [&blocker](Topology::ChangeStateResult result) {
|
||||
LOG(info) << "result for valid ChangeState: " << result;
|
||||
blocker.Signal();
|
||||
});
|
||||
topo.ChangeState(TopologyTransition::Stop, [&blocker](Topology::ChangeStateResult result) {
|
||||
LOG(info) << "result for invalid ChangeState: " << result;
|
||||
EXPECT_EQ(result.rc, fair::mq::AsyncOpResultCode::Error);
|
||||
});
|
||||
blocker.Wait();
|
||||
}
|
||||
|
||||
TEST_F(Topology, ChangeStateTimeout)
|
||||
{
|
||||
using fair::mq::sdk::Topology;
|
||||
using fair::mq::sdk::TopologyTransition;
|
||||
|
||||
Topology topo(mDDSTopo, mDDSSession);
|
||||
fair::mq::tools::Semaphore blocker;
|
||||
topo.ChangeState(TopologyTransition::End, [&](Topology::ChangeStateResult result) {
|
||||
LOG(info) << result;
|
||||
EXPECT_EQ(result.rc, fair::mq::AsyncOpResultCode::Timeout);
|
||||
blocker.Signal();
|
||||
}, std::chrono::milliseconds(1));
|
||||
blocker.Wait();
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
Reference in New Issue
Block a user