diff options
author | Devtools Arcadia <arcadia-devtools@yandex-team.ru> | 2022-02-07 18:08:42 +0300 |
---|---|---|
committer | Devtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net> | 2022-02-07 18:08:42 +0300 |
commit | 1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch) | |
tree | e26c9fed0de5d9873cce7e00bc214573dc2195b7 /library/cpp/archive/yarchive_ut.cpp | |
download | ydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz |
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'library/cpp/archive/yarchive_ut.cpp')
-rw-r--r-- | library/cpp/archive/yarchive_ut.cpp | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/library/cpp/archive/yarchive_ut.cpp b/library/cpp/archive/yarchive_ut.cpp new file mode 100644 index 0000000000..602a1cdbbd --- /dev/null +++ b/library/cpp/archive/yarchive_ut.cpp @@ -0,0 +1,84 @@ +#include "yarchive.h" + +#include <library/cpp/testing/unittest/registar.h> + +#include <util/string/cast.h> +#include <util/stream/file.h> +#include <util/system/tempfile.h> +#include <util/memory/blob.h> + +class TArchiveTest: public TTestBase { + UNIT_TEST_SUITE(TArchiveTest) + UNIT_TEST(TestCreate); + UNIT_TEST(TestRead); + UNIT_TEST(TestOffsetOrder); + UNIT_TEST_SUITE_END(); + +private: + void CreateArchive(); + void TestCreate(); + void TestRead(); + void TestOffsetOrder(); +}; + +UNIT_TEST_SUITE_REGISTRATION(TArchiveTest); + +#define ARCHIVE "./test.ar" + +void TArchiveTest::CreateArchive() { + TFixedBufferFileOutput out(ARCHIVE); + TArchiveWriter w(&out); + + for (size_t i = 0; i < 1000; ++i) { + const TString path = "/" + ToString(i); + const TString data = "data" + ToString(i * 1000) + "dataend"; + TStringInput si(data); + + w.Add(path, &si); + } + + w.Finish(); + out.Finish(); +} + +void TArchiveTest::TestCreate() { + CreateArchive(); + TTempFile tmpFile(ARCHIVE); +} + +void TArchiveTest::TestRead() { + CreateArchive(); + TTempFile tmpFile(ARCHIVE); + TBlob blob = TBlob::FromFileSingleThreaded(ARCHIVE); + TArchiveReader r(blob); + + UNIT_ASSERT_EQUAL(r.Count(), 1000); + + for (size_t i = 0; i < 1000; ++i) { + const TString key = "/" + ToString(i); + TAutoPtr<IInputStream> is = r.ObjectByKey(key); + const TString data = is->ReadAll(); + + UNIT_ASSERT_EQUAL(data, "data" + ToString(i * 1000) + "dataend"); + } +} + +void TArchiveTest::TestOffsetOrder() { + CreateArchive(); + TTempFile tmpFile(ARCHIVE); + TBlob blob1 = TBlob::FromFileSingleThreaded(ARCHIVE); + TArchiveReader r(blob1); + + const void* prevOffset = nullptr; + + for (size_t i = 0; i < r.Count(); ++i) { + const TString key = r.KeyByIndex(i); + TBlob blob2 = r.BlobByKey(key); + const void* offset = blob2.Data(); + + if (i) { + UNIT_ASSERT(prevOffset < offset); + } + prevOffset = offset; + } +} |