[Groonga-commit] groonga/grnxx at d52226c [master] Add a test for OrMerger. (#67)

Back to archive index

susumu.yata null+****@clear*****
Mon Sep 22 17:47:43 JST 2014


susumu.yata	2014-09-22 17:47:43 +0900 (Mon, 22 Sep 2014)

  New Revision: d52226c3234e601caf5bd66e99d2bb76967a2e12
  https://github.com/groonga/grnxx/commit/d52226c3234e601caf5bd66e99d2bb76967a2e12

  Message:
    Add a test for OrMerger. (#67)

  Modified files:
    test/test_merger.cpp

  Modified: test/test_merger.cpp (+53 -1)
===================================================================
--- test/test_merger.cpp    2014-09-22 17:46:57 +0900 (7772683)
+++ test/test_merger.cpp    2014-09-22 17:47:43 +0900 (6c876a5)
@@ -138,6 +138,57 @@ void test_and() {
   assert(count == result_records.size());
 }
 
+void test_or() {
+  grnxx::Error error;
+
+  // Create cursors to read all the records.
+  auto cursor = test.table->create_cursor(&error);
+  assert(cursor);
+  auto cursor2 = test.table->create_cursor(&error);
+  assert(cursor2);
+
+  // Create expressions to read values.
+  auto expression_builder =
+      grnxx::ExpressionBuilder::create(&error, test.table);
+  assert(expression_builder);
+  assert(expression_builder->push_column(&error, "Bool"));
+  auto expression = expression_builder->release(&error);
+  assert(expression);
+  assert(expression_builder->push_column(&error, "Bool2"));
+  auto expression2 = expression_builder->release(&error);
+  assert(expression2);
+
+  // Create input records.
+  grnxx::Array<grnxx::Record> records;
+  assert(cursor->read_all(&error, &records) == test.table->num_rows());
+  assert(expression->filter(&error, &records));
+  grnxx::Array<grnxx::Record> records2;
+  assert(cursor2->read_all(&error, &records2) == test.table->num_rows());
+  assert(expression2->filter(&error, &records2));
+
+  // Merge records.
+  grnxx::MergerOptions options;
+  options.type = grnxx::OR_MERGER;
+  options.operator_type = grnxx::PLUS_MERGER_OPERATOR;
+  auto merger = grnxx::Merger::create(&error, options);
+  assert(merger);
+  grnxx::Array<grnxx::Record> result_records;
+  assert(merger->merge(&error, &records, &records2, &result_records));
+
+  for (grnxx::Int i = 0; i < result_records.size(); ++i) {
+    grnxx::Int row_id = result_records.get_row_id(i);
+    assert(test.bool_values[row_id] || test.bool2_values[row_id]);
+  }
+
+  grnxx::Int count = 0;
+  for (grnxx::Int i = 1; i <= test.table->max_row_id(); ++i) {
+    if (test.bool_values[i] || test.bool2_values[i]) {
+      ++count;
+    }
+  }
+  assert(count == result_records.size());
+}
+
 void test_plus() {
   grnxx::Error error;
 
@@ -184,7 +235,7 @@ void test_plus() {
   grnxx::MergerOptions options;
   options.type = grnxx::AND_MERGER;
   options.operator_type = grnxx::PLUS_MERGER_OPERATOR;
-  auto merger = grnxx::Merger::create(&error);
+  auto merger = grnxx::Merger::create(&error, options);
   assert(merger);
   grnxx::Array<grnxx::Record> result_records;
   assert(merger->merge(&error, &records, &records2, &result_records));
@@ -210,6 +261,7 @@ int main() {
   init_test();
 
   test_and();
+  test_or();
 
   test_plus();
 
-------------- next part --------------
HTML����������������������������...
Télécharger 



More information about the Groonga-commit mailing list
Back to archive index