diff options
author | Geir Storli <geirst@verizonmedia.com> | 2019-11-14 08:49:45 +0000 |
---|---|---|
committer | Geir Storli <geirst@verizonmedia.com> | 2019-11-14 08:49:45 +0000 |
commit | 3e8c96fcba038b3b68f75073fbe516912d169311 (patch) | |
tree | c54a28883ff7f7b29ba111234498758478d36477 /searchlib/src/tests/attribute/multi_value_mapping | |
parent | 03d90c743ae83cfea09be55cb7f1787aa8c8453b (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.cpp | 30 |
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); |