aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/scheme/tests/ut/scheme_cast_ut.cpp
diff options
context:
space:
mode:
authorepar <epar@yandex-team.ru>2022-02-10 16:50:02 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:50:02 +0300
commit5787a7ada46a9bc3f730ce62b840338025f911d9 (patch)
tree5d5cb817648f650d76cf1076100726fd9b8448e8 /library/cpp/scheme/tests/ut/scheme_cast_ut.cpp
parent904f1af50fdd9aae658a7b5688b5a497044c4584 (diff)
downloadydb-5787a7ada46a9bc3f730ce62b840338025f911d9.tar.gz
Restoring authorship annotation for <epar@yandex-team.ru>. Commit 2 of 2.
Diffstat (limited to 'library/cpp/scheme/tests/ut/scheme_cast_ut.cpp')
-rw-r--r--library/cpp/scheme/tests/ut/scheme_cast_ut.cpp224
1 files changed, 112 insertions, 112 deletions
diff --git a/library/cpp/scheme/tests/ut/scheme_cast_ut.cpp b/library/cpp/scheme/tests/ut/scheme_cast_ut.cpp
index 43b2270559..4f907157e9 100644
--- a/library/cpp/scheme/tests/ut/scheme_cast_ut.cpp
+++ b/library/cpp/scheme/tests/ut/scheme_cast_ut.cpp
@@ -1,94 +1,94 @@
#include <library/cpp/scheme/scheme.h>
#include <library/cpp/scheme/scheme_cast.h>
-
+
#include <library/cpp/testing/unittest/registar.h>
-
-#include <util/stream/null.h>
-#include <util/string/subst.h>
-#include <util/string/util.h>
-
-using namespace NJsonConverters;
-
+
+#include <util/stream/null.h>
+#include <util/string/subst.h>
+#include <util/string/util.h>
+
+using namespace NJsonConverters;
+
using TVI = TVector<int>;
using THI = THashMap<int, int>;
using TMI = TMap<int, int>;
using THSI = THashSet<int>;
using TSI = TSet<int>;
using TPI = std::pair<int, int>;
-
+
Y_UNIT_TEST_SUITE(TSchemeCastTest) {
Y_UNIT_TEST(TestYVector) {
- TVI v;
- for (int i = 0; i < 3; ++i)
- v.push_back(i);
-
- UNIT_ASSERT_VALUES_EQUAL("[0,1,2]", ToJson(v));
-
- TVI y(FromJson<TVI>(ToJson(v)));
- UNIT_ASSERT_VALUES_EQUAL(v.size(), y.size());
+ TVI v;
+ for (int i = 0; i < 3; ++i)
+ v.push_back(i);
+
+ UNIT_ASSERT_VALUES_EQUAL("[0,1,2]", ToJson(v));
+
+ TVI y(FromJson<TVI>(ToJson(v)));
+ UNIT_ASSERT_VALUES_EQUAL(v.size(), y.size());
UNIT_ASSERT(std::equal(v.begin(), v.end(), y.begin()));
- }
-
+ }
+
Y_UNIT_TEST(TestYHash) {
- THI h;
- for (int i = 0; i < 3; ++i)
+ THI h;
+ for (int i = 0; i < 3; ++i)
h[i] = i * i;
-
+
const TString etalon = "{\"0\":0,\"1\":1,\"2\":4}";
- UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(h, true));
-
- THI h2(FromJson<THI>(ToJson(h)));
- UNIT_ASSERT_VALUES_EQUAL(ToJson(h2, true), ToJson(h, true));
- }
-
+ UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(h, true));
+
+ THI h2(FromJson<THI>(ToJson(h)));
+ UNIT_ASSERT_VALUES_EQUAL(ToJson(h2, true), ToJson(h, true));
+ }
+
Y_UNIT_TEST(TestYMap) {
- TMI h;
- for (int i = 0; i < 3; ++i)
+ TMI h;
+ for (int i = 0; i < 3; ++i)
h[i] = i * i;
-
+
const TString etalon = "{\"0\":0,\"1\":1,\"2\":4}";
- UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(h, true));
-
- TMI h2(FromJson<TMI>(ToJson(h)));
- UNIT_ASSERT_VALUES_EQUAL(ToJson(h2, true), ToJson(h, true));
- }
-
+ UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(h, true));
+
+ TMI h2(FromJson<TMI>(ToJson(h)));
+ UNIT_ASSERT_VALUES_EQUAL(ToJson(h2, true), ToJson(h, true));
+ }
+
Y_UNIT_TEST(TestYHashSet) {
- THSI h;
- for (int i = 0; i < 3; ++i)
+ THSI h;
+ for (int i = 0; i < 3; ++i)
h.insert(i * i);
-
+
const TString etalon = "{\"0\":null,\"1\":null,\"4\":null}";
- UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(h, true));
-
- THSI h2(FromJson<THSI>(ToJson(h)));
- UNIT_ASSERT_VALUES_EQUAL(ToJson(h2, true), ToJson(h, true));
- }
-
+ UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(h, true));
+
+ THSI h2(FromJson<THSI>(ToJson(h)));
+ UNIT_ASSERT_VALUES_EQUAL(ToJson(h2, true), ToJson(h, true));
+ }
+
Y_UNIT_TEST(TestYSet) {
- TSI h;
- for (int i = 0; i < 3; ++i)
+ TSI h;
+ for (int i = 0; i < 3; ++i)
h.insert(i * i);
-
+
const TString etalon = "{\"0\":null,\"1\":null,\"4\":null}";
- UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(h, true));
-
- TSI h2(FromJson<TSI>(ToJson(h)));
- UNIT_ASSERT_VALUES_EQUAL(ToJson(h2, true), ToJson(h, true));
- }
-
+ UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(h, true));
+
+ TSI h2(FromJson<TSI>(ToJson(h)));
+ UNIT_ASSERT_VALUES_EQUAL(ToJson(h2, true), ToJson(h, true));
+ }
+
Y_UNIT_TEST(TestTPair) {
TPI p(1, 1);
-
+
const TString etalon = "[1,1]";
- UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(p, true));
-
- TPI p2(FromJson<TPI>(ToJson(p)));
- UNIT_ASSERT_VALUES_EQUAL(ToJson(p2, true), ToJson(p, true));
- }
-
- struct TCustom: public IJsonSerializable {
- int A, B;
+ UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(p, true));
+
+ TPI p2(FromJson<TPI>(ToJson(p)));
+ UNIT_ASSERT_VALUES_EQUAL(ToJson(p2, true), ToJson(p, true));
+ }
+
+ struct TCustom: public IJsonSerializable {
+ int A, B;
TCustom()
: A(0)
, B(0){};
@@ -98,65 +98,65 @@ Y_UNIT_TEST_SUITE(TSchemeCastTest) {
{
}
NSc::TValue ToTValue() const override {
- NSc::TValue res;
- res["a"] = A;
- res["b"] = B;
- return res;
- }
+ NSc::TValue res;
+ res["a"] = A;
+ res["b"] = B;
+ return res;
+ }
void FromTValue(const NSc::TValue& v, const bool) override {
- A = v["a"].GetNumber();
- B = v["b"].GetNumber();
- }
-
+ A = v["a"].GetNumber();
+ B = v["b"].GetNumber();
+ }
+
bool operator<(const TCustom& rhs) const {
- return A < rhs.A;
- }
- };
-
+ return A < rhs.A;
+ }
+ };
+
Y_UNIT_TEST(TestTCustom) {
- TCustom x(2, 3);
-
+ TCustom x(2, 3);
+
const TString etalon = "{\"a\":2,\"b\":3}";
- UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(x, true));
-
- TCustom x2(FromJson<TCustom>(ToJson(x)));
- UNIT_ASSERT_VALUES_EQUAL(ToJson(x2, true), ToJson(x, true));
- }
-
+ UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(x, true));
+
+ TCustom x2(FromJson<TCustom>(ToJson(x)));
+ UNIT_ASSERT_VALUES_EQUAL(ToJson(x2, true), ToJson(x, true));
+ }
+
Y_UNIT_TEST(TestVectorOfPairs) {
typedef TVector<TPI> TVPI;
- TVPI v;
-
- for (int i = 0; i < 3; ++i)
+ TVPI v;
+
+ for (int i = 0; i < 3; ++i)
v.push_back(TPI(i, i * i));
-
+
const TString etalon = "[[0,0],[1,1],[2,4]]";
- UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(v, true));
-
- TVPI v2(FromJson<TVPI>(ToJson(v)));
- UNIT_ASSERT_VALUES_EQUAL(ToJson(v2, true), ToJson(v, true));
- }
-
+ UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(v, true));
+
+ TVPI v2(FromJson<TVPI>(ToJson(v)));
+ UNIT_ASSERT_VALUES_EQUAL(ToJson(v2, true), ToJson(v, true));
+ }
+
Y_UNIT_TEST(TestSetOfCustom) {
typedef TSet<TCustom> TSC;
- TSC s;
+ TSC s;
s.insert(TCustom(2, 3));
-
+
const TString etalon = "{\"{\\\"a\\\":2,\\\"b\\\":3}\":null}";
- UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(s, true));
-
- TSC s2(FromJson<TSC>(ToJson(s)));
- UNIT_ASSERT_VALUES_EQUAL(ToJson(s2, true), ToJson(s, true));
- }
-
+ UNIT_ASSERT_VALUES_EQUAL(etalon, ToJson(s, true));
+
+ TSC s2(FromJson<TSC>(ToJson(s)));
+ UNIT_ASSERT_VALUES_EQUAL(ToJson(s2, true), ToJson(s, true));
+ }
+
Y_UNIT_TEST(TestExceptions) {
- NSc::TValue v = 1;
+ NSc::TValue v = 1;
const TString json = v.ToJson();
- UNIT_ASSERT_EXCEPTION(FromJson<TVI>(json, true), yexception);
- UNIT_ASSERT_EXCEPTION(FromJson<THI>(json, true), yexception);
- UNIT_ASSERT_EXCEPTION(FromJson<TMI>(json, true), yexception);
- UNIT_ASSERT_EXCEPTION(FromJson<THSI>(json, true), yexception);
- UNIT_ASSERT_EXCEPTION(FromJson<TSI>(json, true), yexception);
- UNIT_ASSERT_EXCEPTION(FromJson<TPI>(json, true), yexception);
- }
-};
+ UNIT_ASSERT_EXCEPTION(FromJson<TVI>(json, true), yexception);
+ UNIT_ASSERT_EXCEPTION(FromJson<THI>(json, true), yexception);
+ UNIT_ASSERT_EXCEPTION(FromJson<TMI>(json, true), yexception);
+ UNIT_ASSERT_EXCEPTION(FromJson<THSI>(json, true), yexception);
+ UNIT_ASSERT_EXCEPTION(FromJson<TSI>(json, true), yexception);
+ UNIT_ASSERT_EXCEPTION(FromJson<TPI>(json, true), yexception);
+ }
+};