summaryrefslogtreecommitdiffstats
path: root/searchlib/src/tests/query/querybuilder_test.cpp
diff options
context:
space:
mode:
authorHenning Baldersheim <balder@yahoo-inc.com>2021-03-30 14:50:13 +0000
committerHenning Baldersheim <balder@yahoo-inc.com>2021-03-30 14:50:13 +0000
commitd40cbb5e16fe71f516280793d12d9e83a1dc1bda (patch)
tree5d4ed3f42e478180a54ca606ec350edbd192d9d5 /searchlib/src/tests/query/querybuilder_test.cpp
parent9bfa816ed895c2f253dfe72348842931933b6c31 (diff)
Add testing of multiterm and allow mixing and matching of string vs integer.
Diffstat (limited to 'searchlib/src/tests/query/querybuilder_test.cpp')
-rw-r--r--searchlib/src/tests/query/querybuilder_test.cpp71
1 files changed, 71 insertions, 0 deletions
diff --git a/searchlib/src/tests/query/querybuilder_test.cpp b/searchlib/src/tests/query/querybuilder_test.cpp
index 67b45d43406..47dccc76603 100644
--- a/searchlib/src/tests/query/querybuilder_test.cpp
+++ b/searchlib/src/tests/query/querybuilder_test.cpp
@@ -642,6 +642,77 @@ TEST("test query parsing error") {
EXPECT_FALSE(new_node);
}
+class SimpleMultiTerm : public MultiTerm {
+public:
+ SimpleMultiTerm(size_t numTerms) : MultiTerm(numTerms) {}
+ void accept(QueryVisitor & ) override { }
+};
+
+TEST("initial state of MultiTerm") {
+ SimpleMultiTerm mt(7);
+ EXPECT_EQUAL(7u, mt.getNumTerms());
+ EXPECT_TRUE(MultiTerm::Type::UNKNOWN == mt.getType());
+}
+
+void
+verify_multiterm_get(const MultiTerm & mt) {
+ EXPECT_EQUAL(7u, mt.getNumTerms());
+ for (int64_t i(0); i < mt.getNumTerms(); i++) {
+ auto v = mt.getAsInteger(i);
+ EXPECT_EQUAL(v.first, i-3);
+ EXPECT_EQUAL(v.second.percent(), i-4);
+ }
+ for (int64_t i(0); i < mt.getNumTerms(); i++) {
+ auto v = mt.getAsString(i);
+ char buf[24];
+ auto res = std::to_chars(buf, buf + sizeof(buf), i-3);
+ EXPECT_EQUAL(v.first, vespalib::stringref(buf, res.ptr - buf));
+ EXPECT_EQUAL(v.second.percent(), i-4);
+ }
+}
+
+TEST("add and get of integer MultiTerm") {
+ SimpleMultiTerm mt(7);
+ for (int64_t i(0); i < mt.getNumTerms(); i++) {
+ mt.addTerm(i-3, Weight(i-4));
+ }
+ EXPECT_TRUE(MultiTerm::Type::INTEGER == mt.getType());
+ verify_multiterm_get(mt);
+}
+
+TEST("add and get of string MultiTerm") {
+ SimpleMultiTerm mt(7);
+ for (int64_t i(0); i < mt.getNumTerms(); i++) {
+ char buf[24];
+ auto res = std::to_chars(buf, buf + sizeof(buf), i-3);
+ mt.addTerm(vespalib::stringref(buf, res.ptr - buf), Weight(i-4));
+ }
+ EXPECT_TRUE(MultiTerm::Type::STRING == mt.getType());
+ verify_multiterm_get(mt);
+}
+
+TEST("first string then integer MultiTerm") {
+ SimpleMultiTerm mt(7);
+ mt.addTerm("-3", Weight(-4));
+ for (int64_t i(1); i < mt.getNumTerms(); i++) {
+ mt.addTerm(i-3, Weight(i-4));
+ }
+ EXPECT_TRUE(MultiTerm::Type::STRING == mt.getType());
+ verify_multiterm_get(mt);
+}
+
+TEST("first integer then string MultiTerm") {
+ SimpleMultiTerm mt(7);
+ mt.addTerm(-3, Weight(-4));
+ for (int64_t i(1); i < mt.getNumTerms(); i++) {
+ char buf[24];
+ auto res = std::to_chars(buf, buf + sizeof(buf), i-3);
+ mt.addTerm(vespalib::stringref(buf, res.ptr - buf), Weight(i-4));
+ }
+ EXPECT_TRUE(MultiTerm::Type::INTEGER == mt.getType());
+ verify_multiterm_get(mt);
+}
+
} // namespace
TEST_MAIN() { TEST_RUN_ALL(); }