blob: b89d1215792d4782e2e6130d9741c70ae0ff9e94 [file] [log] [blame]
halcanary@google.com1bed6872014-01-02 17:29:28 +00001/*
2 * Copyright 2013 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 */
7
Hal Canary95e3c052017-01-11 12:44:43 -05008#include "SkAutoMalloc.h"
halcanary@google.com1bed6872014-01-02 17:29:28 +00009#include "SkData.h"
10#include "SkMallocPixelRef.h"
11#include "Test.h"
halcanary@google.com1bed6872014-01-02 17:29:28 +000012
13static void delete_uint8_proc(void* ptr, void*) {
14 delete[] static_cast<uint8_t*>(ptr);
15}
16
17static void set_to_one_proc(void*, void* context) {
18 *(static_cast<int*>(context)) = 1;
19}
20
21/**
22 * This test contains basic sanity checks concerning SkMallocPixelRef.
23 */
24DEF_TEST(MallocPixelRef, reporter) {
25 REPORTER_ASSERT(reporter, true);
commit-bot@chromium.org32678d92014-01-15 02:38:22 +000026 SkImageInfo info = SkImageInfo::MakeN32Premul(10, 13);
halcanary@google.com1bed6872014-01-02 17:29:28 +000027 {
Hal Canary342b7ac2016-11-04 11:49:42 -040028 sk_sp<SkMallocPixelRef> pr(
halcanary96fcdcc2015-08-27 07:41:13 -070029 SkMallocPixelRef::NewAllocate(info, info.minRowBytes() - 1, nullptr));
halcanary@google.com1bed6872014-01-02 17:29:28 +000030 // rowbytes too small.
halcanary96fcdcc2015-08-27 07:41:13 -070031 REPORTER_ASSERT(reporter, nullptr == pr.get());
halcanary@google.com1bed6872014-01-02 17:29:28 +000032 }
33 {
34 size_t rowBytes = info.minRowBytes() - 1;
35 size_t size = info.getSafeSize(rowBytes);
bungeman38d909e2016-08-02 14:40:46 -070036 sk_sp<SkData> data(SkData::MakeUninitialized(size));
Hal Canary342b7ac2016-11-04 11:49:42 -040037 sk_sp<SkMallocPixelRef> pr(
bungeman38d909e2016-08-02 14:40:46 -070038 SkMallocPixelRef::NewWithData(info, rowBytes, nullptr, data.get()));
halcanary@google.com1bed6872014-01-02 17:29:28 +000039 // rowbytes too small.
halcanary96fcdcc2015-08-27 07:41:13 -070040 REPORTER_ASSERT(reporter, nullptr == pr.get());
halcanary@google.com1bed6872014-01-02 17:29:28 +000041 }
42 {
43 size_t rowBytes = info.minRowBytes() + 2;
44 size_t size = info.getSafeSize(rowBytes) - 1;
bungeman38d909e2016-08-02 14:40:46 -070045 sk_sp<SkData> data(SkData::MakeUninitialized(size));
Hal Canary342b7ac2016-11-04 11:49:42 -040046 sk_sp<SkMallocPixelRef> pr(
bungeman38d909e2016-08-02 14:40:46 -070047 SkMallocPixelRef::NewWithData(info, rowBytes, nullptr, data.get()));
halcanary@google.com1bed6872014-01-02 17:29:28 +000048 // data too small.
halcanary96fcdcc2015-08-27 07:41:13 -070049 REPORTER_ASSERT(reporter, nullptr == pr.get());
halcanary@google.com1bed6872014-01-02 17:29:28 +000050 }
51 size_t rowBytes = info.minRowBytes() + 7;
52 size_t size = info.getSafeSize(rowBytes) + 9;
53 {
54 SkAutoMalloc memory(size);
Hal Canary342b7ac2016-11-04 11:49:42 -040055 sk_sp<SkMallocPixelRef> pr(
halcanary96fcdcc2015-08-27 07:41:13 -070056 SkMallocPixelRef::NewDirect(info, memory.get(), rowBytes, nullptr));
57 REPORTER_ASSERT(reporter, pr.get() != nullptr);
halcanary@google.com1bed6872014-01-02 17:29:28 +000058 REPORTER_ASSERT(reporter, memory.get() == pr->pixels());
59 }
60 {
Hal Canary342b7ac2016-11-04 11:49:42 -040061 sk_sp<SkMallocPixelRef> pr(
halcanary96fcdcc2015-08-27 07:41:13 -070062 SkMallocPixelRef::NewAllocate(info, rowBytes, nullptr));
63 REPORTER_ASSERT(reporter, pr.get() != nullptr);
bsalomon49f085d2014-09-05 13:34:00 -070064 REPORTER_ASSERT(reporter, pr->pixels());
halcanary@google.com1bed6872014-01-02 17:29:28 +000065 }
66 {
67 void* addr = static_cast<void*>(new uint8_t[size]);
Hal Canary342b7ac2016-11-04 11:49:42 -040068 sk_sp<SkMallocPixelRef> pr(
halcanary96fcdcc2015-08-27 07:41:13 -070069 SkMallocPixelRef::NewWithProc(info, rowBytes, nullptr, addr,
70 delete_uint8_proc, nullptr));
71 REPORTER_ASSERT(reporter, pr.get() != nullptr);
halcanary@google.com1bed6872014-01-02 17:29:28 +000072 REPORTER_ASSERT(reporter, addr == pr->pixels());
73 }
74 {
75 int x = 0;
76 SkAutoMalloc memory(size);
Hal Canary342b7ac2016-11-04 11:49:42 -040077 sk_sp<SkMallocPixelRef> pr(
halcanary96fcdcc2015-08-27 07:41:13 -070078 SkMallocPixelRef::NewWithProc(info, rowBytes, nullptr,
halcanary@google.com1bed6872014-01-02 17:29:28 +000079 memory.get(), set_to_one_proc,
80 static_cast<void*>(&x)));
halcanary96fcdcc2015-08-27 07:41:13 -070081 REPORTER_ASSERT(reporter, pr.get() != nullptr);
halcanary@google.com1bed6872014-01-02 17:29:28 +000082 REPORTER_ASSERT(reporter, memory.get() == pr->pixels());
83 REPORTER_ASSERT(reporter, 0 == x);
halcanary96fcdcc2015-08-27 07:41:13 -070084 pr.reset(nullptr);
halcanary@google.com1bed6872014-01-02 17:29:28 +000085 // make sure that set_to_one_proc was called.
86 REPORTER_ASSERT(reporter, 1 == x);
87 }
88 {
Ben Wagner373b5382017-03-02 17:33:21 -050089 int x = 0;
90 SkAutoMalloc memory(size);
91 sk_sp<SkMallocPixelRef> pr(
92 SkMallocPixelRef::NewWithProc(SkImageInfo::MakeN32Premul(-1, -1), rowBytes, nullptr,
93 memory.get(), set_to_one_proc,
94 static_cast<void*>(&x)));
95 REPORTER_ASSERT(reporter, pr.get() == nullptr);
96 // make sure that set_to_one_proc was called.
97 REPORTER_ASSERT(reporter, 1 == x);
98 }
99 {
halcanary@google.com1bed6872014-01-02 17:29:28 +0000100 void* addr = static_cast<void*>(new uint8_t[size]);
halcanary96fcdcc2015-08-27 07:41:13 -0700101 REPORTER_ASSERT(reporter, addr != nullptr);
Hal Canary342b7ac2016-11-04 11:49:42 -0400102 sk_sp<SkMallocPixelRef> pr(
halcanary96fcdcc2015-08-27 07:41:13 -0700103 SkMallocPixelRef::NewWithProc(info, rowBytes, nullptr, addr,
104 delete_uint8_proc, nullptr));
halcanary@google.com1bed6872014-01-02 17:29:28 +0000105 REPORTER_ASSERT(reporter, addr == pr->pixels());
106 }
107 {
bungeman38d909e2016-08-02 14:40:46 -0700108 sk_sp<SkData> data(SkData::MakeUninitialized(size));
halcanary@google.com1bed6872014-01-02 17:29:28 +0000109 SkData* dataPtr = data.get();
110 REPORTER_ASSERT(reporter, dataPtr->unique());
Hal Canary342b7ac2016-11-04 11:49:42 -0400111 sk_sp<SkMallocPixelRef> pr(
halcanary96fcdcc2015-08-27 07:41:13 -0700112 SkMallocPixelRef::NewWithData(info, rowBytes, nullptr, data.get()));
halcanary@google.com1bed6872014-01-02 17:29:28 +0000113 REPORTER_ASSERT(reporter, !(dataPtr->unique()));
halcanary96fcdcc2015-08-27 07:41:13 -0700114 data.reset(nullptr);
halcanary@google.com1bed6872014-01-02 17:29:28 +0000115 REPORTER_ASSERT(reporter, dataPtr->unique());
commit-bot@chromium.org2c4e75c2014-04-21 21:08:14 +0000116 REPORTER_ASSERT(reporter, dataPtr->data() == pr->pixels());
halcanary@google.com1bed6872014-01-02 17:29:28 +0000117 }
118}