From 44306dad32a4d91dda7fe6663ff0034628cbbfed Mon Sep 17 00:00:00 2001 From: Manel Melaouhi Date: Tue, 16 Feb 2021 13:59:43 +0100 Subject: [PATCH] iox-#454 add method exhaustNodePorts with three optional lambda Signed-off-by: Manel Melaouhi --- .../moduletests/test_roudi_portmanager.cpp | 62 +++++++++---------- 1 file changed, 31 insertions(+), 31 deletions(-) diff --git a/iceoryx_posh/test/moduletests/test_roudi_portmanager.cpp b/iceoryx_posh/test/moduletests/test_roudi_portmanager.cpp index cdbc0b78000..31098de0d7f 100644 --- a/iceoryx_posh/test/moduletests/test_roudi_portmanager.cpp +++ b/iceoryx_posh/test/moduletests/test_roudi_portmanager.cpp @@ -159,6 +159,24 @@ class PortManager_test : public Test } } } + + void exhaustNodePorts(std::string node, + std::string process, + std::function f = + std::function()) + { + for (unsigned int i = 0U; i < iox::MAX_NODE_NUMBER; i++) + { + iox::ProcessName_t newProcessName(iox::cxx::TruncateToCapacity, process + std::to_string(i)); + iox::NodeName_t newNodeName(iox::cxx::TruncateToCapacity, node + std::to_string(i)); + auto NodePort = m_portManager->acquireNodeData(newProcessName, newNodeName); + ASSERT_FALSE(NodePort.has_error()); + if (f) + { + f(NodePort.value(), newNodeName, newProcessName); + } + } + } }; template @@ -501,20 +519,15 @@ TEST_F(PortManager_test, AcquireConditionVariablesDataAfterDestroyingPreviouslyA } } -TEST_F(PortManager_test, AcquiringMaximumNumberOfNodesWorks) +TEST_F(PortManager_test, AcquireMaxNumberOfNodePorts) { std::string process = "Process"; std::string node = "Node"; - for (unsigned int i = 0U; i < iox::MAX_NODE_NUMBER; i++) - { - iox::ProcessName_t newProcessName(iox::cxx::TruncateToCapacity, process + std::to_string(i)); - iox::NodeName_t newNodeName(iox::cxx::TruncateToCapacity, node + std::to_string(i)); - auto nodeData = m_portManager->acquireNodeData(newProcessName, newNodeName); - EXPECT_THAT(nodeData.has_error(), Eq(false)); - EXPECT_THAT(nodeData.value()->m_node, StrEq(newNodeName)); - EXPECT_THAT(nodeData.value()->m_process, StrEq(newProcessName)); - } + exhaustNodePorts(node, process, [&](auto NodePort, auto newNodeName, auto newProcessName) { + EXPECT_THAT(NodePort->m_node, StrEq(newNodeName)); + EXPECT_THAT(NodePort->m_process, StrEq(newProcessName)); + }); } TEST_F(PortManager_test, AcquiringOneMoreThanMaximumNumberOfNodesFails) @@ -523,13 +536,7 @@ TEST_F(PortManager_test, AcquiringOneMoreThanMaximumNumberOfNodesFails) std::string node = "Node"; // first acquire all possible NodeData - for (unsigned int i = 0U; i < iox::MAX_NODE_NUMBER; i++) - { - iox::ProcessName_t newProcessName(iox::cxx::TruncateToCapacity, process + std::to_string(i)); - iox::NodeName_t newNodeName(iox::cxx::TruncateToCapacity, node + std::to_string(i)); - auto nodeData = m_portManager->acquireNodeData(newProcessName, newNodeName); - ASSERT_THAT(nodeData.has_error(), Eq(false)); - } + exhaustNodePorts(node, process); // test if overflow errors get hit auto errorHandlerCalled{false}; @@ -550,13 +557,7 @@ TEST_F(PortManager_test, DeleteNodePortfromMaximumNumberandAddOneIsSuccessful) std::string node = "Node"; // first acquire all possible NodeData - for (unsigned int i = 0U; i < iox::MAX_NODE_NUMBER; i++) - { - iox::ProcessName_t newProcessName(iox::cxx::TruncateToCapacity, process + std::to_string(i)); - iox::NodeName_t newNodeName(iox::cxx::TruncateToCapacity, node + std::to_string(i)); - auto nodeData = m_portManager->acquireNodeData(newProcessName, newNodeName); - ASSERT_THAT(nodeData.has_error(), Eq(false)); - } + exhaustNodePorts(node, process); // delete one and add one NodeData should be possible now unsigned int i = 0U; @@ -578,12 +579,11 @@ TEST_F(PortManager_test, AcquireNodeDataAfterDestroyingPreviouslyAcquiredOnesIsS std::vector nodeContainer; // first acquire all possible NodeData - for (unsigned int i = 0U; i < iox::MAX_NODE_NUMBER; i++) - { - auto nodeData = m_portManager->acquireNodeData(process, node); - EXPECT_THAT(nodeData.has_error(), Eq(false)); - nodeContainer.push_back(nodeData.value()); - } + exhaustNodePorts(node, process, [&](auto NodePort, auto newNodeName, auto newProcessName) { + nodeContainer.push_back(NodePort); + EXPECT_THAT(NodePort->m_node, StrEq(newNodeName)); + EXPECT_THAT(NodePort->m_process, StrEq(newProcessName)); + }); // so now no NodeData should be available auto nodeData = m_portManager->acquireNodeData(process, node); @@ -601,7 +601,7 @@ TEST_F(PortManager_test, AcquireNodeDataAfterDestroyingPreviouslyAcquiredOnesIsS } } -TEST_F(PortManager_test, PortsDestroyInP2ChangeStatesOfPortsInProcessP1) +TEST_F(PortManager_test, PortsDestroyInProcessP2ChangeStatesOfPortsInProcessP1) { iox::ProcessName_t p1 = "myProcess1"; iox::ProcessName_t p2 = "myProcess2";