aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/openssl/big_integer/ut/big_integer_ut.cpp
diff options
context:
space:
mode:
authorkomels <komels@yandex-team.ru>2022-04-14 13:10:53 +0300
committerkomels <komels@yandex-team.ru>2022-04-14 13:10:53 +0300
commit21c9b0e6b039e9765eb414c406c2b86e8cea6850 (patch)
treef40ebc18ff8958dfbd189954ad024043ca983ea5 /library/cpp/openssl/big_integer/ut/big_integer_ut.cpp
parent9a4effa852abe489707139c2b260dccc6f4f9aa9 (diff)
downloadydb-21c9b0e6b039e9765eb414c406c2b86e8cea6850.tar.gz
Final part on compatibility layer: LOGBROKER-7215
ref:777c67aadbf705d19034a09a792b2df61ba53697
Diffstat (limited to 'library/cpp/openssl/big_integer/ut/big_integer_ut.cpp')
-rw-r--r--library/cpp/openssl/big_integer/ut/big_integer_ut.cpp43
1 files changed, 43 insertions, 0 deletions
diff --git a/library/cpp/openssl/big_integer/ut/big_integer_ut.cpp b/library/cpp/openssl/big_integer/ut/big_integer_ut.cpp
new file mode 100644
index 0000000000..8a0050f531
--- /dev/null
+++ b/library/cpp/openssl/big_integer/ut/big_integer_ut.cpp
@@ -0,0 +1,43 @@
+#include "big_integer.h"
+
+#include <library/cpp/testing/unittest/registar.h>
+
+#include <util/system/byteorder.h>
+#include <util/stream/str.h>
+
+Y_UNIT_TEST_SUITE(BigInteger) {
+ using NOpenSsl::TBigInteger;
+
+ Y_UNIT_TEST(Initialization) {
+ constexpr ui64 testVal = 12345678900;
+ const auto fromULong = TBigInteger::FromULong(testVal);
+
+ const ui64 testArea = HostToInet(testVal); // transform to big-endian
+ const auto fromRegion = TBigInteger::FromRegion(&testArea, sizeof(testArea));
+ UNIT_ASSERT(fromULong == fromRegion);
+ UNIT_ASSERT_VALUES_EQUAL(fromULong, fromRegion);
+
+ const auto fromULongOther = TBigInteger::FromULong(22345678900);
+ UNIT_ASSERT(fromULong != fromULongOther);
+ }
+
+ Y_UNIT_TEST(Decimal) {
+ UNIT_ASSERT_VALUES_EQUAL(TBigInteger::FromULong(123456789).ToDecimalString(), "123456789");
+ }
+
+ Y_UNIT_TEST(Region) {
+ const auto v1 = TBigInteger::FromULong(1234567890);
+ char buf[1024];
+ const auto v2 = TBigInteger::FromRegion(buf, v1.ToRegion(buf));
+
+ UNIT_ASSERT_VALUES_EQUAL(v1, v2);
+ }
+
+ Y_UNIT_TEST(Output) {
+ TStringStream ss;
+
+ ss << TBigInteger::FromULong(123456789);
+
+ UNIT_ASSERT_VALUES_EQUAL(ss.Str(), "123456789");
+ }
+}