From 48305e835351291ef72a7084c6c1af7b185d89c0 Mon Sep 17 00:00:00 2001 From: halcanary Date: Tue, 18 Aug 2015 13:30:25 -0700 Subject: SkPDF/Deflate: clean up old SkFlate code Factor out some of https://crrev.com/1227913008 BUG=skia:3030 Review URL: https://codereview.chromium.org/1298243002 --- tests/StreamTest.cpp | 58 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) (limited to 'tests/StreamTest.cpp') diff --git a/tests/StreamTest.cpp b/tests/StreamTest.cpp index 926cfc2579..78c0e506db 100644 --- a/tests/StreamTest.cpp +++ b/tests/StreamTest.cpp @@ -11,6 +11,7 @@ #include "SkOSFile.h" #include "SkRandom.h" #include "SkStream.h" +#include "SkStreamPriv.h" #include "Test.h" #ifndef SK_BUILD_FOR_WIN @@ -335,3 +336,60 @@ DEF_TEST(StreamPeek_BlockMemoryStream, rep) { } stream_peek_test(rep, asset, expected); } + +namespace { +class DumbStream : public SkStream { +public: + DumbStream(const uint8_t* data, size_t n) + : fData(data), fCount(n), fIdx(0) {} + size_t read(void* buffer, size_t size) override { + size_t c = SkTMin(fCount - fIdx, size); + if (c) { + memcpy(buffer, &fData[fIdx], size); + fIdx += c; + } + return c; + } + bool isAtEnd() const override { + return fCount > fIdx; + } + private: + const uint8_t* fData; + size_t fCount, fIdx; +}; +} // namespace + +static void stream_copy_test(skiatest::Reporter* reporter, + const void* srcData, + size_t N, + SkStream* stream) { + SkDynamicMemoryWStream tgt; + if (!SkStreamCopy(&tgt, stream)) { + ERRORF(reporter, "SkStreamCopy failed"); + return; + } + SkAutoTUnref data(tgt.copyToData()); + tgt.reset(); + if (data->size() != N) { + ERRORF(reporter, "SkStreamCopy incorrect size"); + return; + } + if (0 != memcmp(data->data(), srcData, N)) { + ERRORF(reporter, "SkStreamCopy bad copy"); + } +} + +DEF_TEST(StreamCopy, reporter) { + SkRandom random(123456); + static const size_t N = 10000; + uint8_t src[N]; + for (size_t j = 0; j < N; ++j) { + src[j] = random.nextU() & 0xff; + } + // SkStreamCopy had two code paths; this test both. + DumbStream dumbStream(src, N); + stream_copy_test(reporter, src, N, &dumbStream); + SkMemoryStream smartStream(src, N); + stream_copy_test(reporter, src, N, &smartStream); + +} -- cgit v1.2.3