Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1071)

Unified Diff: tests/PipeTest.cpp

Issue 2347593004: test/fix/tweak writePicture/readPicture (Closed)
Patch Set: remove dead code Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/pipe/SkPipeReader.cpp ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/PipeTest.cpp
diff --git a/tests/PipeTest.cpp b/tests/PipeTest.cpp
index 7f42071a7564cf6548b2aeec286f83f50c8f60be..3b89441f32635dfbae4e9c5f55f958ab7b23cdf1 100644
--- a/tests/PipeTest.cpp
+++ b/tests/PipeTest.cpp
@@ -15,6 +15,7 @@
#include "SkNullCanvas.h"
#include "SkAutoPixmapStorage.h"
+#include "SkPictureRecorder.h"
static void drain(SkPipeDeserializer* deserial, SkDynamicMemoryWStream* stream) {
std::unique_ptr<SkCanvas> canvas(SkCreateNullCanvas());
@@ -22,11 +23,6 @@ static void drain(SkPipeDeserializer* deserial, SkDynamicMemoryWStream* stream)
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;
@@ -73,17 +69,17 @@ DEF_TEST(Pipe_image_draw_first, reporter) {
drain(&deserializer, &stream);
// try serializing the same image directly, again it should be small
- serializer.write(img.get(), &stream);
- size_t offset2 = stream.bytesWritten();
+ sk_sp<SkData> data = serializer.writeImage(img.get());
+ size_t offset2 = data->size();
REPORTER_ASSERT(reporter, offset2 <= 32);
- auto img1 = drain_as_image(&deserializer, &stream);
+ auto img1 = deserializer.readImage(data.get());
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();
+ data = serializer.writeImage(img.get());
+ size_t offset3 = data->size();
REPORTER_ASSERT(reporter, offset3 <= 32);
- auto img2 = drain_as_image(&deserializer, &stream);
+ auto img2 = deserializer.readImage(data.get());
REPORTER_ASSERT(reporter, img1.get() == img2.get());
}
@@ -95,21 +91,97 @@ DEF_TEST(Pipe_image_draw_second, reporter) {
SkPipeDeserializer deserializer;
SkDynamicMemoryWStream stream;
- serializer.write(img.get(), &stream);
- size_t offset0 = stream.bytesWritten();
+ sk_sp<SkData> data = serializer.writeImage(img.get());
+ size_t offset0 = data->size();
REPORTER_ASSERT(reporter, offset0 > 100); // the raw image must be sorta big
- drain_as_image(&deserializer, &stream);
+ auto img1 = deserializer.readImage(data.get());
// The 2nd image should be nice and small
- serializer.write(img.get(), &stream);
- size_t offset1 = stream.bytesWritten();
- REPORTER_ASSERT(reporter, offset1 <= 32);
- drain_as_image(&deserializer, &stream);
+ data = serializer.writeImage(img.get());
+ size_t offset1 = data->size();
+ REPORTER_ASSERT(reporter, offset1 <= 16);
+ auto img2 = deserializer.readImage(data.get());
+ REPORTER_ASSERT(reporter, img1.get() == img2.get());
// Now try drawing the image, it should also be small
SkCanvas* wc = serializer.beginWrite(SkRect::MakeWH(100, 100), &stream);
wc->drawImage(img, 0, 0, nullptr);
serializer.endWrite();
size_t offset2 = stream.bytesWritten();
- REPORTER_ASSERT(reporter, offset2 <= 32);
+ REPORTER_ASSERT(reporter, offset2 <= 16);
+}
+
+DEF_TEST(Pipe_picture_draw_first, reporter) {
+ sk_sp<SkPicture> picture = []() {
+ SkPictureRecorder rec;
+ SkCanvas* c = rec.beginRecording(SkRect::MakeWH(100, 100));
+ for (int i = 0; i < 100; ++i) {
+ c->drawColor(i);
+ }
+ return rec.finishRecordingAsPicture();
+ }();
+ SkPipeSerializer serializer;
+ SkPipeDeserializer deserializer;
+
+ SkDynamicMemoryWStream stream;
+ SkCanvas* wc = serializer.beginWrite(SkRect::MakeWH(100, 100), &stream);
+ wc->drawPicture(picture);
+ serializer.endWrite();
+ size_t offset0 = stream.bytesWritten();
+ REPORTER_ASSERT(reporter, offset0 > 100); // the raw picture must be sorta big
+ drain(&deserializer, &stream);
+
+ // try drawing the same picture again -- it should be much smaller
+ wc = serializer.beginWrite(SkRect::MakeWH(100, 100), &stream);
+ wc->drawPicture(picture);
+ size_t offset1 = stream.bytesWritten();
+ serializer.endWrite();
+ REPORTER_ASSERT(reporter, offset1 <= 16);
+ drain(&deserializer, &stream);
+
+ // try writing the picture directly, it should also be small
+ sk_sp<SkData> data = serializer.writePicture(picture.get());
+ size_t offset2 = data->size();
+ REPORTER_ASSERT(reporter, offset2 <= 16);
+ auto pic1 = deserializer.readPicture(data.get());
+
+ // try writing the picture directly, it should also be small
+ data = serializer.writePicture(picture.get());
+ size_t offset3 = data->size();
+ REPORTER_ASSERT(reporter, offset3 == offset2);
+ auto pic2 = deserializer.readPicture(data.get());
+ REPORTER_ASSERT(reporter, pic1.get() == pic2.get());
+}
+
+DEF_TEST(Pipe_picture_draw_second, reporter) {
+ sk_sp<SkPicture> picture = []() {
+ SkPictureRecorder rec;
+ SkCanvas* c = rec.beginRecording(SkRect::MakeWH(100, 100));
+ for (int i = 0; i < 100; ++i) {
+ c->drawColor(i);
+ }
+ return rec.finishRecordingAsPicture();
+ }();
+ SkPipeSerializer serializer;
+ SkPipeDeserializer deserializer;
+ SkDynamicMemoryWStream stream;
+
+ sk_sp<SkData> data = serializer.writePicture(picture.get());
+ size_t offset0 = data->size();
+ REPORTER_ASSERT(reporter, offset0 > 100); // the raw picture must be sorta big
+ auto pic1 = deserializer.readPicture(data.get());
+
+ // The 2nd picture should be nice and small
+ data = serializer.writePicture(picture.get());
+ size_t offset1 = data->size();
+ REPORTER_ASSERT(reporter, offset1 <= 16);
+ auto pic2 = deserializer.readPicture(data.get());
+ SkASSERT(pic1.get() == pic2.get());
+
+ // Now try drawing the image, it should also be small
+ SkCanvas* wc = serializer.beginWrite(SkRect::MakeWH(100, 100), &stream);
+ wc->drawPicture(picture);
+ serializer.endWrite();
+ size_t offset2 = stream.bytesWritten();
+ REPORTER_ASSERT(reporter, offset2 <= 16);
}
« no previous file with comments | « src/pipe/SkPipeReader.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698