Files
clice/tests/unit/Index/MergedIndexTests.cpp
2025-11-30 15:21:27 +08:00

79 lines
2.2 KiB
C++

#include "Test/Test.h"
#include "Test/Tester.h"
#include "Async/Async.h"
#include "Index/MergedIndex.h"
namespace clice::testing {
namespace {
TEST_SUITE(MergedIndex) {
Tester tester;
index::TUIndex tu_index;
void build_index(llvm::StringRef code,
std::source_location location = std::source_location::current()) {
tester.clear();
tester.add_main("main.cpp", code);
ASSERT_TRUE(tester.compile());
tu_index = index::TUIndex::build(*tester.unit);
};
void expect_select(llvm::StringRef pos,
llvm::StringRef expect_range,
llvm::StringRef file = "",
std::source_location location = std::source_location::current()) {
auto offset = tester.point(pos, file);
auto range = tester.range(expect_range, file);
auto fid = file.empty() ? tester.unit->interested_file() : tester.unit->file_id(file);
auto& index = tu_index.file_indices[fid];
auto it =
std::ranges::lower_bound(index.occurrences, offset, {}, [](index::Occurrence& occurrence) {
return occurrence.range.end;
});
auto err =
std::format("Fail to find symbol for offser: {} range: range: {}", offset, dump(range));
ASSERT_TRUE(it != index.occurrences.end());
/// FIXME: Make eq pretty print reflectable struct.
ASSERT_EQ(dump(it->range), dump(range));
}
TEST_CASE(Serialization) {
build_index(R"(
#include <iostream>
int main () {
std::cout << "Hello world!" << std::endl;
return 0;
}
)");
llvm::StringMap<index::MergedIndex> merged_indices;
auto& graph = tu_index.graph;
for(auto& [fid, index]: tu_index.file_indices) {
llvm::StringRef path = graph.paths[graph.path_id(fid)];
merged_indices[path].merge(0, graph.include_location_id(fid), index);
}
for(auto& [path, merged]: merged_indices) {
llvm::SmallString<1024> s;
llvm::raw_svector_ostream os(s);
merged.serialize(os);
auto view = index::MergedIndex(s);
ASSERT_TRUE(merged == view);
}
}
}; // TEST_SUITE(MergedIndex)
} // namespace
} // namespace clice::testing