summaryrefslogtreecommitdiffstats
path: root/vdslib/src/tests/container/searchresulttest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'vdslib/src/tests/container/searchresulttest.cpp')
-rw-r--r--vdslib/src/tests/container/searchresulttest.cpp44
1 files changed, 43 insertions, 1 deletions
diff --git a/vdslib/src/tests/container/searchresulttest.cpp b/vdslib/src/tests/container/searchresulttest.cpp
index 8433a6008a1..2b27aeeb95c 100644
--- a/vdslib/src/tests/container/searchresulttest.cpp
+++ b/vdslib/src/tests/container/searchresulttest.cpp
@@ -1,11 +1,26 @@
// Copyright Yahoo. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
-#include <vespa/document/base/testdocman.h>
#include <vespa/vdslib/container/searchresult.h>
#include <vespa/vespalib/gtest/gtest.h>
+using vespalib::FeatureValues;
+using FeatureValue = vespalib::FeatureSet::Value;
+
namespace vdslib {
+namespace {
+
+std::vector<double> to_doubles(vespalib::ConstArrayRef<FeatureValue> v) {
+ std::vector<double> result;
+ for (auto& iv : v) {
+ EXPECT_TRUE(iv.is_double());
+ result.emplace_back(iv.as_double());
+ }
+ return result;
+}
+
+}
+
TEST(SearchResultTest, test_simple)
{
SearchResult a;
@@ -68,4 +83,31 @@ TEST(SearchResultTest, test_simple_sort_data)
EXPECT_EQ(4, sz);
}
+TEST(SearchResultTest, test_match_features)
+{
+ SearchResult sr;
+ sr.addHit(7, "doc1", 5);
+ sr.addHit(8, "doc2", 7);
+ FeatureValues mf;
+ mf.names.push_back("foo");
+ mf.names.push_back("bar");
+ mf.values.resize(4);
+ mf.values[0].set_double(1.0);
+ mf.values[1].set_double(7.0);
+ mf.values[2].set_double(12.0);
+ mf.values[3].set_double(13.0);
+ sr.set_match_features(FeatureValues(mf));
+ EXPECT_EQ(mf.names, sr.get_match_features().names);
+ EXPECT_EQ(mf.values, sr.get_match_features().values);
+ EXPECT_EQ((std::vector<double>{ 1.0, 7.0}), to_doubles(sr.get_match_feature_values(0)));
+ EXPECT_EQ((std::vector<double>{ 12.0, 13.0}), to_doubles(sr.get_match_feature_values(1)));
+ sr.sort();
+ // Sorting does not change the stored match features
+ EXPECT_EQ(mf.names, sr.get_match_features().names);
+ EXPECT_EQ(mf.values, sr.get_match_features().values);
+ // Sorting affects retrieval of the stored matched features
+ EXPECT_EQ((std::vector<double>{ 12.0, 13.0}), to_doubles(sr.get_match_feature_values(0)));
+ EXPECT_EQ((std::vector<double>{ 1.0, 7.0}), to_doubles(sr.get_match_feature_values(1)));
+}
+
}