diff options
author | yurial <yurial@yandex-team.com> | 2023-11-16 13:59:02 +0300 |
---|---|---|
committer | yurial <yurial@yandex-team.com> | 2023-11-16 14:43:37 +0300 |
commit | a2fd00a24fcb20211418b797cb6191c4f1afa6ea (patch) | |
tree | 68e33195baef03090a66c0e3868c89bfd2268480 /library/cpp/yt/yson_string | |
parent | cab414f768af417824e8def2b045b5f13c5e7931 (diff) | |
download | ydb-a2fd00a24fcb20211418b797cb6191c4f1afa6ea.tar.gz |
Support Save/Load TYsonString
Diffstat (limited to 'library/cpp/yt/yson_string')
-rw-r--r-- | library/cpp/yt/yson_string/string.cpp | 22 | ||||
-rw-r--r-- | library/cpp/yt/yson_string/string.h | 4 | ||||
-rw-r--r-- | library/cpp/yt/yson_string/unittests/saveload_ut.cpp | 46 | ||||
-rw-r--r-- | library/cpp/yt/yson_string/unittests/ya.make | 1 |
4 files changed, 73 insertions, 0 deletions
diff --git a/library/cpp/yt/yson_string/string.cpp b/library/cpp/yt/yson_string/string.cpp index dec428c31e..164e450b72 100644 --- a/library/cpp/yt/yson_string/string.cpp +++ b/library/cpp/yt/yson_string/string.cpp @@ -173,6 +173,28 @@ size_t TYsonString::ComputeHash() const return THash<TStringBuf>()(TStringBuf(Begin_, Begin_ + Size_)); } +void TYsonString::Save(IOutputStream* s) const +{ + EYsonType type = Type_; + if (*this) { + ::SaveMany(s, type, ToSharedRef()); + } else { + ::SaveMany(s, type, TString()); + } +} + +void TYsonString::Load(IInputStream* s) +{ + EYsonType type; + TString data; + ::LoadMany(s, type, data); + if (data) { + *this = TYsonString(data, type); + } else { + *this = TYsonString(); + } +} + //////////////////////////////////////////////////////////////////////////////// TString ToString(const TYsonString& yson) diff --git a/library/cpp/yt/yson_string/string.h b/library/cpp/yt/yson_string/string.h index 29845b70ae..d9f036569f 100644 --- a/library/cpp/yt/yson_string/string.h +++ b/library/cpp/yt/yson_string/string.h @@ -107,6 +107,10 @@ public: //! Computes the hash code. size_t ComputeHash() const; + //! Allow to serialize/deserialize using the ::Save ::Load functions. See util/ysaveload.h. + void Save(IOutputStream* s) const; + void Load(IInputStream* s); + private: struct TNullPayload { }; diff --git a/library/cpp/yt/yson_string/unittests/saveload_ut.cpp b/library/cpp/yt/yson_string/unittests/saveload_ut.cpp new file mode 100644 index 0000000000..33a98a30ea --- /dev/null +++ b/library/cpp/yt/yson_string/unittests/saveload_ut.cpp @@ -0,0 +1,46 @@ +#include <library/cpp/testing/gtest/gtest.h> + +#include <library/cpp/testing/gtest_extensions/assertions.h> + +#include <library/cpp/yt/yson_string/string.h> + +namespace NYT::NYson { +namespace { + +//////////////////////////////////////////////////////////////////////////////// + +TEST(TYsonStringTest, SaveLoadNull) +{ + const TYsonString expected; + TStringStream s; + ::Save(&s, expected); + TYsonString result; + ::Load(&s, result); + EXPECT_EQ(expected, result); +} + +TEST(TYsonStringTest, SaveLoadString) +{ + const TYsonString expected(TString("My tests data")); + TStringStream s; + ::Save(&s, expected); + TYsonString result; + ::Load(&s, result); + EXPECT_EQ(expected, result); +} + +TEST(TYsonStringTest, SaveLoadSharedRef) +{ + TSharedRef ref = TSharedRef::FromString("My tests data"); + const TYsonString expected(ref); + TStringStream s; + ::Save(&s, expected); + TYsonString result; + ::Load(&s, result); + EXPECT_EQ(expected, result); +} + +//////////////////////////////////////////////////////////////////////////////// + +} // namespace +} // namespace NYT::NYson diff --git a/library/cpp/yt/yson_string/unittests/ya.make b/library/cpp/yt/yson_string/unittests/ya.make index f301e5b438..b584119f78 100644 --- a/library/cpp/yt/yson_string/unittests/ya.make +++ b/library/cpp/yt/yson_string/unittests/ya.make @@ -4,6 +4,7 @@ INCLUDE(${ARCADIA_ROOT}/library/cpp/yt/ya_cpp.make.inc) SRCS( convert_ut.cpp + saveload_ut.cpp ) PEERDIR( |