aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/SerializationTest.cpp
diff options
context:
space:
mode:
authorGravatar Mike Reed <reed@google.com>2018-03-14 09:52:02 -0400
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2018-03-14 14:20:42 +0000
commit253258419b01675a43a80f5f04eb1013d9f2b6d5 (patch)
tree91aa67afc11651dc2b8a2bb4f09518e61c4edd88 /tests/SerializationTest.cpp
parent7d2b16ad13fd3262c776ae75ae35da4ad69df690 (diff)
add explicit API to know if the writebuffer is using its external storage
To help with https://skia-review.googlesource.com/c/skia/+/114262 Bug: skia: Change-Id: I83fcccdec0dbaef28d0e557ea6fb9bd0ed59ed44 Reviewed-on: https://skia-review.googlesource.com/114284 Commit-Queue: Mike Reed <reed@google.com> Reviewed-by: Mike Reed <reed@google.com>
Diffstat (limited to 'tests/SerializationTest.cpp')
-rw-r--r--tests/SerializationTest.cpp29
1 files changed, 29 insertions, 0 deletions
diff --git a/tests/SerializationTest.cpp b/tests/SerializationTest.cpp
index 2543870667..da797398c1 100644
--- a/tests/SerializationTest.cpp
+++ b/tests/SerializationTest.cpp
@@ -637,3 +637,32 @@ DEF_TEST(Annotations, reporter) {
TestAnnotationCanvas canvas(reporter, recs, SK_ARRAY_COUNT(recs));
canvas.drawPicture(pict1);
}
+
+DEF_TEST(WriteBuffer_storage, reporter) {
+ enum {
+ kSize = 32
+ };
+ int32_t storage[kSize/4];
+ char src[kSize];
+ sk_bzero(src, kSize);
+
+ SkBinaryWriteBuffer writer(storage, kSize);
+ REPORTER_ASSERT(reporter, writer.usingInitialStorage());
+ REPORTER_ASSERT(reporter, writer.bytesWritten() == 0);
+ writer.write(src, kSize - 4);
+ REPORTER_ASSERT(reporter, writer.usingInitialStorage());
+ REPORTER_ASSERT(reporter, writer.bytesWritten() == kSize - 4);
+ writer.writeInt(0);
+ REPORTER_ASSERT(reporter, writer.usingInitialStorage());
+ REPORTER_ASSERT(reporter, writer.bytesWritten() == kSize);
+
+ writer.reset(storage, kSize-4);
+ REPORTER_ASSERT(reporter, writer.usingInitialStorage());
+ REPORTER_ASSERT(reporter, writer.bytesWritten() == 0);
+ writer.write(src, kSize - 4);
+ REPORTER_ASSERT(reporter, writer.usingInitialStorage());
+ REPORTER_ASSERT(reporter, writer.bytesWritten() == kSize - 4);
+ writer.writeInt(0);
+ REPORTER_ASSERT(reporter, !writer.usingInitialStorage()); // this is the change
+ REPORTER_ASSERT(reporter, writer.bytesWritten() == kSize);
+}