Chromium Code Reviews| Index: tests/SerializationTest.cpp | 
| diff --git a/tests/SerializationTest.cpp b/tests/SerializationTest.cpp | 
| index d2c692526f62bf3a673aba38568f2a19a7b6f95a..f047ec128470f3393a3ecabac652340eb16a98c2 100644 | 
| --- a/tests/SerializationTest.cpp | 
| +++ b/tests/SerializationTest.cpp | 
| @@ -9,140 +9,202 @@ | 
| #include "SkValidatingReadBuffer.h" | 
| #include "Test.h" | 
| -static void Tests(skiatest::Reporter* reporter) { | 
| - { | 
| - static const uint32_t arraySize = 512; | 
| - unsigned char data[arraySize] = {0}; | 
| - SkOrderedWriteBuffer writer(1024); | 
| - writer.setFlags(SkOrderedWriteBuffer::kValidation_Flag); | 
| - writer.writeByteArray(data, arraySize); | 
| - uint32_t bytesWritten = writer.bytesWritten(); | 
| - // This should write the length (in 4 bytes) and the array | 
| - REPORTER_ASSERT(reporter, (4 + arraySize) == bytesWritten); | 
| +static const uint32_t kArraySize = 64; | 
| + | 
| +template<typename T> | 
| +static void TestAlignment(T* testObj, skiatest::Reporter* reporter) { | 
| + // Test memory read/write functions directly | 
| + unsigned char dataWritten[1024]; | 
| + size_t bytesWrittenToMemory = testObj->writeToMemory(dataWritten); | 
| + REPORTER_ASSERT(reporter, SkAlign4(bytesWrittenToMemory) == bytesWrittenToMemory); | 
| + size_t bytesReadFromMemory = testObj->readFromMemory(dataWritten, bytesWrittenToMemory); | 
| + REPORTER_ASSERT(reporter, SkAlign4(bytesReadFromMemory) == bytesReadFromMemory); | 
| +} | 
| - unsigned char dataWritten[1024]; | 
| - writer.writeToMemory(dataWritten); | 
| +template<typename T> struct SerializationUtils { | 
| +}; | 
| - // Make sure this fails when it should | 
| - SkValidatingReadBuffer buffer(dataWritten, bytesWritten); | 
| - unsigned char dataRead[arraySize]; | 
| - bool success = buffer.readByteArray(dataRead, 256); | 
| - // This should have failed, since 256 < sizeInBytes | 
| - REPORTER_ASSERT(reporter, !success); | 
| +template<> struct SerializationUtils<SkMatrix> { | 
| + static void Write(SkOrderedWriteBuffer& writer, const SkMatrix* matrix) { | 
| + writer.writeMatrix(*matrix); | 
| + } | 
| + static void Read(SkValidatingReadBuffer& reader, SkMatrix* matrix) { | 
| + reader.readMatrix(matrix); | 
| + } | 
| +}; | 
| - // Make sure this succeeds when it should | 
| - SkValidatingReadBuffer buffer2(dataWritten, bytesWritten); | 
| - success = buffer2.readByteArray(dataRead, arraySize); | 
| - // This should have succeeded, since there are enough bytes to read this | 
| - REPORTER_ASSERT(reporter, success); | 
| +template<> struct SerializationUtils<SkPath> { | 
| + static void Write(SkOrderedWriteBuffer& writer, const SkPath* path) { | 
| + writer.writePath(*path); | 
| } | 
| + static void Read(SkValidatingReadBuffer& reader, SkPath* path) { | 
| + reader.readPath(path); | 
| + } | 
| +}; | 
| - { | 
| - static const uint32_t arraySize = 64; | 
| - SkColor data[arraySize]; | 
| - SkOrderedWriteBuffer writer(1024); | 
| - writer.setFlags(SkOrderedWriteBuffer::kValidation_Flag); | 
| +template<> struct SerializationUtils<SkRegion> { | 
| + static void Write(SkOrderedWriteBuffer& writer, const SkRegion* region) { | 
| + writer.writeRegion(*region); | 
| + } | 
| + static void Read(SkValidatingReadBuffer& reader, SkRegion* region) { | 
| + reader.readRegion(region); | 
| + } | 
| +}; | 
| + | 
| +template<> struct SerializationUtils<unsigned char> { | 
| + static void Write(SkOrderedWriteBuffer& writer, unsigned char* data, uint32_t arraySize) { | 
| + writer.writeByteArray(data, arraySize); | 
| + } | 
| + static bool Read(SkValidatingReadBuffer& reader, unsigned char* data, uint32_t arraySize) { | 
| + return reader.readByteArray(data, arraySize); | 
| + } | 
| +}; | 
| + | 
| +template<> struct SerializationUtils<SkColor> { | 
| + static void Write(SkOrderedWriteBuffer& writer, SkColor* data, uint32_t arraySize) { | 
| writer.writeColorArray(data, arraySize); | 
| - uint32_t bytesWritten = writer.bytesWritten(); | 
| - // This should write the length (in 4 bytes) and the array | 
| - REPORTER_ASSERT(reporter, (4 + arraySize * sizeof(SkColor)) == bytesWritten); | 
| + } | 
| + static bool Read(SkValidatingReadBuffer& reader, SkColor* data, uint32_t arraySize) { | 
| + return reader.readColorArray(data, arraySize); | 
| + } | 
| +}; | 
| - unsigned char dataWritten[1024]; | 
| - writer.writeToMemory(dataWritten); | 
| +template<> struct SerializationUtils<int32_t> { | 
| + static void Write(SkOrderedWriteBuffer& writer, int32_t* data, uint32_t arraySize) { | 
| + writer.writeIntArray(data, arraySize); | 
| + } | 
| + static bool Read(SkValidatingReadBuffer& reader, int32_t* data, uint32_t arraySize) { | 
| + return reader.readIntArray(data, arraySize); | 
| + } | 
| +}; | 
| - // Make sure this fails when it should | 
| - SkValidatingReadBuffer buffer(dataWritten, bytesWritten); | 
| - SkColor dataRead[arraySize]; | 
| - bool success = buffer.readColorArray(dataRead, 32); | 
| - // This should have failed, since 256 < sizeInBytes | 
| - REPORTER_ASSERT(reporter, !success); | 
| +template<> struct SerializationUtils<SkPoint> { | 
| + static void Write(SkOrderedWriteBuffer& writer, SkPoint* data, uint32_t arraySize) { | 
| + writer.writePointArray(data, arraySize); | 
| + } | 
| + static bool Read(SkValidatingReadBuffer& reader, SkPoint* data, uint32_t arraySize) { | 
| + return reader.readPointArray(data, arraySize); | 
| + } | 
| +}; | 
| - // Make sure this succeeds when it should | 
| - SkValidatingReadBuffer buffer2(dataWritten, bytesWritten); | 
| - success = buffer2.readColorArray(dataRead, arraySize); | 
| - // This should have succeeded, since there are enough bytes to read this | 
| - REPORTER_ASSERT(reporter, success); | 
| +template<> struct SerializationUtils<SkScalar> { | 
| + static void Write(SkOrderedWriteBuffer& writer, SkScalar* data, uint32_t arraySize) { | 
| + writer.writeScalarArray(data, arraySize); | 
| + } | 
| + static bool Read(SkValidatingReadBuffer& reader, SkScalar* data, uint32_t arraySize) { | 
| + return reader.readScalarArray(data, arraySize); | 
| } | 
| +}; | 
| + | 
| +template<typename T> | 
| +static void TestObjectSerialization(T* testObj, skiatest::Reporter* reporter) { | 
| + SkOrderedWriteBuffer writer(1024); | 
| + writer.setFlags(SkOrderedWriteBuffer::kValidation_Flag); | 
| + SerializationUtils<T>::Write(writer, testObj); | 
| + size_t bytesWritten = writer.bytesWritten(); | 
| + REPORTER_ASSERT(reporter, SkAlign4(bytesWritten) == bytesWritten); | 
| + | 
| + unsigned char dataWritten[1024]; | 
| + writer.writeToMemory(dataWritten); | 
| + | 
| + // Make sure this fails when it should (test with smaller size, but still multiple of 4) | 
| + SkValidatingReadBuffer buffer(dataWritten, bytesWritten - 4); | 
| + const unsigned char* peekBefore = static_cast<const unsigned char*>(buffer.skip(0)); | 
| + SerializationUtils<T>::Read(buffer, testObj); | 
| + const unsigned char* peekAfter = static_cast<const unsigned char*>(buffer.skip(0)); | 
| + // This should have failed, since the buffer is too small to read a matrix from it | 
| + REPORTER_ASSERT(reporter, peekBefore == peekAfter); | 
| + | 
| + // Make sure this succeeds when it should | 
| + SkValidatingReadBuffer buffer2(dataWritten, bytesWritten); | 
| + peekBefore = static_cast<const unsigned char*>(buffer2.skip(0)); | 
| + SerializationUtils<T>::Read(buffer2, testObj); | 
| + peekAfter = static_cast<const unsigned char*>(buffer2.skip(0)); | 
| + // This should have succeeded, since there are enough bytes to read this | 
| + REPORTER_ASSERT(reporter, static_cast<size_t>(peekAfter - peekBefore) == bytesWritten); | 
| + | 
| + TestAlignment(testObj, reporter); | 
| +} | 
| + | 
| +template<typename T> | 
| +static void TestArraySerialization(T* data, skiatest::Reporter* reporter) { | 
| + SkOrderedWriteBuffer writer(1024); | 
| + writer.setFlags(SkOrderedWriteBuffer::kValidation_Flag); | 
| + SerializationUtils<T>::Write(writer, data, kArraySize); | 
| + size_t bytesWritten = writer.bytesWritten(); | 
| + // This should write the length (in 4 bytes) and the array | 
| + REPORTER_ASSERT(reporter, (4 + kArraySize * sizeof(T)) == bytesWritten); | 
| + | 
| + unsigned char dataWritten[1024]; | 
| + writer.writeToMemory(dataWritten); | 
| + | 
| + // Make sure this fails when it should | 
| + SkValidatingReadBuffer buffer(dataWritten, bytesWritten); | 
| + T dataRead[kArraySize]; | 
| + bool success = SerializationUtils<T>::Read(buffer, dataRead, kArraySize / 2); | 
| + // This should have failed, since the provided size was too small | 
| + REPORTER_ASSERT(reporter, !success); | 
| + | 
| + // Make sure this succeeds when it should | 
| + SkValidatingReadBuffer buffer2(dataWritten, bytesWritten); | 
| + success = SerializationUtils<T>::Read(buffer2, dataRead, kArraySize); | 
| + // This should have succeeded, since there are enough bytes to read this | 
| + REPORTER_ASSERT(reporter, success); | 
| +} | 
| +static void Tests(skiatest::Reporter* reporter) { | 
| + // Test matrix serialization | 
| { | 
| - static const uint32_t arraySize = 64; | 
| - int32_t data[arraySize]; | 
| - SkOrderedWriteBuffer writer(1024); | 
| - writer.setFlags(SkOrderedWriteBuffer::kValidation_Flag); | 
| - writer.writeIntArray(data, arraySize); | 
| - uint32_t bytesWritten = writer.bytesWritten(); | 
| - // This should write the length (in 4 bytes) and the array | 
| - REPORTER_ASSERT(reporter, (4 + arraySize * sizeof(int32_t)) == bytesWritten); | 
| + SkMatrix matrix = SkMatrix::I(); | 
| + TestObjectSerialization(&matrix, reporter); | 
| + } | 
| - unsigned char dataWritten[1024]; | 
| - writer.writeToMemory(dataWritten); | 
| + // Test path serialization | 
| + { | 
| + SkPath path; | 
| + TestObjectSerialization(&path, reporter); | 
| + } | 
| - // Make sure this fails when it should | 
| - SkValidatingReadBuffer buffer(dataWritten, bytesWritten); | 
| - int32_t dataRead[arraySize]; | 
| - bool success = buffer.readIntArray(dataRead, 32); | 
| - // This should have failed, since 256 < sizeInBytes | 
| - REPORTER_ASSERT(reporter, !success); | 
| + // Test region serialization | 
| + { | 
| + SkRegion region; | 
| + TestObjectSerialization(®ion, reporter); | 
| + } | 
| - // Make sure this succeeds when it should | 
| - SkValidatingReadBuffer buffer2(dataWritten, bytesWritten); | 
| - success = buffer2.readIntArray(dataRead, arraySize); | 
| - // This should have succeeded, since there are enough bytes to read this | 
| - REPORTER_ASSERT(reporter, success); | 
| + // Test rrect serialization | 
| + { | 
| + SkRRect rrect; | 
| + TestAlignment(&rrect, reporter); | 
| 
 
bungeman-skia
2013/11/27 17:11:26
This test is causing Valgrind to complain about Sk
 
 | 
| } | 
| + // Test readByteArray | 
| { | 
| - static const uint32_t arraySize = 64; | 
| - SkPoint data[arraySize]; | 
| - SkOrderedWriteBuffer writer(1024); | 
| - writer.setFlags(SkOrderedWriteBuffer::kValidation_Flag); | 
| - writer.writePointArray(data, arraySize); | 
| - uint32_t bytesWritten = writer.bytesWritten(); | 
| - // This should write the length (in 4 bytes) and the array | 
| - REPORTER_ASSERT(reporter, (4 + arraySize * sizeof(SkPoint)) == bytesWritten); | 
| + unsigned char data[kArraySize] = {0}; | 
| + TestArraySerialization(data, reporter); | 
| + } | 
| - unsigned char dataWritten[1024]; | 
| - writer.writeToMemory(dataWritten); | 
| + // Test readColorArray | 
| + { | 
| + SkColor data[kArraySize]; | 
| + TestArraySerialization(data, reporter); | 
| + } | 
| - // Make sure this fails when it should | 
| - SkValidatingReadBuffer buffer(dataWritten, bytesWritten); | 
| - SkPoint dataRead[arraySize]; | 
| - bool success = buffer.readPointArray(dataRead, 32); | 
| - // This should have failed, since 256 < sizeInBytes | 
| - REPORTER_ASSERT(reporter, !success); | 
| + // Test readIntArray | 
| + { | 
| + int32_t data[kArraySize]; | 
| + TestArraySerialization(data, reporter); | 
| + } | 
| - // Make sure this succeeds when it should | 
| - SkValidatingReadBuffer buffer2(dataWritten, bytesWritten); | 
| - success = buffer2.readPointArray(dataRead, arraySize); | 
| - // This should have succeeded, since there are enough bytes to read this | 
| - REPORTER_ASSERT(reporter, success); | 
| + // Test readPointArray | 
| + { | 
| + SkPoint data[kArraySize]; | 
| + TestArraySerialization(data, reporter); | 
| } | 
| + // Test readScalarArray | 
| { | 
| - static const uint32_t arraySize = 64; | 
| - SkScalar data[arraySize]; | 
| - SkOrderedWriteBuffer writer(1024); | 
| - writer.setFlags(SkOrderedWriteBuffer::kValidation_Flag); | 
| - writer.writeScalarArray(data, arraySize); | 
| - uint32_t bytesWritten = writer.bytesWritten(); | 
| - // This should write the length (in 4 bytes) and the array | 
| - REPORTER_ASSERT(reporter, (4 + arraySize * sizeof(SkScalar)) == bytesWritten); | 
| - | 
| - unsigned char dataWritten[1024]; | 
| - writer.writeToMemory(dataWritten); | 
| - | 
| - // Make sure this fails when it should | 
| - SkValidatingReadBuffer buffer(dataWritten, bytesWritten); | 
| - SkScalar dataRead[arraySize]; | 
| - bool success = buffer.readScalarArray(dataRead, 32); | 
| - // This should have failed, since 256 < sizeInBytes | 
| - REPORTER_ASSERT(reporter, !success); | 
| - | 
| - // Make sure this succeeds when it should | 
| - SkValidatingReadBuffer buffer2(dataWritten, bytesWritten); | 
| - success = buffer2.readScalarArray(dataRead, arraySize); | 
| - // This should have succeeded, since there are enough bytes to read this | 
| - REPORTER_ASSERT(reporter, success); | 
| + SkScalar data[kArraySize]; | 
| + TestArraySerialization(data, reporter); | 
| } | 
| } |