summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTor Egge <Tor.Egge@online.no>2023-02-27 10:35:45 +0100
committerTor Egge <Tor.Egge@online.no>2023-02-27 10:35:45 +0100
commit467e33231bde5e05676990c07a724b0b467b7d61 (patch)
tree1cc8f411a4b0df79ccc5a51fd8e3ba2fe1067ffb
parent310e42fc49911471eebcb1f031c954fab5bb17a4 (diff)
Use gtest for closeness and distance features unit tests.
-rw-r--r--searchlib/src/tests/features/nns_closeness/nns_closeness_test.cpp93
-rw-r--r--searchlib/src/tests/features/nns_distance/nns_distance_test.cpp98
-rw-r--r--searchlib/src/vespa/searchlib/test/features/CMakeLists.txt1
-rw-r--r--searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.cpp8
-rw-r--r--searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.h10
5 files changed, 151 insertions, 59 deletions
diff --git a/searchlib/src/tests/features/nns_closeness/nns_closeness_test.cpp b/searchlib/src/tests/features/nns_closeness/nns_closeness_test.cpp
index e67370d48f6..8cb060c08e4 100644
--- a/searchlib/src/tests/features/nns_closeness/nns_closeness_test.cpp
+++ b/searchlib/src/tests/features/nns_closeness/nns_closeness_test.cpp
@@ -7,7 +7,7 @@
#include <vespa/searchlib/fef/test/labels.h>
#include <vespa/searchlib/test/features/distance_closeness_fixture.h>
#include <vespa/vespalib/stllike/asciistream.h>
-#include <vespa/vespalib/testkit/test_kit.h>
+#include <vespa/vespalib/gtest/gtest.h>
#include <vespa/vespalib/util/stringfmt.h>
using search::feature_t;
@@ -23,60 +23,97 @@ const vespalib::string fieldFeatureName("closeness(bar)");
using RankFixture = DistanceClosenessFixture;
-TEST_F("require that blueprint can be created from factory", BlueprintFactoryFixture) {
+TEST(NnsClosenessTest, require_that_blueprint_can_be_created_from_factory)
+{
+ BlueprintFactoryFixture f;
Blueprint::SP bp = f.factory.createBlueprint("closeness");
EXPECT_TRUE(bp.get() != 0);
EXPECT_TRUE(dynamic_cast<ClosenessBlueprint*>(bp.get()) != 0);
}
-TEST_FFF("require that no features are dumped", ClosenessBlueprint, IndexEnvironmentFixture, FeatureDumpFixture) {
+TEST(NnsClosenessTest, require_that_no_features_are_dumped)
+{
+ ClosenessBlueprint f1;
+ IndexEnvironmentFixture f2;
+ FeatureDumpFixture f3;
f1.visitDumpFeatures(f2.indexEnv, f3);
}
-TEST_FF("require that setup can be done on random label", ClosenessBlueprint, IndexEnvironmentFixture) {
+TEST(NnsClosenessTest, require_that_setup_can_be_done_on_random_label)
+{
+ ClosenessBlueprint f1;
+ IndexEnvironmentFixture f2;
DummyDependencyHandler deps(f1);
f1.setName(vespalib::make_string("%s(label,random_label)", f1.getBaseName().c_str()));
EXPECT_TRUE(static_cast<Blueprint&>(f1).setup(f2.indexEnv, std::vector<vespalib::string>{"label", "random_label"}));
}
-TEST_FF("require that no label gives 0 closeness", NoLabel(), RankFixture(2, 2, f1, labelFeatureName)) {
- EXPECT_EQUAL(0.0, f2.getScore(10));
+TEST(NnsClosenessTest, require_that_no_label_gives_0_closeness)
+{
+ NoLabel f1;
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
+ EXPECT_EQ(0.0, f2.getScore(10));
}
-TEST_FF("require that unrelated label gives 0 closeness", SingleLabel("unrelated", 1), RankFixture(2, 2, f1, labelFeatureName)) {
- EXPECT_EQUAL(0.0, f2.getScore(10));
+TEST(NnsClosenessTest, require_that_unrelated_label_gives_0_closeness)
+{
+ SingleLabel f1("unrelated", 1);
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
+ EXPECT_EQ(0.0, f2.getScore(10));
}
-TEST_FF("require that labeled item raw score can be obtained", SingleLabel("nns", 1), RankFixture(2, 2, f1, labelFeatureName)) {
+TEST(NnsClosenessTest, require_that_labeled_item_raw_score_can_be_obtained)
+{
+ SingleLabel f1("nns", 1);
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setFooScore(0, 10, 5.0);
- EXPECT_EQUAL(1/(1+5.0), f2.getScore(10));
+ EXPECT_EQ(1/(1+5.0), f2.getScore(10));
}
-TEST_FF("require that field raw score can be obtained", NoLabel(), RankFixture(2, 2, f1, fieldFeatureName)) {
+TEST(NnsClosenessTest, require_that_field_raw_score_can_be_obtained)
+{
+ NoLabel f1;
+ RankFixture f2(2, 2, f1, fieldFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setBarScore(0, 10, 5.0);
- EXPECT_EQUAL(1/(1+5.0), f2.getScore(10));
+ EXPECT_EQ(1/(1+5.0), f2.getScore(10));
}
-TEST_FF("require that other raw scores are ignored", SingleLabel("nns", 2), RankFixture(2, 2, f1, labelFeatureName)) {
+TEST(NnsClosenessTest, require_that_other_raw_scores_are_ignored)
+{
+ SingleLabel f1("nns", 2);
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setFooScore(0, 10, 1.0);
f2.setFooScore(1, 10, 2.0);
f2.setBarScore(0, 10, 5.0);
f2.setBarScore(1, 10, 6.0);
- EXPECT_EQUAL(1/(1+2.0), f2.getScore(10));
+ EXPECT_EQ(1/(1+2.0), f2.getScore(10));
}
-TEST_FF("require that the correct raw score is used", NoLabel(), RankFixture(2, 2, f1, fieldFeatureName)) {
+TEST(NnsClosenessTest, require_that_the_correct_raw_score_is_used)
+{
+ NoLabel f1;
+ RankFixture f2(2, 2, f1, fieldFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setFooScore(0, 10, 3.0);
f2.setFooScore(1, 10, 4.0);
f2.setBarScore(0, 10, 8.0);
f2.setBarScore(1, 10, 7.0);
- EXPECT_EQUAL(1/(1+7.0), f2.getScore(10));
+ EXPECT_EQ(1/(1+7.0), f2.getScore(10));
}
-TEST_FF("require that stale data is ignored", SingleLabel("nns", 2), RankFixture(2, 2, f1, labelFeatureName)) {
+TEST(NnsClosenessTest, require_that_stale_data_is_ignored)
+{
+ SingleLabel f1("nns", 2);
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setFooScore(0, 10, 1.0);
f2.setFooScore(1, 5, 2.0);
- EXPECT_EQUAL(0, f2.getScore(10));
+ EXPECT_EQ(0, f2.getScore(10));
}
void
@@ -88,21 +125,25 @@ expect_raw_score_calculated_on_the_fly(RankFixture& f)
// For docids 9 and 10 the raw score is calculated on the fly
// using a distance calculator over the attribute and query tensors.
- EXPECT_EQUAL(1/(1+13.0), f.getScore(8));
- EXPECT_EQUAL(1/(1+(5.0-3.0)), f.getScore(9));
- EXPECT_EQUAL(1/(1+(7.0-3.0)), f.getScore(10));
+ EXPECT_EQ(1/(1+13.0), f.getScore(8));
+ EXPECT_EQ(1/(1+(5.0-3.0)), f.getScore(9));
+ EXPECT_EQ(1/(1+(7.0-3.0)), f.getScore(10));
}
-TEST_FF("raw score is calculated on the fly (using field setup)",
- NoLabel(), RankFixture(0, 1, f1, fieldFeatureName, "tensor(x[2]):[3,11]"))
+TEST(NnsClosenessTest, raw_score_is_calculated_on_the_fly_using_field_setup)
{
+ NoLabel f1;
+ RankFixture f2(0, 1, f1, fieldFeatureName, "tensor(x[2]):[3,11]");
+ ASSERT_FALSE(f2.failed());
expect_raw_score_calculated_on_the_fly(f2);
}
-TEST_FF("raw score is calculated on the fly (using label setup)",
- SingleLabel("nns", 1), RankFixture(0, 1, f1, labelFeatureName, "tensor(x[2]):[3,11]"))
+TEST(NnsClosenessTest, raw_score_is_calculated_on_the_fly_using_label_setup)
{
+ SingleLabel f1("nns", 1);
+ RankFixture f2(0, 1, f1, labelFeatureName, "tensor(x[2]):[3,11]");
+ ASSERT_FALSE(f2.failed());
expect_raw_score_calculated_on_the_fly(f2);
}
-TEST_MAIN() { TEST_RUN_ALL(); }
+GTEST_MAIN_RUN_ALL_TESTS()
diff --git a/searchlib/src/tests/features/nns_distance/nns_distance_test.cpp b/searchlib/src/tests/features/nns_distance/nns_distance_test.cpp
index fff4c9f1c0e..acc67803886 100644
--- a/searchlib/src/tests/features/nns_distance/nns_distance_test.cpp
+++ b/searchlib/src/tests/features/nns_distance/nns_distance_test.cpp
@@ -6,7 +6,7 @@
#include <vespa/searchlib/fef/test/labels.h>
#include <vespa/searchlib/test/features/distance_closeness_fixture.h>
#include <vespa/vespalib/stllike/asciistream.h>
-#include <vespa/vespalib/testkit/test_kit.h>
+#include <vespa/vespalib/gtest/gtest.h>
#include <vespa/vespalib/util/stringfmt.h>
using search::feature_t;
@@ -22,66 +22,106 @@ const vespalib::string fieldFeatureName("distance(bar)");
using RankFixture = DistanceClosenessFixture;
-TEST_F("require that blueprint can be created from factory", BlueprintFactoryFixture) {
+TEST(NnsDistanceTest, require_that_blueprint_can_be_created_from_factory)
+{
+ BlueprintFactoryFixture f;
Blueprint::SP bp = f.factory.createBlueprint("distance");
EXPECT_TRUE(bp.get() != 0);
EXPECT_TRUE(dynamic_cast<DistanceBlueprint*>(bp.get()) != 0);
}
-TEST_FFF("require that no features are dumped", DistanceBlueprint, IndexEnvironmentFixture, FeatureDumpFixture) {
+TEST(NnsDistanceTest, require_that_no_features_are_dumped)
+{
+ DistanceBlueprint f1;
+ IndexEnvironmentFixture f2;
+ FeatureDumpFixture f3;
f1.visitDumpFeatures(f2.indexEnv, f3);
}
-TEST_FF("require that setup can be done on random label", DistanceBlueprint, IndexEnvironmentFixture) {
+TEST(NnsDistanceTest, require_that_setup_can_be_done_on_random_label)
+{
+ DistanceBlueprint f1;
+ IndexEnvironmentFixture f2;
DummyDependencyHandler deps(f1);
f1.setName(vespalib::make_string("%s(label,random_label)", f1.getBaseName().c_str()));
EXPECT_TRUE(static_cast<Blueprint&>(f1).setup(f2.indexEnv, std::vector<vespalib::string>{"label", "random_label"}));
}
-TEST_FF("require that setup with unknown field fails", DistanceBlueprint, IndexEnvironmentFixture) {
+TEST(NnsDistanceTest, require_that_setup_with_unknown_field_fails)
+{
+ DistanceBlueprint f1;
+ IndexEnvironmentFixture f2;
DummyDependencyHandler deps(f1);
f1.setName(vespalib::make_string("%s(field,random_fieldname)", f1.getBaseName().c_str()));
EXPECT_FALSE(static_cast<Blueprint&>(f1).setup(f2.indexEnv, std::vector<vespalib::string>{"field", "random_fieldname"}));
}
-TEST_FF("require that no label gives max-double distance", NoLabel(), RankFixture(2, 2, f1, labelFeatureName)) {
- EXPECT_EQUAL(std::numeric_limits<feature_t>::max(), f2.getScore(10));
+TEST(NnsDistanceTest, require_that_no_label_gives_max_double_distance)
+{
+ NoLabel f1;
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
+ EXPECT_EQ(std::numeric_limits<feature_t>::max(), f2.getScore(10));
}
-TEST_FF("require that unrelated label gives max-double distance", SingleLabel("unrelated", 1), RankFixture(2, 2, f1, labelFeatureName)) {
- EXPECT_EQUAL(std::numeric_limits<feature_t>::max(), f2.getScore(10));
+TEST(NnsDistanceTest, require_that_unrelated_label_gives_max_double_distance)
+{
+ SingleLabel f1("unrelated", 1);
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
+ EXPECT_EQ(std::numeric_limits<feature_t>::max(), f2.getScore(10));
}
-TEST_FF("require that labeled item raw score can be obtained", SingleLabel("nns", 1), RankFixture(2, 2, f1, labelFeatureName)) {
+TEST(NnsDistanceTest, require_that_labeled_item_raw_score_can_be_obtained)
+{
+ SingleLabel f1("nns", 1);
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setFooScore(0, 10, 5.0);
- EXPECT_EQUAL(5.0, f2.getScore(10));
+ EXPECT_EQ(5.0, f2.getScore(10));
}
-TEST_FF("require that field raw score can be obtained", NoLabel(), RankFixture(2, 2, f1, fieldFeatureName)) {
+TEST(NnsDistanceTest, require_that_field_raw_score_can_be_obtained)
+{
+ NoLabel f1;
+ RankFixture f2(2, 2, f1, fieldFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setBarScore(0, 10, 5.0);
- EXPECT_EQUAL(5.0, f2.getScore(10));
+ EXPECT_EQ(5.0, f2.getScore(10));
}
-TEST_FF("require that other raw scores are ignored", SingleLabel("nns", 2), RankFixture(2, 2, f1, labelFeatureName)) {
+TEST(NnsDistanceTest, require_that_other_raw_scores_are_ignored)
+{
+ SingleLabel f1("nns", 2);
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setFooScore(0, 10, 1.0);
f2.setFooScore(1, 10, 2.0);
f2.setBarScore(0, 10, 5.0);
f2.setBarScore(1, 10, 6.0);
- EXPECT_EQUAL(2.0, f2.getScore(10));
+ EXPECT_EQ(2.0, f2.getScore(10));
}
-TEST_FF("require that the correct raw score is used", NoLabel(), RankFixture(2, 2, f1, fieldFeatureName)) {
+TEST(NnsDistanceTest, require_that_the_correct_raw_score_is_used)
+{
+ NoLabel f1;
+ RankFixture f2(2, 2, f1, fieldFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setFooScore(0, 10, 3.0);
f2.setFooScore(1, 10, 4.0);
f2.setBarScore(0, 10, 8.0);
f2.setBarScore(1, 10, 7.0);
- EXPECT_EQUAL(7.0, f2.getScore(10));
+ EXPECT_EQ(7.0, f2.getScore(10));
}
-TEST_FF("require that stale data is ignored", SingleLabel("nns", 2), RankFixture(2, 2, f1, labelFeatureName)) {
+TEST(NnsDistanceTest, require_that_stale_data_is_ignored)
+{
+ SingleLabel f1("nns", 2);
+ RankFixture f2(2, 2, f1, labelFeatureName);
+ ASSERT_FALSE(f2.failed());
f2.setFooScore(0, 10, 1.0);
f2.setFooScore(1, 5, 2.0);
- EXPECT_EQUAL(std::numeric_limits<feature_t>::max(), f2.getScore(10));
+ EXPECT_EQ(std::numeric_limits<feature_t>::max(), f2.getScore(10));
}
void
@@ -93,21 +133,25 @@ expect_raw_score_calculated_on_the_fly(RankFixture& f)
// For docids 9 and 10 the raw score is calculated on the fly
// using a distance calculator over the attribute and query tensors.
- EXPECT_EQUAL(13.0, f.getScore(8));
- EXPECT_EQUAL((5-3), f.getScore(9));
- EXPECT_EQUAL((7-3), f.getScore(10));
+ EXPECT_EQ(13.0, f.getScore(8));
+ EXPECT_EQ((5-3), f.getScore(9));
+ EXPECT_EQ((7-3), f.getScore(10));
}
-TEST_FF("raw score is calculated on the fly (using field setup)",
- NoLabel(), RankFixture(0, 1, f1, fieldFeatureName, "tensor(x[2]):[3,11]"))
+TEST(NnsDistanceTest, raw_score_is_calculated_on_the_fly_using_field_setup)
{
+ NoLabel f1;
+ RankFixture f2(0, 1, f1, fieldFeatureName, "tensor(x[2]):[3,11]");
+ ASSERT_FALSE(f2.failed());
expect_raw_score_calculated_on_the_fly(f2);
}
-TEST_FF("raw score is calculated on the fly (using label setup)",
- SingleLabel("nns", 1), RankFixture(0, 1, f1, labelFeatureName, "tensor(x[2]):[3,11]"))
+TEST(NnsDistanceTest, raw_score_is_calculated_on_the_fly_using_label_setup)
{
+ SingleLabel f1("nns", 1);
+ RankFixture f2(0, 1, f1, labelFeatureName, "tensor(x[2]):[3,11]");
+ ASSERT_FALSE(f2.failed());
expect_raw_score_calculated_on_the_fly(f2);
}
-TEST_MAIN() { TEST_RUN_ALL(); }
+GTEST_MAIN_RUN_ALL_TESTS()
diff --git a/searchlib/src/vespa/searchlib/test/features/CMakeLists.txt b/searchlib/src/vespa/searchlib/test/features/CMakeLists.txt
index ba70fe57e88..f51ccea5678 100644
--- a/searchlib/src/vespa/searchlib/test/features/CMakeLists.txt
+++ b/searchlib/src/vespa/searchlib/test/features/CMakeLists.txt
@@ -4,4 +4,5 @@ vespa_add_library(searchlib_searchlib_test_features
distance_closeness_fixture.cpp
DEPENDS
searchlib
+ GTest::GTest
)
diff --git a/searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.cpp b/searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.cpp
index e161a4e9839..275ee145240 100644
--- a/searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.cpp
+++ b/searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.cpp
@@ -50,7 +50,8 @@ DistanceClosenessFixture::DistanceClosenessFixture(size_t fooCnt, size_t barCnt,
: queryEnv(&indexEnv), rankSetup(factory, indexEnv),
mdl(), match_data(), rankProgram(), fooHandles(), barHandles(),
tensor_attr(),
- docid_limit(11)
+ docid_limit(11),
+ _failed(false)
{
for (size_t i = 0; i < fooCnt; ++i) {
uint32_t fieldId = indexEnv.getFieldByName("foo")->id();
@@ -79,7 +80,10 @@ DistanceClosenessFixture::DistanceClosenessFixture(size_t fooCnt, size_t barCnt,
labels.inject(queryEnv.getProperties());
rankSetup.setFirstPhaseRank(featureName);
rankSetup.setIgnoreDefaultRankFeatures(true);
- ASSERT_TRUE(rankSetup.compile());
+ EXPECT_TRUE(rankSetup.compile()) << (_failed = true, "");
+ if (_failed) {
+ return;
+ }
rankSetup.prepareSharedState(queryEnv, queryEnv.getObjectStore());
match_data = mdl.createMatchData();
rankProgram = rankSetup.create_first_phase_program();
diff --git a/searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.h b/searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.h
index cc1c0a6fb15..15ff68e325c 100644
--- a/searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.h
+++ b/searchlib/src/vespa/searchlib/test/features/distance_closeness_fixture.h
@@ -8,7 +8,7 @@
#include <vespa/searchlib/fef/test/indexenvironmentbuilder.h>
#include <vespa/searchlib/fef/test/labels.h>
#include <vespa/searchlib/fef/test/queryenvironment.h>
-#include <vespa/vespalib/testkit/test_kit.h>
+#include <vespa/vespalib/gtest/gtest.h>
using namespace search::fef;
using namespace search::fef::test;
@@ -38,7 +38,7 @@ struct IndexEnvironmentFixture {
struct FeatureDumpFixture : public IDumpFeatureVisitor {
virtual void visitDumpFeature(const vespalib::string &) override {
- TEST_ERROR("no features should be dumped");
+ FAIL() << "no features should be dumped";
}
FeatureDumpFixture() : IDumpFeatureVisitor() {}
~FeatureDumpFixture() override;
@@ -57,6 +57,7 @@ struct DistanceClosenessFixture : BlueprintFactoryFixture, IndexEnvironmentFixtu
std::vector<TermFieldHandle> barHandles;
std::shared_ptr<search::tensor::DenseTensorAttribute> tensor_attr;
uint32_t docid_limit;
+ bool _failed;
DistanceClosenessFixture(size_t fooCnt, size_t barCnt,
const Labels &labels, const vespalib::string &featureName,
const vespalib::string& query_tensor = "");
@@ -72,13 +73,14 @@ struct DistanceClosenessFixture : BlueprintFactoryFixture, IndexEnvironmentFixtu
match_data->resolveTermField(handle)->setRawScore(docId, score);
}
void setFooScore(uint32_t i, uint32_t docId, feature_t distance) {
- ASSERT_LESS(i, fooHandles.size());
+ ASSERT_LT(i, fooHandles.size());
setScore(fooHandles[i], docId, 1.0/(1.0+distance));
}
void setBarScore(uint32_t i, uint32_t docId, feature_t distance) {
- ASSERT_LESS(i, barHandles.size());
+ ASSERT_LT(i, barHandles.size());
setScore(barHandles[i], docId, 1.0/(1.0+distance));
}
+ bool failed() const noexcept { return _failed; }
};
}