From ab14529843d7bbb3a0d0c30b163ed444afee04ed Mon Sep 17 00:00:00 2001 From: Douglas Rumbaugh Date: Mon, 29 May 2023 16:37:43 -0400 Subject: WIRS Query tests + fixes --- tests/wirs_tests.cpp | 207 +++++++++++++++++++++++++++++++-------------------- 1 file changed, 127 insertions(+), 80 deletions(-) (limited to 'tests/wirs_tests.cpp') diff --git a/tests/wirs_tests.cpp b/tests/wirs_tests.cpp index ba4b754..0a9b1d0 100644 --- a/tests/wirs_tests.cpp +++ b/tests/wirs_tests.cpp @@ -44,6 +44,7 @@ START_TEST(t_mbuffer_init) delete shard; } + START_TEST(t_wirs_init) { size_t n = 512; @@ -94,31 +95,6 @@ START_TEST(t_wirs_init) delete shard4; } -/* -START_TEST(t_get_lower_bound_index) -{ - size_t n = 10000; - auto mbuffer = create_double_seq_mbuffer(n); - - ck_assert_ptr_nonnull(mbuffer); - Shard* shard = new Shard(mbuffer); - - ck_assert_int_eq(shard->get_record_count(), n); - ck_assert_int_eq(shard->get_tombstone_count(), 0); - - auto tbl_records = mbuffer->sorted_output(); - for (size_t i=0; iget_record_at(i); - auto pos = shard->get_lower_bound(tbl_rec->key); - ck_assert_int_eq(shard->get_record_at(pos)->key, tbl_rec->key); - ck_assert_int_le(pos, i); - } - - delete mbuffer; - delete shard; -} - -*/ START_TEST(t_full_cancelation) { @@ -150,8 +126,7 @@ START_TEST(t_full_cancelation) END_TEST -/* -START_TEST(t_weighted_sampling) +START_TEST(t_wirs_query) { size_t n=1000; auto buffer = create_weighted_mbuffer(n); @@ -163,72 +138,156 @@ START_TEST(t_weighted_sampling) size_t k = 1000; - std::vector results; - results.reserve(k); size_t cnt[3] = {0}; + wirs_query_parms parms = {lower_key, upper_key, k}; + parms.rng = gsl_rng_alloc(gsl_rng_mt19937); + for (size_t i=0; i<1000; i++) { - WIRS::wirs_query_parms parms = {lower_key, upper_key}; - auto state = shard->get_query_state(&parms); - - shard->get_samples(state, results, lower_key, upper_key, k, g_rng); + auto state = WIRSQuery::get_query_state(shard, &parms); + auto result = WIRSQuery::query(shard, state, &parms); - for (size_t j=0; j::delete_query_state(state); + WIRSQuery::delete_query_state(state); } ck_assert(roughly_equal(cnt[0] / 1000, (double) k/4.0, k, .05)); ck_assert(roughly_equal(cnt[1] / 1000, (double) k/4.0, k, .05)); ck_assert(roughly_equal(cnt[2] / 1000, (double) k/2.0, k, .05)); + gsl_rng_free(parms.rng); delete shard; delete buffer; } END_TEST -*/ -/* -START_TEST(t_tombstone_check) +template +std::vector strip_wrapping(std::vector> vec) { + std::vector out(vec.size()); + for (size_t i=0; i(cnt + ts_cnt, true, ts_cnt); - - std::vector> tombstones; - - uint64_t key = 1000; - uint32_t val = 101; - for (size_t i = 0; i < cnt; i++) { - buffer->append({key, val, 1}); - key++; - val++; + size_t n=1000; + auto buffer = create_weighted_mbuffer(n); + + Shard* shard = new Shard(buffer); + + uint64_t lower_key = 0; + uint64_t upper_key = 5; + + size_t k = 1000; + + size_t cnt[3] = {0}; + wirs_query_parms parms = {lower_key, upper_key, k}; + parms.rng = gsl_rng_alloc(gsl_rng_mt19937); + + std::vector> results(2); + + for (size_t i=0; i<1000; i++) { + auto state1 = WIRSQuery::get_query_state(shard, &parms); + results[0] = strip_wrapping(WIRSQuery::query(shard, state1, &parms)); + + auto state2 = WIRSQuery::get_query_state(shard, &parms); + results[1] = strip_wrapping(WIRSQuery::query(shard, state2, &parms)); + + WIRSQuery::delete_query_state(state1); + WIRSQuery::delete_query_state(state2); } - // ensure that the key range doesn't overlap, so nothing - // gets cancelled. - for (size_t i=0; i::merge(results); + + ck_assert_int_eq(merged.size(), 2*k); + for (size_t i=0; iappend({tombstones[i].first, tombstones[i].second, 1, 1}); + gsl_rng_free(parms.rng); + delete shard; + delete buffer; +} +END_TEST + + +START_TEST(t_wirs_buffer_query_scan) +{ + size_t n=1000; + auto buffer = create_weighted_mbuffer(n); + + uint64_t lower_key = 0; + uint64_t upper_key = 5; + + size_t k = 1000; + + size_t cnt[3] = {0}; + wirs_query_parms parms = {lower_key, upper_key, k}; + parms.rng = gsl_rng_alloc(gsl_rng_mt19937); + + for (size_t i=0; i<1000; i++) { + auto state = WIRSQuery::get_buffer_query_state(buffer, &parms); + auto result = WIRSQuery::buffer_query(buffer, state, &parms); + + for (size_t j=0; j::delete_buffer_query_state(state); } - auto shard = new Shard(buffer); + ck_assert(roughly_equal(cnt[0] / 1000, (double) k/4.0, k, .05)); + ck_assert(roughly_equal(cnt[1] / 1000, (double) k/4.0, k, .05)); + ck_assert(roughly_equal(cnt[2] / 1000, (double) k/2.0, k, .05)); + + gsl_rng_free(parms.rng); + delete buffer; +} +END_TEST + + +START_TEST(t_wirs_buffer_query_rejection) +{ + size_t n=1000; + auto buffer = create_weighted_mbuffer(n); + + uint64_t lower_key = 0; + uint64_t upper_key = 5; + + size_t k = 1000; + + size_t cnt[3] = {0}; + wirs_query_parms parms = {lower_key, upper_key, k}; + parms.rng = gsl_rng_alloc(gsl_rng_mt19937); - for (size_t i=0; icheck_tombstone({tombstones[i].first, tombstones[i].second})); - ck_assert_int_eq(shard->get_rejection_count(), i+1); + for (size_t i=0; i<1000; i++) { + auto state = WIRSQuery::get_buffer_query_state(buffer, &parms); + auto result = WIRSQuery::buffer_query(buffer, state, &parms); + + for (size_t j=0; j::delete_buffer_query_state(state); } - delete shard; + ck_assert(roughly_equal(cnt[0] / 1000, (double) k/4.0, k, .05)); + ck_assert(roughly_equal(cnt[1] / 1000, (double) k/4.0, k, .05)); + ck_assert(roughly_equal(cnt[2] / 1000, (double) k/2.0, k, .05)); + + gsl_rng_free(parms.rng); delete buffer; } END_TEST -*/ + Suite *unit_testing() { @@ -241,29 +300,17 @@ Suite *unit_testing() suite_add_tcase(unit, create); - TCase *bounds = tcase_create("de:WIRS::get_{lower,upper}_bound Testing"); - //tcase_add_test(bounds, t_get_lower_bound_index); - tcase_set_timeout(bounds, 100); - suite_add_tcase(unit, bounds); - - TCase *tombstone = tcase_create("de:WIRS::tombstone cancellation Testing"); tcase_add_test(tombstone, t_full_cancelation); suite_add_tcase(unit, tombstone); - /* - TCase *sampling = tcase_create("de:WIRS::sampling Testing"); - tcase_add_test(sampling, t_weighted_sampling); + TCase *sampling = tcase_create("de:WIRS::WIRSQuery Testing"); + tcase_add_test(sampling, t_wirs_query); + tcase_add_test(sampling, t_wirs_query_merge); + tcase_add_test(sampling, t_wirs_buffer_query_rejection); + tcase_add_test(sampling, t_wirs_buffer_query_scan); suite_add_tcase(unit, sampling); - */ - - - /* - TCase *check_ts = tcase_create("de::WIRS::check_tombstone Testing"); - tcase_add_test(check_ts, t_tombstone_check); - suite_add_tcase(unit, check_ts); - */ return unit; } -- cgit v1.2.3