blob: aacde34a1be8cea4b636a2e213b15124e544ac7d [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
reed@google.com8a85d0c2011-06-24 19:12:12 +000011#include "SkData.h"
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000012#include "SkFlate.h"
13#include "SkStream.h"
tfarina@chromium.org8f6884a2014-01-24 20:56:26 +000014#include "Test.h"
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000015
16// A memory stream that reports zero size with the standard call, like
17// an unseekable file stream would.
vandebo@chromium.org2a22e102011-01-25 21:01:34 +000018class SkZeroSizeMemStream : public SkMemoryStream {
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000019public:
20 virtual size_t read(void* buffer, size_t size) {
21 if (buffer == NULL && size == 0)
22 return 0;
23 if (buffer == NULL && size == kGetSizeKey)
24 size = 0;
25 return SkMemoryStream::read(buffer, size);
26 }
27
28 static const size_t kGetSizeKey = 0xDEADBEEF;
29};
30
31static void TestFlate(skiatest::Reporter* reporter, SkMemoryStream* testStream,
32 size_t dataSize) {
33 if (testStream == NULL)
34 return;
35
36 SkMemoryStream testData(dataSize);
37 uint8_t* data = (uint8_t*)testData.getMemoryBase();
38 srand(0); // Make data deterministic.
39 for (size_t i = 0; i < dataSize; i++)
40 data[i] = rand() & 0xFF;
41
42 testStream->setMemory(testData.getMemoryBase(), dataSize, true);
43 SkDynamicMemoryWStream compressed;
44 bool status = SkFlate::Deflate(testStream, &compressed);
45 REPORTER_ASSERT(reporter, status);
46
47 // Check that the input data wasn't changed.
48 size_t inputSize = testStream->getLength();
49 if (inputSize == 0)
vandebo@chromium.org2a22e102011-01-25 21:01:34 +000050 inputSize = testStream->read(NULL, SkZeroSizeMemStream::kGetSizeKey);
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000051 REPORTER_ASSERT(reporter, testData.getLength() == inputSize);
52 REPORTER_ASSERT(reporter, memcmp(testData.getMemoryBase(),
53 testStream->getMemoryBase(),
54 testData.getLength()) == 0);
55
56 // Assume there are two test sizes, big and small.
57 if (dataSize < 1024)
58 REPORTER_ASSERT(reporter, compressed.getOffset() < 1024);
59 else
60 REPORTER_ASSERT(reporter, compressed.getOffset() > 1024);
61
reed@google.com8a85d0c2011-06-24 19:12:12 +000062 SkAutoDataUnref data1(compressed.copyToData());
63
64 testStream->setData(data1.get())->unref();
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000065 SkDynamicMemoryWStream uncompressed;
66 status = SkFlate::Inflate(testStream, &uncompressed);
67 REPORTER_ASSERT(reporter, status);
68
69 // Check that the input data wasn't changed.
70 inputSize = testStream->getLength();
71 if (inputSize == 0)
vandebo@chromium.org2a22e102011-01-25 21:01:34 +000072 inputSize = testStream->read(NULL, SkZeroSizeMemStream::kGetSizeKey);
robertphillips@google.com59f46b82012-07-10 17:30:58 +000073 REPORTER_ASSERT(reporter, data1->size() == inputSize);
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000074 REPORTER_ASSERT(reporter, memcmp(testStream->getMemoryBase(),
rmistry@google.comd6176b02012-08-23 18:14:13 +000075 data1->data(),
robertphillips@google.com59f46b82012-07-10 17:30:58 +000076 data1->size()) == 0);
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000077
78 // Check that the uncompressed data matches the source data.
reed@google.com8a85d0c2011-06-24 19:12:12 +000079 SkAutoDataUnref data2(uncompressed.copyToData());
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000080 REPORTER_ASSERT(reporter, testData.getLength() == uncompressed.getOffset());
rmistry@google.comd6176b02012-08-23 18:14:13 +000081 REPORTER_ASSERT(reporter, memcmp(testData.getMemoryBase(),
robertphillips@google.com59f46b82012-07-10 17:30:58 +000082 data2->data(),
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000083 testData.getLength()) == 0);
84}
85
tfarina@chromium.orge4fafb12013-12-12 21:11:12 +000086DEF_TEST(Flate, reporter) {
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000087 TestFlate(reporter, NULL, 0);
vandebo@chromium.orgfb0b0ed2011-04-15 20:01:17 +000088#if defined(SK_ZLIB_INCLUDE) && !defined(SK_DEBUG)
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000089 REPORTER_ASSERT(reporter, SkFlate::HaveFlate());
90
91 SkMemoryStream memStream;
92 TestFlate(reporter, &memStream, 512);
93 TestFlate(reporter, &memStream, 10240);
94
vandebo@chromium.org2a22e102011-01-25 21:01:34 +000095 SkZeroSizeMemStream fileStream;
vandebo@chromium.orgee34e352010-12-02 22:55:33 +000096 TestFlate(reporter, &fileStream, 512);
97 TestFlate(reporter, &fileStream, 10240);
98#endif
99}