diff options
| author | Dan Goodliffe <dan@randomdan.homeip.net> | 2015-11-18 00:20:53 +0000 |
|---|---|---|
| committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2015-11-18 00:20:53 +0000 |
| commit | fd91e1b9f19664574e08a1fc8bf23b95a68193af (patch) | |
| tree | b3ffe6808c160491c6581ad3e6db2b30c174126e | |
| parent | Add missing doxygen comments (diff) | |
| download | libadhocutil-fd91e1b9f19664574e08a1fc8bf23b95a68193af.tar.bz2 libadhocutil-fd91e1b9f19664574e08a1fc8bf23b95a68193af.tar.xz libadhocutil-fd91e1b9f19664574e08a1fc8bf23b95a68193af.zip | |
Prevent test failed due to race condition
| -rw-r--r-- | libadhocutil/unittests/testResourcePool.cpp | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/libadhocutil/unittests/testResourcePool.cpp b/libadhocutil/unittests/testResourcePool.cpp index 8b4161e..6e62730 100644 --- a/libadhocutil/unittests/testResourcePool.cpp +++ b/libadhocutil/unittests/testResourcePool.cpp @@ -213,19 +213,24 @@ BOOST_AUTO_TEST_CASE( threading1 ) static void -acquireAndKeepFor1Second(TRPSmall * pool) +acquireAndKeepFor1Second(TRPSmall * pool, AdHoc::Semaphore & s) { auto r = pool->get(); + s.notify(); sleep(1); } BOOST_AUTO_TEST_CASE( threading2 ) { TRPSmall pool; - std::thread t1([&pool]() { acquireAndKeepFor1Second(&pool); }); - std::thread t2([&pool]() { acquireAndKeepFor1Second(&pool); }); - std::thread t3([&pool]() { acquireAndKeepFor1Second(&pool); }); - + AdHoc::Semaphore s; + std::thread t1([&pool, &s]() { acquireAndKeepFor1Second(&pool, s); }); + std::thread t2([&pool, &s]() { acquireAndKeepFor1Second(&pool, s); }); + std::thread t3([&pool, &s]() { acquireAndKeepFor1Second(&pool, s); }); + + s.wait(); + s.wait(); + s.wait(); BOOST_REQUIRE_THROW(pool.get(100), AdHoc::TimeOutOnResourcePoolT<MockResource>); BOOST_REQUIRE_EQUAL(3, pool.inUseCount()); |
