aboutsummaryrefslogtreecommitdiffstats
path: root/util/generic/singleton_ut.cpp
diff options
context:
space:
mode:
authorDevtools Arcadia <arcadia-devtools@yandex-team.ru>2022-02-07 18:08:42 +0300
committerDevtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net>2022-02-07 18:08:42 +0300
commit1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch)
treee26c9fed0de5d9873cce7e00bc214573dc2195b7 /util/generic/singleton_ut.cpp
downloadydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'util/generic/singleton_ut.cpp')
-rw-r--r--util/generic/singleton_ut.cpp46
1 files changed, 46 insertions, 0 deletions
diff --git a/util/generic/singleton_ut.cpp b/util/generic/singleton_ut.cpp
new file mode 100644
index 0000000000..35ba90cd76
--- /dev/null
+++ b/util/generic/singleton_ut.cpp
@@ -0,0 +1,46 @@
+#include "singleton.h"
+
+#include <library/cpp/testing/unittest/registar.h>
+
+Y_UNIT_TEST_SUITE(TestSingleton) {
+ struct THuge {
+ char Buf[1000000];
+ int V = 1234;
+ };
+
+ Y_UNIT_TEST(TestHuge) {
+ UNIT_ASSERT_VALUES_EQUAL(*HugeSingleton<int>(), 0);
+ UNIT_ASSERT_VALUES_EQUAL(HugeSingleton<THuge>()->V, 1234);
+ }
+
+ struct TWithParams {
+ explicit TWithParams(const ui32 data1 = 0, const TString& data2 = TString())
+ : Data1(data1)
+ , Data2(data2)
+ {
+ }
+
+ ui32 Data1;
+ TString Data2;
+ };
+
+ Y_UNIT_TEST(TestConstructorParamsOrder) {
+ UNIT_ASSERT_VALUES_EQUAL(Singleton<TWithParams>(10, "123123")->Data1, 10);
+ UNIT_ASSERT_VALUES_EQUAL(Singleton<TWithParams>(20, "123123")->Data1, 10);
+ UNIT_ASSERT_VALUES_EQUAL(Singleton<TWithParams>(10, "456456")->Data2, "123123");
+ }
+
+ Y_UNIT_TEST(TestInstantiationWithConstructorParams) {
+ UNIT_ASSERT_VALUES_EQUAL(Singleton<TWithParams>(10)->Data1, 10);
+ UNIT_ASSERT_VALUES_EQUAL(HugeSingleton<TWithParams>(20, "123123")->Data2, "123123");
+ {
+ const auto value = SingletonWithPriority<TWithParams, 12312>(30, "456")->Data1;
+ UNIT_ASSERT_VALUES_EQUAL(value, 30);
+ }
+ {
+ const auto value = HugeSingletonWithPriority<TWithParams, 12311>(40, "789")->Data2;
+ UNIT_ASSERT_VALUES_EQUAL(value, "789");
+ }
+ UNIT_ASSERT_VALUES_EQUAL(Default<TWithParams>().Data1, 0);
+ }
+}