/** * Copyright (c) 2021 OceanBase * OceanBase CE is licensed under Mulan PubL v2. * You can use this software according to the terms and conditions of the Mulan PubL v2. * You may obtain a copy of Mulan PubL v2 at: * http://license.coscl.org.cn/MulanPubL-2.0 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE. * See the Mulan PubL v2 for more details. */ #include #include #include "storage/ob_row_sample_iterator.h" #include "mockcontainer/mock_ob_iterator.h" namespace oceanbase { using namespace common; using namespace storage; namespace unittest { class TestObRowSampleIterator : public ::testing::Test { public: void check_result(const char *input, const char *output, const SampleInfo &sample_info); void check_iters(ObQueryRowIterator &iter1, ObQueryRowIterator &iter2); }; void TestObRowSampleIterator::check_result(const char *input, const char *output, const SampleInfo &sample_info) { ObMockQueryRowIterator input_iter; ObMockQueryRowIterator expect_iter; ObRowSampleIterator row_sample_iterator(sample_info); ASSERT_EQ(OB_SUCCESS, input_iter.from(input)); ASSERT_EQ(OB_SUCCESS, expect_iter.from(output)); ASSERT_EQ(OB_SUCCESS, row_sample_iterator.open(input_iter)); ASSERT_TRUE(expect_iter.equals(row_sample_iterator)); } void TestObRowSampleIterator::check_iters(ObQueryRowIterator &iter1, ObQueryRowIterator &iter2) { int ret1 = OB_SUCCESS; int ret2 = OB_SUCCESS; ObStoreRow *row1 = nullptr; ObStoreRow *row2 = nullptr; while (OB_SUCCESS == ret1 && OB_SUCCESS == ret2) { ret1 = iter1.get_next_row(row1); ret2 = iter2.get_next_row(row2); if (ret1 == ret2 && OB_SUCCESS == ret1) { ASSERT_TRUE(nullptr != row1); ASSERT_TRUE(nullptr != row2); ASSERT_TRUE(ObMockIterator::equals(*row1, *row2)); } } ASSERT_EQ(OB_ITER_END, ret1); ASSERT_EQ(ret1, ret2); } void print_hash_value(int64_t hash_input, double percent = 30.0) { uint64_t hash = murmurhash(&hash_input, sizeof(int64_t), 100000); uint64_t cut_off = static_cast(static_cast(UINT64_MAX) * percent / 100.0); bool ret = hash <= cut_off; STORAGE_LOG(INFO, "hash value: ", K(hash_input), K(hash), K(cut_off), K(ret)); } TEST_F(TestObRowSampleIterator, test_sample) { SampleInfo sample_info; sample_info.method_ = SampleInfo::ROW_SAMPLE; sample_info.percent_ = 30.0; sample_info.seed_ = 100000; const char *input = "int var flag \n" "1 var1 EXIST \n" "2 var2 EXIST \n" "3 var3 EXIST \n" "4 var4 EXIST \n" "5 var5 EXIST \n"; const char *output = "int var flag \n" "2 var2 EXIST \n" "4 var4 EXIST \n"; check_result(input, output, sample_info); sample_info.percent_ = 99.99999; check_result(input, input, sample_info); } TEST_F(TestObRowSampleIterator, test_seed) { SampleInfo sample_info; sample_info.method_ = SampleInfo::ROW_SAMPLE; sample_info.percent_ = 30.0; sample_info.seed_ = 0; ObRowSampleIterator iter1(sample_info); ObRowSampleIterator iter2(sample_info); ObMockQueryRowIterator miter1; ObMockQueryRowIterator miter2; const char *input = "int var flag \n" "1 var1 EXIST \n" "2 var2 EXIST \n" "3 var3 EXIST \n" "4 var4 EXIST \n" "5 var5 EXIST \n"; ASSERT_EQ(OB_SUCCESS, miter1.from(input)); ASSERT_EQ(OB_SUCCESS, miter2.from(input)); ASSERT_EQ(OB_SUCCESS, iter1.open(miter1)); ASSERT_EQ(OB_SUCCESS, iter2.open(miter2)); check_iters(iter1, iter2); } } } int main(int argc, char **argv) { OB_LOGGER.set_log_level("INFO"); ::testing::InitGoogleTest(&argc, argv); printf("start running test\n"); return RUN_ALL_TESTS(); }