Skip to content

Commit

Permalink
Refs #20993: Refactor flaky test
Browse files Browse the repository at this point in the history
Signed-off-by: JesusPoderoso <[email protected]>
  • Loading branch information
JesusPoderoso committed May 24, 2024
1 parent c521caf commit 1aade3c
Showing 1 changed file with 6 additions and 12 deletions.
18 changes: 6 additions & 12 deletions test/unittest/transport/SharedMemTests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1409,20 +1409,18 @@ TEST_F(SHMTransportTests, port_not_ok_listener_recover)
thread_listener.join();
}

//! This test has been updated to avoid flakiness #20993
TEST_F(SHMTransportTests, buffer_recover)
{
auto shared_mem_manager = SharedMemManager::create(domain_name);

auto segment = shared_mem_manager->create_segment(3, 3);

shared_mem_manager->remove_port(1);
auto pub_sub1_write = shared_mem_manager->open_port(1, 8, 1000, SharedMemGlobal::Port::OpenMode::Write);

shared_mem_manager->remove_port(2);
auto pub_sub2_write = shared_mem_manager->open_port(2, 8, 1000, SharedMemGlobal::Port::OpenMode::Write);

auto sub1_read = shared_mem_manager->open_port(1, 8, 1000, SharedMemGlobal::Port::OpenMode::ReadExclusive);

auto sub2_read = shared_mem_manager->open_port(2, 8, 1000, SharedMemGlobal::Port::OpenMode::ReadExclusive);

bool exit_listeners = false;
Expand Down Expand Up @@ -1461,10 +1459,7 @@ TEST_F(SHMTransportTests, buffer_recover)

if (buffer)
{
{
std::lock_guard<SharedMemSegment::mutex> lock(received_mutex);
listener2_recv_count.fetch_add(1);
}
listener2_recv_count.fetch_add(1);
std::this_thread::sleep_for(std::chrono::milliseconds(listener2_sleep_ms));
buffer.reset();
received_cv.notify_one();
Expand All @@ -1477,7 +1472,7 @@ TEST_F(SHMTransportTests, buffer_recover)

bool is_port_ok = false;

while (listener1_recv_count.load() < 16u)
while (listener2_recv_count.load() < 32u)
{
{
// The segment should never overflow
Expand Down Expand Up @@ -1506,14 +1501,13 @@ TEST_F(SHMTransportTests, buffer_recover)
}
}

// The slow listener is 4 times slower than the fast one
ASSERT_LT(listener1_recv_count.load() * 3, listener2_recv_count.load());
ASSERT_GT(listener1_recv_count.load(), listener2_recv_count.load() / 5);
std::cout << "Test1:"
<< " Listener1_recv_count " << listener1_recv_count.load()
<< " Listener2_recv_count " << listener2_recv_count.load()
<< std::endl;

// The slow listener is 4 times slower than the fast one
EXPECT_LT(listener1_recv_count.load() * 3, listener2_recv_count.load());
EXPECT_GE(listener1_recv_count.load() * 4, listener2_recv_count.load());
// Test 2 (with port overflow)
listener2_sleep_ms = 0u;
send_counter = 0u;
Expand Down

0 comments on commit 1aade3c

Please sign in to comment.