diff options
author | 2016-09-13 08:09:45 -0700 | |
---|---|---|
committer | 2016-09-13 08:09:45 -0700 | |
commit | 54dc4878b02765efea39e68b218df1e4bfff4b88 (patch) | |
tree | 296347d73c08b8b1d0a0b244ca062434ac48caa1 /tests/PipeTest.cpp | |
parent | 5f1d0f61ea182829826d9d76cb85346d3e23305d (diff) |
add pipecanvas
BUG=skia:
GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2201323003
Review-Url: https://codereview.chromium.org/2201323003
Diffstat (limited to 'tests/PipeTest.cpp')
-rw-r--r-- | tests/PipeTest.cpp | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/tests/PipeTest.cpp b/tests/PipeTest.cpp new file mode 100644 index 0000000000..f345debb8c --- /dev/null +++ b/tests/PipeTest.cpp @@ -0,0 +1,88 @@ +/* + * Copyright 2016 Google Inc. + * + * Use of this source code is governed by a BSD-style license that can be + * found in the LICENSE file. + */ + +#include "Resources.h" +#include "SkCanvas.h" +#include "SkPipe.h" +#include "SkPaint.h" +#include "SkStream.h" +#include "SkSurface.h" +#include "Test.h" + +#include "SkNullCanvas.h" +#include "SkAutoPixmapStorage.h" + +static void drain(SkPipeDeserializer* deserial, SkDynamicMemoryWStream* stream) { + std::unique_ptr<SkCanvas> canvas(SkCreateNullCanvas()); + sk_sp<SkData> data = stream->detachAsData(); + deserial->playback(data->data(), data->size(), canvas.get()); +} + +static sk_sp<SkImage> drain_as_image(SkPipeDeserializer* deserial, SkDynamicMemoryWStream* stream) { + sk_sp<SkData> data = stream->detachAsData(); + return deserial->readImage(data->data(), data->size()); +} + +static bool deep_equal(SkImage* a, SkImage* b) { + if (a->width() != b->width() || a->height() != b->height()) { + return false; + } + + const SkImageInfo info = SkImageInfo::MakeN32Premul(a->width(), a->height()); + SkAutoPixmapStorage pmapA, pmapB; + pmapA.alloc(info); + pmapB.alloc(info); + + if (!a->readPixels(pmapA, 0, 0) || !b->readPixels(pmapB, 0, 0)) { + return false; + } + + for (int y = 0; y < info.height(); ++y) { + if (memcmp(pmapA.addr32(0, y), pmapB.addr32(0, y), info.width() * sizeof(SkPMColor))) { + return false; + } + } + return true; +} + +DEF_TEST(Pipe_image, reporter) { + sk_sp<SkImage> img = GetResourceAsImage("mandrill_128.png"); + SkASSERT(img.get()); + + SkPipeSerializer serializer; + SkPipeDeserializer deserializer; + + SkDynamicMemoryWStream stream; + SkCanvas* wc = serializer.beginWrite(SkRect::MakeWH(100, 100), &stream); + wc->drawImage(img, 0, 0, nullptr); + serializer.endWrite(); + size_t offset0 = stream.bytesWritten(); + REPORTER_ASSERT(reporter, offset0 > 100); // the raw image must be sorta big + drain(&deserializer, &stream); + + // try drawing the same image again -- it should be much smaller + wc = serializer.beginWrite(SkRect::MakeWH(100, 100), &stream); + wc->drawImage(img, 0, 0, nullptr); + size_t offset1 = stream.bytesWritten(); + serializer.endWrite(); + REPORTER_ASSERT(reporter, offset1 <= 32); + drain(&deserializer, &stream); + + // try serializing the same image directly, again it should be small + serializer.write(img.get(), &stream); + size_t offset2 = stream.bytesWritten(); + REPORTER_ASSERT(reporter, offset2 <= 32); + auto img1 = drain_as_image(&deserializer, &stream); + REPORTER_ASSERT(reporter, deep_equal(img.get(), img1.get())); + + // try serializing the same image directly (again), check that it is the same! + serializer.write(img.get(), &stream); + size_t offset3 = stream.bytesWritten(); + REPORTER_ASSERT(reporter, offset3 <= 32); + auto img2 = drain_as_image(&deserializer, &stream); + REPORTER_ASSERT(reporter, img1.get() == img2.get()); +} |