blob: bc0e1adc8d8fa68801d9becf0938ae02bc0d5823 [file] [log] [blame]
/*
* Copyright 2024-present Alibaba Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#pragma once
#include <memory>
#include <string>
#include <vector>
#include "gtest/gtest.h"
#include "paimon/common/types/data_field.h"
#include "paimon/core/key_value.h"
#include "paimon/core/utils/fields_comparator.h"
#include "paimon/testing/utils/binary_row_generator.h"
#include "paimon/testing/utils/testharness.h"
namespace paimon::test {
class KeyValueChecker : public testing::Test {
public:
// only support INT field
static void CheckResult(const std::vector<KeyValue>& expected,
const std::vector<KeyValue>& result, int32_t key_arity,
int32_t value_arity) {
ASSERT_EQ(expected.size(), result.size());
for (size_t i = 0; i < expected.size(); i++) {
CheckResult(expected[i], result[i], key_arity, value_arity);
}
}
static void CheckResult(const KeyValue& expected, const KeyValue& result, int32_t key_arity,
int32_t value_arity) {
ASSERT_EQ(*(expected.value_kind), *(result.value_kind));
ASSERT_EQ(expected.sequence_number, result.sequence_number);
ASSERT_EQ(expected.level, result.level);
ASSERT_EQ(key_arity, result.key->GetFieldCount());
ASSERT_EQ(value_arity, result.value->GetFieldCount());
for (int32_t k = 0; k < key_arity; k++) {
ASSERT_EQ(expected.key->GetInt(k), result.key->GetInt(k));
}
for (int32_t v = 0; v < value_arity; v++) {
if (expected.value->IsNullAt(v)) {
ASSERT_TRUE(result.value->IsNullAt(v));
} else {
ASSERT_EQ(expected.value->GetInt(v), result.value->GetInt(v));
}
}
}
// support non-nested field
static void CheckResult(const std::vector<KeyValue>& expected_vec,
const std::vector<KeyValue>& result_vec,
const std::vector<DataField>& key_fields,
const std::vector<DataField>& value_fields) {
ASSERT_EQ(expected_vec.size(), result_vec.size());
ASSERT_OK_AND_ASSIGN(
auto key_comparator,
FieldsComparator::Create(key_fields, /*is_ascending_order=*/true, /*use_view=*/false));
ASSERT_OK_AND_ASSIGN(auto value_comparator,
FieldsComparator::Create(value_fields, /*is_ascending_order=*/true,
/*use_view=*/false));
for (size_t i = 0; i < expected_vec.size(); i++) {
const auto& expected = expected_vec[i];
const auto& result = result_vec[i];
ASSERT_EQ(*(expected.value_kind), *(result.value_kind));
ASSERT_EQ(expected.sequence_number, result.sequence_number);
ASSERT_EQ(expected.level, result.level);
ASSERT_EQ(key_fields.size(), result.key->GetFieldCount());
ASSERT_EQ(value_fields.size(), result.value->GetFieldCount());
ASSERT_EQ(0, key_comparator->CompareTo(*expected.key, *result.key));
ASSERT_EQ(0, value_comparator->CompareTo(*expected.value, *result.value));
}
}
static std::vector<KeyValue> GenerateKeyValues(
const std::vector<int64_t>& seq_vec,
const std::vector<BinaryRowGenerator::ValueType>& key_vec,
const std::vector<BinaryRowGenerator::ValueType>& value_vec,
const std::shared_ptr<MemoryPool>& pool) {
// default row kind is insert, level is 0
std::vector<RowKind*> row_kind_vec(key_vec.size(), const_cast<RowKind*>(RowKind::Insert()));
std::vector<int64_t> level_vec(key_vec.size(), 0);
return GenerateKeyValues(row_kind_vec, seq_vec, level_vec, key_vec, value_vec, pool);
}
static std::vector<KeyValue> GenerateKeyValues(
const std::vector<RowKind*>& row_kind_vec, const std::vector<int64_t>& seq_vec,
const std::vector<int64_t>& level_vec,
const std::vector<BinaryRowGenerator::ValueType>& key_vec,
const std::vector<BinaryRowGenerator::ValueType>& value_vec,
const std::shared_ptr<MemoryPool>& pool) {
EXPECT_EQ(row_kind_vec.size(), key_vec.size());
EXPECT_EQ(seq_vec.size(), key_vec.size());
EXPECT_EQ(level_vec.size(), key_vec.size());
EXPECT_EQ(value_vec.size(), key_vec.size());
std::vector<KeyValue> results;
for (size_t i = 0; i < seq_vec.size(); i++) {
results.emplace_back(
row_kind_vec[i], /*sequence_number=*/seq_vec[i], /*level=*/level_vec[i],
/*key=*/BinaryRowGenerator::GenerateRowPtr(key_vec[i], pool.get()),
/*value=*/BinaryRowGenerator::GenerateRowPtr(value_vec[i], pool.get()));
}
return results;
}
};
} // namespace paimon::test