blob: 8a6ed88f677310c905862768d1d176279208fbb2 [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001/*
2 * Copyright 2011 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
tfarina@chromium.orge4fafb12013-12-12 21:11:12 +00007
reed@android.comed673312009-02-27 16:24:51 +00008#include "Test.h"
tfarina@chromium.orge4fafb12013-12-12 21:11:12 +00009#include "TestClassDef.h"
reed@android.comed673312009-02-27 16:24:51 +000010#include "SkPackBits.h"
11
12static const uint16_t gTest0[] = { 0, 0, 1, 1 };
13static const uint16_t gTest1[] = { 1, 2, 3, 4, 5, 6 };
14static const uint16_t gTest2[] = { 0, 0, 0, 1, 2, 3, 3, 3 };
15static const uint16_t gTest3[] = { 0, 0, 0, 0, 0, 0, 1, 2, 3, 3, 3, 0, 0, 1 };
16
17#include "SkRandom.h"
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +000018static SkRandom gRand;
reed@android.comed673312009-02-27 16:24:51 +000019static void rand_fill(uint16_t buffer[], int count) {
20 for (int i = 0; i < count; i++)
21 buffer[i] = (uint16_t)gRand.nextU();
22}
23
24static void test_pack16(skiatest::Reporter* reporter) {
25 static const struct {
26 const uint16_t* fSrc;
27 int fCount;
28 } gTests[] = {
29 { gTest0, SK_ARRAY_COUNT(gTest0) },
30 { gTest1, SK_ARRAY_COUNT(gTest1) },
31 { gTest2, SK_ARRAY_COUNT(gTest2) },
32 { gTest3, SK_ARRAY_COUNT(gTest3) }
33 };
reed@android.com80e39a72009-04-02 16:59:40 +000034
reed@android.comed673312009-02-27 16:24:51 +000035 for (size_t i = 0; i < SK_ARRAY_COUNT(gTests); i++) {
36 uint8_t dst[100];
37 size_t dstSize = SkPackBits::Pack16(gTests[i].fSrc,
38 gTests[i].fCount, dst);
39 uint16_t src[100];
40 int srcCount = SkPackBits::Unpack16(dst, dstSize, src);
41 bool match = gTests[i].fCount == srcCount && memcmp(gTests[i].fSrc, src,
42 gTests[i].fCount * sizeof(uint16_t)) == 0;
43 REPORTER_ASSERT(reporter, match);
44 }
reed@android.com80e39a72009-04-02 16:59:40 +000045
reed@android.comed673312009-02-27 16:24:51 +000046 for (int n = 1000; n; n--) {
47 size_t size = 50;
48 uint16_t src[100], src2[100];
49 uint8_t dst[200];
50 rand_fill(src, size);
51
52 size_t dstSize = SkPackBits::Pack16(src, size, dst);
53 size_t maxSize = SkPackBits::ComputeMaxSize16(size);
54 REPORTER_ASSERT(reporter, maxSize >= dstSize);
55
reed@android.com04225dc2009-03-20 04:59:37 +000056 size_t srcCount = SkPackBits::Unpack16(dst, dstSize, src2);
reed@android.comed673312009-02-27 16:24:51 +000057 REPORTER_ASSERT(reporter, size == srcCount);
58 bool match = memcmp(src, src2, size * sizeof(uint16_t)) == 0;
59 REPORTER_ASSERT(reporter, match);
60 }
61}
62
63static const uint8_t gTest80[] = { 0, 0, 1, 1 };
64static const uint8_t gTest81[] = { 1, 2, 3, 4, 5, 6 };
65static const uint8_t gTest82[] = { 0, 0, 0, 1, 2, 3, 3, 3 };
66static const uint8_t gTest83[] = { 0, 0, 0, 0, 0, 0, 1, 2, 3, 3, 3, 0, 0, 1 };
67static const uint8_t gTest84[] = { 1, 0, 3, 0, 0, 0, 2, 1, 1, 2 };
68
69static void rand_fill(uint8_t buffer[], int count) {
70 for (int i = 0; i < count; i++)
71 buffer[i] = (uint8_t)((gRand.nextU() >> 8) & 0x3);
72}
73
74static void test_pack8(skiatest::Reporter* reporter) {
75 static const struct {
76 const uint8_t* fSrc;
77 int fCount;
78 } gTests[] = {
79 { gTest80, SK_ARRAY_COUNT(gTest80) },
80 { gTest81, SK_ARRAY_COUNT(gTest81) },
81 { gTest82, SK_ARRAY_COUNT(gTest82) },
82 { gTest83, SK_ARRAY_COUNT(gTest83) },
83 { gTest84, SK_ARRAY_COUNT(gTest84) }
84 };
reed@android.com80e39a72009-04-02 16:59:40 +000085
reed@android.comed673312009-02-27 16:24:51 +000086 for (size_t i = 4; i < SK_ARRAY_COUNT(gTests); i++) {
87 uint8_t dst[100];
88 size_t maxSize = SkPackBits::ComputeMaxSize8(gTests[i].fCount);
89 size_t dstSize = SkPackBits::Pack8(gTests[i].fSrc,
90 gTests[i].fCount, dst);
91 REPORTER_ASSERT(reporter, dstSize <= maxSize);
92 uint8_t src[100];
93 int srcCount = SkPackBits::Unpack8(dst, dstSize, src);
94 bool match = gTests[i].fCount == srcCount &&
95 memcmp(gTests[i].fSrc, src,
96 gTests[i].fCount * sizeof(uint8_t)) == 0;
97 REPORTER_ASSERT(reporter, match);
98 }
99
100 for (size_t size = 1; size <= 512; size += 1) {
reed@android.come72fee52009-11-16 14:52:01 +0000101 for (int n = 100; n; n--) {
reed@android.comed673312009-02-27 16:24:51 +0000102 uint8_t src[600], src2[600];
103 uint8_t dst[600];
104 rand_fill(src, size);
105
106 size_t dstSize = SkPackBits::Pack8(src, size, dst);
107 size_t maxSize = SkPackBits::ComputeMaxSize8(size);
108 REPORTER_ASSERT(reporter, maxSize >= dstSize);
109
reed@android.com04225dc2009-03-20 04:59:37 +0000110 size_t srcCount = SkPackBits::Unpack8(dst, dstSize, src2);
reed@android.comed673312009-02-27 16:24:51 +0000111 REPORTER_ASSERT(reporter, size == srcCount);
112 bool match = memcmp(src, src2, size * sizeof(uint8_t)) == 0;
113 REPORTER_ASSERT(reporter, match);
reed@android.com80e39a72009-04-02 16:59:40 +0000114
reed@android.come72fee52009-11-16 14:52:01 +0000115 for (int j = 0; j < 100; j++) {
reed@android.comed673312009-02-27 16:24:51 +0000116 size_t skip = gRand.nextU() % size;
117 size_t write = gRand.nextU() % size;
118 if (skip + write > size) {
119 write = size - skip;
120 }
121 SkPackBits::Unpack8(src, skip, write, dst);
122 bool match = memcmp(src, src2 + skip, write) == 0;
123 REPORTER_ASSERT(reporter, match);
124 }
125 }
126 }
127}
128
tfarina@chromium.orge4fafb12013-12-12 21:11:12 +0000129DEF_TEST(PackBits, reporter) {
reed@android.comd8730ea2009-02-27 22:06:06 +0000130 test_pack8(reporter);
131 test_pack16(reporter);
reed@android.comed673312009-02-27 16:24:51 +0000132}