-#include <junction/ConcurrentMap_Crude.h>
-#include <junction/ConcurrentMap_Grampa.h>
-#include <junction/ConcurrentMap_Leapfrog.h>
-#include <junction/ConcurrentMap_Linear.h>
-
-#include <cds_test/stress_test.h>
-#include <cds_test/stress_test_util.h>
-
-#include <algorithm>
-#include <iostream>
-#include <memory>
-#include <random>
-#include <thread>
+#include "test.h"
namespace junction_test {
class JunctionMapInsDelFindTest_Parallel : public cds_test::stress_fixture {
protected:
- typedef junction::ConcurrentMap_Grampa<size_t, size_t> GrampaMap;
- typedef junction::ConcurrentMap_Linear<size_t, size_t> LinearMap;
- typedef junction::ConcurrentMap_Leapfrog<size_t, size_t> LeapfrogMap;
- typedef junction::ConcurrentMap_Crude<size_t, size_t> CrudeMap;
-
static unsigned s_nInsertPercentage;
static unsigned s_nDeletePercentage;
static size_t s_nGCFrequency; // Run GC after "s_nGCFrequency" operations.
GetConfigNonZeroExpected(LeapfrogPassCount, 850000000);
}
- template <typename Map, typename Key, typename Value>
- static bool map_insert(Map* map, Key key, Value value) {
- auto iter = map->insertOrFind(key);
- if (!iter.getValue() || iter.getValue() != value) {
- // Insert/update the <key,value> pair
- iter.assignValue(value);
- return true;
- } else {
- return false;
- }
- }
-
- template <typename Map, typename Key>
- static bool map_delete(Map* map, Key key) {
- auto iter = map->find(key);
- if (iter.getValue()) {
- iter.eraseValue();
- return true;
- } else {
- return false;
- }
- }
-
- template <typename Map, typename Key>
- static bool map_find(Map* map, Key key) {
- auto iter = map->find(key);
- if (iter.getValue()) {
- return true;
- } else {
- return false;
- }
- }
-
- // Specialization for CrudeMap
- template <typename Key, typename Value>
- static bool map_insert(CrudeMap* map, Key key, Value value) {
- auto old_val = map->get(key);
- if (!old_val || old_val != value) {
- map->assign(key, value);
- return true;
- } else {
- return false;
- }
- }
-
- template <typename Key> static bool map_delete(CrudeMap* map, Key key) {
- if (!map->get(key)) {
- map->assign(key, ((Key)0));
- return true;
- } else {
- return false;
- }
- }
-
- template <typename Key> static bool map_find(CrudeMap* map, Key key) {
- return map->get(key) != ((Key)0);
- }
-
template <typename Map> static void run_test(Map* map, size_t pass_count) {
auto qsbrContext = junction::DefaultQSBR.createContext();
}
} // namespace junction_test
-
-int main(int argc, char** argv) {
- // Read test config file
- cds_test::init_config(argc, argv);
-
- // Init Google test
- ::testing::InitGoogleTest(&argc, argv);
- int result = RUN_ALL_TESTS();
- return result;
-}
-#include <junction/ConcurrentMap_Crude.h>
-#include <junction/ConcurrentMap_Grampa.h>
-#include <junction/ConcurrentMap_Leapfrog.h>
-#include <junction/ConcurrentMap_Linear.h>
-
-#include <gtest/gtest.h>
-
-#include <memory>
+#include "test.h"
namespace junction_test {
-class JunctionMapInsDelFindTest : public ::testing::Test {
+class JunctionMapInsDelFindTest_Sequential : public cds_test::stress_fixture {
protected:
- typedef junction::ConcurrentMap_Grampa<size_t, size_t> GrampaMap;
- typedef junction::ConcurrentMap_Linear<size_t, size_t> LinearMap;
- typedef junction::ConcurrentMap_Leapfrog<size_t, size_t> LeapfrogMap;
- typedef junction::ConcurrentMap_Crude<size_t, size_t> CrudeMap;
-
- static const unsigned s_nInsertPercentage = 10;
- // Run GC after "kGCFrequency" operations.
- static const size_t kGCFrequency = 3000;
- static const size_t kLeapfrogGCFrequency = 1500;
-
- static const size_t kCrudeMapSize = 10000;
- static const size_t kCrudePassCount = 400000;
-
- static const size_t kGrampaMapSize = 20000;
- static const size_t kGrampaPassCount = 60000;
-
- static const size_t kLinearMapSize = 20000;
- static const size_t kLinearPassCount = 70000;
-
- static const size_t kLeapfrogMapSize = 20000;
- static const size_t kLeapfrogPassCount = 75000;
-
- static void SetUpTestCase() {}
-
- template <typename Map>
- static void run_test(size_t map_size, size_t pass_count,
- size_t gc_frequency) {
- size_t nInsertedNum = 0;
- size_t nFindSuccess = 0;
- size_t nOperations = 0;
- std::unique_ptr<Map> map(new Map());
- auto qsbrContext = junction::DefaultQSBR.createContext();
- for (size_t count = 0; count < pass_count; count++) {
- for (size_t i = 0; i < map_size; ++i) {
- // The number to operate on the map.
- size_t n = map_size + i;
- // Insert
- if (i % s_nInsertPercentage == 1) {
- auto iter = map->insertOrFind(i);
- if (!iter.getValue()) {
- iter.assignValue(n);
- nInsertedNum++;
- // std::cout << "Inserted" << i << "\n";
- }
- }
- // Find
- {
- auto iter = map->find(i);
- if (iter.getValue()) {
- ++nFindSuccess;
- // std::cout << "Found" << i << "\n";
- }
- }
- // Delete
- if (i % s_nInsertPercentage == 1) {
- auto iter = map->find(i);
- if (iter.getValue()) {
- iter.eraseValue();
- // std::cout << "Erased" << i << "\n";
- }
- }
- if (++nOperations > gc_frequency) {
- junction::DefaultQSBR.update(qsbrContext);
- nOperations = 0;
- }
- }
- }
- junction::DefaultQSBR.update(qsbrContext);
- junction::DefaultQSBR.destroyContext(qsbrContext);
- EXPECT_EQ(nFindSuccess, nInsertedNum);
+ static unsigned s_nInsertDeletePercentage;
+ static size_t s_nGCFrequency; // Run GC after "s_nGCFrequency" operations.
+ static size_t s_nMapKeyRange;
+ static size_t s_nCrudeMapCapacity;
+
+ enum actions { do_find, do_insert, do_delete };
+ static const unsigned int kShuffleSize = 100;
+ static actions s_arrShuffle[kShuffleSize];
+
+ static size_t s_nCrudePassCount;
+ static size_t s_nGrampaPassCount;
+ static size_t s_nLinearPassCount;
+ static size_t s_nLeapfrogPassCount;
+
+ static void SetUpTestCase() {
+ const cds_test::config& cfg = get_config("SequentialJunction");
+ GetConfigNonZeroExpected(InsertDeletePercentage, 5);
+ GetConfigNonZeroExpected(MapKeyRange, 20000);
+ GetConfigNonZeroExpected(CrudeMapCapacity, s_nMapKeyRange * 64);
+ GetConfigNonZeroExpected(GCFrequency, 1500);
+ GetConfigNonZeroExpected(CrudePassCount, 1500000000);
+ GetConfigNonZeroExpected(GrampaPassCount, 650000000);
+ GetConfigNonZeroExpected(LinearPassCount, 900000000);
+ GetConfigNonZeroExpected(LeapfrogPassCount, 850000000);
}
- template <typename Map>
- void run_crude_map(size_t map_size, size_t pass_count, size_t gc_frequency) {
+ template <typename Map> static void run_test(Map* map, size_t pass_count) {
+ auto qsbrContext = junction::DefaultQSBR.createContext();
size_t nInsertedNum = 0;
+ size_t nNotInsertedNum = 0;
size_t nFindSuccess = 0;
+ size_t nFindFailed = 0;
+ size_t nDeletedNum = 0;
size_t nOperations = 0;
- // Seems like the crude map won't resize, so better have a large enough
- // capacity.
- std::unique_ptr<Map> map(new Map(map_size * 32));
- auto qsbrContext = junction::DefaultQSBR.createContext();
+
+ // The number to operate on the map.
+ size_t n = s_nMapKeyRange;
for (size_t count = 0; count < pass_count; count++) {
- for (size_t i = 0; i < map_size; ++i) {
- // The number to operate on the map.
- size_t n = map_size + i;
- // Insert
- if (i % s_nInsertPercentage == 1) {
- map->assign(i, n);
- nInsertedNum++;
- // std::cout << "Inserted" << i << "\n";
- }
- // Find
- {
- if (map->get(i)) {
- ++nFindSuccess;
- // std::cout << "Found" << i << "\n";
- }
- }
- // Delete
- if (i % s_nInsertPercentage == 1) {
- if (map->get(i)) {
- map->assign(n, 0);
- // std::cout << "Erased" << i << "\n";
- }
- }
- if (++nOperations > gc_frequency) {
- junction::DefaultQSBR.update(qsbrContext);
- nOperations = 0;
- }
+ // Insert
+ unsigned mod = count % kShuffleSize;
+ if (mod < s_nInsertDeletePercentage && map_insert(map, n, n)) {
+ nInsertedNum++;
+ } else {
+ nNotInsertedNum++;
+ }
+ // Find
+ if (map_find(map, n)) {
+ ++nFindSuccess;
+ } else {
+ ++nFindFailed;
+ }
+ // Delete
+ if (mod < s_nInsertDeletePercentage && map_delete(map, n)) {
+ nDeletedNum++;
+ }
+ if (++nOperations > s_nGCFrequency) {
+ junction::DefaultQSBR.update(qsbrContext);
+ nOperations = 0;
+ }
+ if (++n == 2 * s_nMapKeyRange) {
+ n = s_nMapKeyRange;
}
}
junction::DefaultQSBR.update(qsbrContext);
junction::DefaultQSBR.destroyContext(qsbrContext);
-
- EXPECT_EQ(nFindSuccess, nInsertedNum);
+ EXPECT_EQ(nInsertedNum, nDeletedNum);
+ EXPECT_EQ(nInsertedNum, nFindSuccess);
+ EXPECT_EQ(nFindFailed, nNotInsertedNum);
}
};
-TEST_F(JunctionMapInsDelFindTest, JunctionMapCrude) {
- run_crude_map<CrudeMap>(kCrudeMapSize, kCrudePassCount, kGCFrequency);
+size_t JunctionMapInsDelFindTest_Sequential::s_nMapKeyRange;
+size_t JunctionMapInsDelFindTest_Sequential::s_nCrudeMapCapacity;
+size_t JunctionMapInsDelFindTest_Sequential::s_nGCFrequency;
+unsigned JunctionMapInsDelFindTest_Sequential::s_nInsertDeletePercentage;
+const unsigned int JunctionMapInsDelFindTest_Sequential::kShuffleSize;
+JunctionMapInsDelFindTest_Sequential::actions
+ JunctionMapInsDelFindTest_Sequential::s_arrShuffle
+ [JunctionMapInsDelFindTest_Sequential::kShuffleSize];
+size_t JunctionMapInsDelFindTest_Sequential::s_nCrudePassCount;
+size_t JunctionMapInsDelFindTest_Sequential::s_nGrampaPassCount;
+size_t JunctionMapInsDelFindTest_Sequential::s_nLinearPassCount;
+size_t JunctionMapInsDelFindTest_Sequential::s_nLeapfrogPassCount;
+
+TEST_F(JunctionMapInsDelFindTest_Sequential, JunctionMapCrude) {
+ std::unique_ptr<CrudeMap> map(new CrudeMap(s_nCrudeMapCapacity));
+ run_test(map.get(), s_nCrudePassCount);
}
-TEST_F(JunctionMapInsDelFindTest, JunctionMapLeapfrog) {
- run_test<LeapfrogMap>(kLeapfrogMapSize, kLeapfrogPassCount,
- kLeapfrogGCFrequency);
+TEST_F(JunctionMapInsDelFindTest_Sequential, JunctionMapLeapfrog) {
+ std::unique_ptr<LeapfrogMap> map(new LeapfrogMap());
+ run_test(map.get(), s_nLeapfrogPassCount);
}
-TEST_F(JunctionMapInsDelFindTest, JunctionMapLinear) {
- run_test<LinearMap>(kLinearMapSize, kLinearPassCount, kGCFrequency);
+TEST_F(JunctionMapInsDelFindTest_Sequential, JunctionMapLinear) {
+ std::unique_ptr<LinearMap> map(new LinearMap());
+ run_test(map.get(), s_nLinearPassCount);
}
-TEST_F(JunctionMapInsDelFindTest, JunctionMapGrampa) {
- run_test<GrampaMap>(kGrampaMapSize, kGrampaPassCount, kGCFrequency);
+TEST_F(JunctionMapInsDelFindTest_Sequential, JunctionMapGrampa) {
+ std::unique_ptr<GrampaMap> map(new GrampaMap());
+ run_test(map.get(), s_nGrampaPassCount);
}
} // namespace junction_test
-
-int main(int argc, char** argv) {
- // Init Google test
- ::testing::InitGoogleTest(&argc, argv);
- int result = RUN_ALL_TESTS();
- return 0;
-}
--- /dev/null
+#ifndef _JUNCTION_TEST_H
+#define _JUNCTION_TEST_H
+
+#include <junction/ConcurrentMap_Crude.h>
+#include <junction/ConcurrentMap_Grampa.h>
+#include <junction/ConcurrentMap_Leapfrog.h>
+#include <junction/ConcurrentMap_Linear.h>
+
+#include <cds_test/stress_test.h>
+#include <cds_test/stress_test_util.h>
+
+#include <algorithm>
+#include <iostream>
+#include <memory>
+#include <random>
+#include <thread>
+
+namespace junction_test {
+
+typedef junction::ConcurrentMap_Grampa<size_t, size_t> GrampaMap;
+typedef junction::ConcurrentMap_Linear<size_t, size_t> LinearMap;
+typedef junction::ConcurrentMap_Leapfrog<size_t, size_t> LeapfrogMap;
+typedef junction::ConcurrentMap_Crude<size_t, size_t> CrudeMap;
+
+template <typename Map, typename Key, typename Value>
+static bool map_insert(Map* map, Key key, Value value) {
+ auto iter = map->insertOrFind(key);
+ if (!iter.getValue() || iter.getValue() != value) {
+ // Insert/update the <key,value> pair
+ iter.assignValue(value);
+ return true;
+ } else {
+ return false;
+ }
+}
+
+template <typename Map, typename Key>
+static bool map_delete(Map* map, Key key) {
+ auto iter = map->find(key);
+ if (iter.getValue()) {
+ iter.eraseValue();
+ return true;
+ } else {
+ return false;
+ }
+}
+
+template <typename Map, typename Key> static bool map_find(Map* map, Key key) {
+ auto iter = map->find(key);
+ if (iter.getValue()) {
+ return true;
+ } else {
+ return false;
+ }
+}
+
+// Specialization for CrudeMap
+template <typename Key, typename Value>
+static bool map_insert(CrudeMap* map, Key key, Value value) {
+ auto old_val = map->get(key);
+ if (!old_val || old_val != value) {
+ map->assign(key, value);
+ return true;
+ } else {
+ return false;
+ }
+}
+
+template <typename Key> static bool map_delete(CrudeMap* map, Key key) {
+ if (map->get(key)) {
+ map->assign(key, ((Key)0));
+ return true;
+ } else {
+ return false;
+ }
+}
+
+template <typename Key> static bool map_find(CrudeMap* map, Key key) {
+ return map->get(key) != ((Key)0);
+}
+
+} // namespace junction_test
+
+#endif