summaryrefslogtreecommitdiffstats
path: root/searchlib/src/tests/attribute/multi_value_mapping
diff options
context:
space:
mode:
authorGeir Storli <geirst@verizonmedia.com>2019-11-14 08:49:45 +0000
committerGeir Storli <geirst@verizonmedia.com>2019-11-14 08:49:45 +0000
commit3e8c96fcba038b3b68f75073fbe516912d169311 (patch)
treec54a28883ff7f7b29ba111234498758478d36477 /searchlib/src/tests/attribute/multi_value_mapping
parent03d90c743ae83cfea09be55cb7f1787aa8c8453b (diff)
Enable free lists for multi-value mapping used in all multi-value attributes.
This should reduce the need for compaction which is CPU intensive for some applications.
Diffstat (limited to 'searchlib/src/tests/attribute/multi_value_mapping')
-rw-r--r--searchlib/src/tests/attribute/multi_value_mapping/multi_value_mapping_test.cpp30
1 files changed, 22 insertions, 8 deletions
diff --git a/searchlib/src/tests/attribute/multi_value_mapping/multi_value_mapping_test.cpp b/searchlib/src/tests/attribute/multi_value_mapping/multi_value_mapping_test.cpp
index 9bbcd71f59d..2f74e9d31f6 100644
--- a/searchlib/src/tests/attribute/multi_value_mapping/multi_value_mapping_test.cpp
+++ b/searchlib/src/tests/attribute/multi_value_mapping/multi_value_mapping_test.cpp
@@ -80,17 +80,19 @@ public:
_maxSmallArraySize()
{
}
- void setup(uint32_t maxSmallArraySize) {
- _mvMapping = std::make_unique<MvMapping>(ArrayStoreConfig(maxSmallArraySize,
- ArrayStoreConfig::AllocSpec(0, RefType::offsetSize(), 8 * 1024,
- ALLOC_GROW_FACTOR)));
+ void setup(uint32_t maxSmallArraySize, bool enable_free_lists = true) {
+ ArrayStoreConfig config(maxSmallArraySize,
+ ArrayStoreConfig::AllocSpec(0, RefType::offsetSize(), 8 * 1024, ALLOC_GROW_FACTOR));
+ config.enable_free_lists(enable_free_lists);
+ _mvMapping = std::make_unique<MvMapping>(config);
_attr = std::make_unique<AttributeType>(*_mvMapping);
_maxSmallArraySize = maxSmallArraySize;
}
- void setup(uint32_t maxSmallArraySize, size_t minArrays, size_t maxArrays, size_t numArraysForNewBuffer) {
- _mvMapping = std::make_unique<MvMapping>(ArrayStoreConfig(maxSmallArraySize,
- ArrayStoreConfig::AllocSpec(minArrays, maxArrays, numArraysForNewBuffer,
- ALLOC_GROW_FACTOR)));
+ void setup(uint32_t maxSmallArraySize, size_t minArrays, size_t maxArrays, size_t numArraysForNewBuffer, bool enable_free_lists = true) {
+ ArrayStoreConfig config(maxSmallArraySize,
+ ArrayStoreConfig::AllocSpec(minArrays, maxArrays, numArraysForNewBuffer, ALLOC_GROW_FACTOR));
+ config.enable_free_lists(enable_free_lists);
+ _mvMapping = std::make_unique<MvMapping>(config);
_attr = std::make_unique<AttributeType>(*_mvMapping);
_maxSmallArraySize = maxSmallArraySize;
}
@@ -307,6 +309,18 @@ TEST_F(IntMappingTest, test_that_replace_works)
EXPECT_EQ(4u, getTotalValueCnt());
}
+TEST_F(IntMappingTest, test_that_free_lists_can_be_enabled)
+{
+ setup(3, true);
+ EXPECT_TRUE(_mvMapping->has_free_lists_enabled());
+}
+
+TEST_F(IntMappingTest, test_that_free_lists_can_be_disabled)
+{
+ setup(3, false);
+ EXPECT_FALSE(_mvMapping->has_free_lists_enabled());
+}
+
TEST_F(CompactionIntMappingTest, test_that_compaction_works)
{
setup(3, 64, 512, 129);