aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTor Egge <Tor.Egge@online.no>2022-03-02 10:13:49 +0100
committerTor Egge <Tor.Egge@online.no>2022-03-02 10:13:49 +0100
commit67b92c1c702e38b493759bad92df98803cf6ba99 (patch)
treec7219473827d0690c5ed6ffea2492bf7d3820bdc
parent726654b5dc5c349d9c3c4ed8abd816449cefd091 (diff)
Remove unneeded preprocessor directives.
Make stopping of readers more robust.
-rw-r--r--vespalib/src/tests/util/generationhandler_stress/generation_handler_stress_test.cpp20
1 files changed, 15 insertions, 5 deletions
diff --git a/vespalib/src/tests/util/generationhandler_stress/generation_handler_stress_test.cpp b/vespalib/src/tests/util/generationhandler_stress/generation_handler_stress_test.cpp
index 43e72ca73f8..57c765b8e44 100644
--- a/vespalib/src/tests/util/generationhandler_stress/generation_handler_stress_test.cpp
+++ b/vespalib/src/tests/util/generationhandler_stress/generation_handler_stress_test.cpp
@@ -20,6 +20,18 @@ const vespalib::string smoke_test_option = "--smoke-test";
}
+class ReadStopper {
+ std::atomic<bool> &_stop_read;
+public:
+ ReadStopper(std::atomic<bool>& stop_read)
+ : _stop_read(stop_read)
+ {
+ }
+ ~ReadStopper() {
+ _stop_read = true;
+ }
+};
+
struct WorkContext
{
std::atomic<uint64_t> _generation;
@@ -141,12 +153,12 @@ Fixture::readWork(const WorkContext &context)
void
Fixture::writeWork(uint32_t cnt, WorkContext &context)
{
+ ReadStopper read_stopper(_stopRead);
for (uint32_t i = 0; i < cnt; ++i) {
context._generation.store(_generationHandler.getNextGeneration(), std::memory_order_relaxed);
_generationHandler.incGeneration();
}
_doneWriteWork += cnt;
- _stopRead = true;
LOG(info, "done %u write work", cnt);
}
@@ -223,6 +235,7 @@ Fixture::read_indirect_work(const IndirectContext& context)
void
Fixture::write_indirect_work(uint64_t cnt, IndirectContext& context)
{
+ ReadStopper read_stopper(_stopRead);
uint32_t sleep_cnt = 0;
ASSERT_EQ(0, _generationHandler.getCurrentGeneration());
auto oldest_gen = _generationHandler.getFirstUsedGeneration();
@@ -231,7 +244,7 @@ Fixture::write_indirect_work(uint64_t cnt, IndirectContext& context)
// Hold data for gen, write new data for next_gen
auto next_gen = gen + 1;
auto *v_ptr = context.calc_value_ptr(next_gen);
- ASSERT_EQ(0u, *v_ptr) << (_stopRead = true, "");
+ ASSERT_EQ(0u, *v_ptr);
*v_ptr = next_gen;
context._value_ptr.store(v_ptr, std::memory_order_release);
_generationHandler.incGeneration();
@@ -250,7 +263,6 @@ Fixture::write_indirect_work(uint64_t cnt, IndirectContext& context)
}
}
_doneWriteWork += cnt;
- _stopRead = true;
LOG(info, "done %" PRIu64 " write work, %u sleeps", cnt, sleep_cnt);
}
@@ -262,11 +274,9 @@ Fixture::stress_test_indirect(uint64_t write_cnt)
LOG(info, "starting stress test indirect, 1 write thread, %u read threads, %" PRIu64 " writes", read_threads, write_cnt);
auto context = std::make_shared<IndirectContext>();
_writer.execute(makeLambdaTask([this, context, write_cnt]() { write_indirect_work(write_cnt, *context); }));
-#if 1
for (uint32_t i = 0; i < read_threads; ++i) {
_readers->execute(makeLambdaTask([this, context]() { read_indirect_work(*context); }));
}
-#endif
_writer.sync();
_readers->sync();
}