blob: 8d5f015979ec80319ca0703c566024628c8a3a3d [file] [log] [blame]
vandebo@chromium.orgee34e352010-12-02 22:55:33 +00001/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00002 * Copyright 2011 Google Inc.
vandebo@chromium.orgee34e352010-12-02 22:55:33 +00003 *
epoger@google.comec3ed6a2011-07-28 14:26:00 +00004 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
vandebo@chromium.orgee34e352010-12-02 22:55:33 +00006 */
7
8#include <stdlib.h>
9#include <string.h>
10
11#include "Test.h"
tfarina@chromium.orge4fafb12013-12-12 21:11:12 +000012#include "TestClassDef.h"
reed@google.com8a85d0c2011-06-24 19:12:12 +000013#include "SkData.h"
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000014#include "SkFlate.h"
15#include "SkStream.h"
16
17// A memory stream that reports zero size with the standard call, like
18// an unseekable file stream would.
vandebo@chromium.org2a22e102011-01-25 21:01:34 +000019class SkZeroSizeMemStream : public SkMemoryStream {
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000020public:
21 virtual size_t read(void* buffer, size_t size) {
22 if (buffer == NULL && size == 0)
23 return 0;
24 if (buffer == NULL && size == kGetSizeKey)
25 size = 0;
26 return SkMemoryStream::read(buffer, size);
27 }
28
29 static const size_t kGetSizeKey = 0xDEADBEEF;
30};
31
32static void TestFlate(skiatest::Reporter* reporter, SkMemoryStream* testStream,
33 size_t dataSize) {
34 if (testStream == NULL)
35 return;
36
37 SkMemoryStream testData(dataSize);
38 uint8_t* data = (uint8_t*)testData.getMemoryBase();
39 srand(0); // Make data deterministic.
40 for (size_t i = 0; i < dataSize; i++)
41 data[i] = rand() & 0xFF;
42
43 testStream->setMemory(testData.getMemoryBase(), dataSize, true);
44 SkDynamicMemoryWStream compressed;
45 bool status = SkFlate::Deflate(testStream, &compressed);
46 REPORTER_ASSERT(reporter, status);
47
48 // Check that the input data wasn't changed.
49 size_t inputSize = testStream->getLength();
50 if (inputSize == 0)
vandebo@chromium.org2a22e102011-01-25 21:01:34 +000051 inputSize = testStream->read(NULL, SkZeroSizeMemStream::kGetSizeKey);
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000052 REPORTER_ASSERT(reporter, testData.getLength() == inputSize);
53 REPORTER_ASSERT(reporter, memcmp(testData.getMemoryBase(),
54 testStream->getMemoryBase(),
55 testData.getLength()) == 0);
56
57 // Assume there are two test sizes, big and small.
58 if (dataSize < 1024)
59 REPORTER_ASSERT(reporter, compressed.getOffset() < 1024);
60 else
61 REPORTER_ASSERT(reporter, compressed.getOffset() > 1024);
62
reed@google.com8a85d0c2011-06-24 19:12:12 +000063 SkAutoDataUnref data1(compressed.copyToData());
64
65 testStream->setData(data1.get())->unref();
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000066 SkDynamicMemoryWStream uncompressed;
67 status = SkFlate::Inflate(testStream, &uncompressed);
68 REPORTER_ASSERT(reporter, status);
69
70 // Check that the input data wasn't changed.
71 inputSize = testStream->getLength();
72 if (inputSize == 0)
vandebo@chromium.org2a22e102011-01-25 21:01:34 +000073 inputSize = testStream->read(NULL, SkZeroSizeMemStream::kGetSizeKey);
robertphillips@google.com59f46b82012-07-10 17:30:58 +000074 REPORTER_ASSERT(reporter, data1->size() == inputSize);
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000075 REPORTER_ASSERT(reporter, memcmp(testStream->getMemoryBase(),
rmistry@google.comd6176b02012-08-23 18:14:13 +000076 data1->data(),
robertphillips@google.com59f46b82012-07-10 17:30:58 +000077 data1->size()) == 0);
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000078
79 // Check that the uncompressed data matches the source data.
reed@google.com8a85d0c2011-06-24 19:12:12 +000080 SkAutoDataUnref data2(uncompressed.copyToData());
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000081 REPORTER_ASSERT(reporter, testData.getLength() == uncompressed.getOffset());
rmistry@google.comd6176b02012-08-23 18:14:13 +000082 REPORTER_ASSERT(reporter, memcmp(testData.getMemoryBase(),
robertphillips@google.com59f46b82012-07-10 17:30:58 +000083 data2->data(),
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000084 testData.getLength()) == 0);
85}
86
tfarina@chromium.orge4fafb12013-12-12 21:11:12 +000087DEF_TEST(Flate, reporter) {
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000088 TestFlate(reporter, NULL, 0);
vandebo@chromium.orgfb0b0ed2011-04-15 20:01:17 +000089#if defined(SK_ZLIB_INCLUDE) && !defined(SK_DEBUG)
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000090 REPORTER_ASSERT(reporter, SkFlate::HaveFlate());
91
92 SkMemoryStream memStream;
93 TestFlate(reporter, &memStream, 512);
94 TestFlate(reporter, &memStream, 10240);
95
vandebo@chromium.org2a22e102011-01-25 21:01:34 +000096 SkZeroSizeMemStream fileStream;
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000097 TestFlate(reporter, &fileStream, 512);
98 TestFlate(reporter, &fileStream, 10240);
99#endif
100}