Skip to content

Commit

Permalink
add ut
Browse files Browse the repository at this point in the history
  • Loading branch information
bobhan1 committed Dec 19, 2024
1 parent 3425738 commit e3921f6
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 9 deletions.
4 changes: 2 additions & 2 deletions cloud/src/recycler/recycler.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1489,8 +1489,8 @@ int InstanceRecycler::delete_rowset_data(const std::vector<doris::RowsetMetaClou
index_ids = std::move(index_info.second);
}
if (rs.rowset_state() == RowsetStatePB::BEGIN_PARTIAL_UPDATE) {
// if rowset state is RowsetStatePB::BEGIN_PARTIAL_UPDATE, the num of segments may be bigger than num_segments
// so we need to delete the rowset's data by prefix
// if rowset state is RowsetStatePB::BEGIN_PARTIAL_UPDATE, the number of segments data
// may be larger than num_segments field in RowsetMeta, so we need to delete the rowset's data by prefix
rowsets_delete_by_prefix.emplace_back(rs.resource_id(), tablet_id, rs.rowset_id_v2());
continue;
}
Expand Down
22 changes: 15 additions & 7 deletions cloud/test/recycler_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,7 @@ static doris::RowsetMetaCloudPB create_rowset(const std::string& resource_id, in
rowset.set_resource_id(resource_id);
rowset.set_schema_version(schema.schema_version());
rowset.mutable_tablet_schema()->CopyFrom(schema);
rowset.set_rowset_state(rowset_state);
return rowset;
}

Expand Down Expand Up @@ -960,6 +961,12 @@ TEST(RecyclerTest, recycle_tmp_rowsets_partial_update) {
auto sp = SyncPoint::get_instance();
std::unique_ptr<int, std::function<void(int*)>> defer(
(int*)0x01, [](int*) { SyncPoint::get_instance()->clear_all_call_backs(); });
std::vector<doris::RowsetMetaCloudPB> rowsets_begin_partial_update;
sp->set_call_back("InstanceRecycler.collect_rowset.begin_partial_update", [&](auto&& args) {
doris::RowsetMetaCloudPB* rowset_meta = try_any_cast<doris::RowsetMetaCloudPB*>(args[0]);
rowsets_begin_partial_update.emplace_back(*rowset_meta);
});

sp->enable_processing();

InstanceRecycler recycler(txn_kv, instance, thread_group,
Expand All @@ -971,16 +978,18 @@ TEST(RecyclerTest, recycle_tmp_rowsets_partial_update) {
auto accessor = recycler.accessor_map_.begin()->second;
int64_t tablet_id = 10015;
int64_t index_id = 1000;
int64_t txn_id = 293039;
int64_t txn_id_base = 293039;
for (int j = 0; j < 20; ++j) {
int64_t txn_id = txn_id_base + j;
int segment_num = 5;
if (j < 15) {
auto rowset = create_rowset("recycle_tmp_rowsets_partial_update", tablet_id, tablet_id,
5, schema, txn_id);
auto rowset = create_rowset("recycle_tmp_rowsets_partial_update", tablet_id, index_id,
segment_num, schema, RowsetStatePB::VISIBLE, txn_id);
create_tmp_rowset(txn_kv.get(), accessor.get(), rowset, false);
} else {
int segment_num = 5;
auto rowset = create_rowset("recycle_tmp_rowsets_partial_update", tablet_id, tablet_id,
5, schema, txn_id);
auto rowset =
create_rowset("recycle_tmp_rowsets_partial_update", tablet_id, tablet_id,
segment_num, schema, RowsetStatePB::BEGIN_PARTIAL_UPDATE, txn_id);
create_tmp_rowset(txn_kv.get(), accessor.get(), rowset, false);

// partial update may write new segment to an existing tmp rowsets
Expand All @@ -993,7 +1002,6 @@ TEST(RecyclerTest, recycle_tmp_rowsets_partial_update) {
}

ASSERT_EQ(recycler.recycle_tmp_rowsets(), 0);

// check rowset does not exist on obj store
std::unique_ptr<ListIterator> list_iter;
ASSERT_EQ(0, accessor->list_directory("data/", &list_iter));
Expand Down

0 comments on commit e3921f6

Please sign in to comment.