blob: 3bcd9353fc3d3af0821adc87ede7b08a693ccced [file] [log] [blame]
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -07001/*
2 * Copyright 2018 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#define LOG_TAG "BufferHubBufferTest"
18
Tianyu Jiangce232742019-01-29 10:17:31 -080019#include <errno.h>
Fan Xu5cf47bc2019-01-15 15:02:15 -080020#include <sys/epoll.h>
21
Fan Xu93c94902018-11-01 12:22:05 -070022#include <android/hardware_buffer.h>
Fan Xu467e08f2018-11-09 15:58:51 -080023#include <cutils/native_handle.h>
Fan Xu021776e2018-12-05 13:34:48 -080024#include <gmock/gmock.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070025#include <gtest/gtest.h>
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070026#include <hidl/ServiceManagement.h>
27#include <hwbinder/IPCThreadState.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070028#include <ui/BufferHubBuffer.h>
Fan Xu5cf47bc2019-01-15 15:02:15 -080029#include <ui/BufferHubEventFd.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070030
31namespace android {
32
33namespace {
34
Fan Xu021776e2018-12-05 13:34:48 -080035using ::android::BufferHubDefs::AnyClientAcquired;
36using ::android::BufferHubDefs::AnyClientGained;
37using ::android::BufferHubDefs::AnyClientPosted;
Fan Xu021776e2018-12-05 13:34:48 -080038using ::android::BufferHubDefs::IsClientAcquired;
39using ::android::BufferHubDefs::IsClientGained;
40using ::android::BufferHubDefs::IsClientPosted;
41using ::android::BufferHubDefs::IsClientReleased;
42using ::android::BufferHubDefs::kMetadataHeaderSize;
43using ::testing::IsNull;
44using ::testing::NotNull;
45
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070046const int kWidth = 640;
47const int kHeight = 480;
48const int kLayerCount = 1;
49const int kFormat = HAL_PIXEL_FORMAT_RGBA_8888;
50const int kUsage = 0;
Fan Xu021776e2018-12-05 13:34:48 -080051const AHardwareBuffer_Desc kDesc = {kWidth, kHeight, kLayerCount, kFormat,
52 kUsage, /*stride=*/0UL, /*rfu0=*/0UL, /*rfu1=*/0ULL};
53const size_t kUserMetadataSize = 1;
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070054
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070055class BufferHubBufferTest : public ::testing::Test {
Tianyu Jiangb08b7222018-11-16 17:55:26 -080056protected:
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070057 void SetUp() override { android::hardware::ProcessState::self()->startThreadPool(); }
58};
59
Fan Xu021776e2018-12-05 13:34:48 -080060bool cmpAHardwareBufferDesc(const AHardwareBuffer_Desc& desc, const AHardwareBuffer_Desc& other) {
61 // Not comparing stride because it's unknown before allocation
62 return desc.format == other.format && desc.height == other.height &&
63 desc.layers == other.layers && desc.usage == other.usage && desc.width == other.width;
64}
65
Tianyu Jiangb08b7222018-11-16 17:55:26 -080066class BufferHubBufferStateTransitionTest : public BufferHubBufferTest {
67protected:
68 void SetUp() override {
69 BufferHubBufferTest::SetUp();
70 CreateTwoClientsOfABuffer();
71 }
72
73 std::unique_ptr<BufferHubBuffer> b1;
Tianyu Jiangec97b762019-01-07 17:14:02 -080074 uint32_t b1ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080075 std::unique_ptr<BufferHubBuffer> b2;
Tianyu Jiangec97b762019-01-07 17:14:02 -080076 uint32_t b2ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080077
78private:
79 // Creates b1 and b2 as the clients of the same buffer for testing.
80 void CreateTwoClientsOfABuffer();
81};
82
83void BufferHubBufferStateTransitionTest::CreateTwoClientsOfABuffer() {
84 b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage, kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -080085 ASSERT_THAT(b1, NotNull());
Tianyu Jiangb08b7222018-11-16 17:55:26 -080086 b1ClientMask = b1->client_state_mask();
Tianyu Jianga99f9112018-12-13 18:23:07 -080087 ASSERT_NE(b1ClientMask, 0U);
Fan Xu021776e2018-12-05 13:34:48 -080088
89 native_handle_t* token = b1->Duplicate();
90 ASSERT_THAT(token, NotNull());
91
92 // TODO(b/122543147): use a movalbe wrapper for token
93 b2 = BufferHubBuffer::Import(token);
94 native_handle_close(token);
95 native_handle_delete(token);
96 ASSERT_THAT(b2, NotNull());
97
Tianyu Jiangb08b7222018-11-16 17:55:26 -080098 b2ClientMask = b2->client_state_mask();
Tianyu Jianga99f9112018-12-13 18:23:07 -080099 ASSERT_NE(b2ClientMask, 0U);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800100 ASSERT_NE(b2ClientMask, b1ClientMask);
101}
102
Fan Xu021776e2018-12-05 13:34:48 -0800103TEST_F(BufferHubBufferTest, CreateBufferFails) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700104 // Buffer Creation will fail: BLOB format requires height to be 1.
105 auto b1 = BufferHubBuffer::Create(kWidth, /*height=*/2, kLayerCount,
106 /*format=*/HAL_PIXEL_FORMAT_BLOB, kUsage, kUserMetadataSize);
107
Fan Xu021776e2018-12-05 13:34:48 -0800108 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700109
110 // Buffer Creation will fail: user metadata size too large.
111 auto b2 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
112 /*userMetadataSize=*/std::numeric_limits<size_t>::max());
113
Fan Xu021776e2018-12-05 13:34:48 -0800114 EXPECT_THAT(b2, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700115
116 // Buffer Creation will fail: user metadata size too large.
117 const size_t userMetadataSize = std::numeric_limits<size_t>::max() - kMetadataHeaderSize;
118 auto b3 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
119 userMetadataSize);
120
Fan Xu021776e2018-12-05 13:34:48 -0800121 EXPECT_THAT(b3, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700122}
123
Fan Xu021776e2018-12-05 13:34:48 -0800124TEST_F(BufferHubBufferTest, CreateBuffer) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700125 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
126 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800127 ASSERT_THAT(b1, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700128 EXPECT_TRUE(b1->IsConnected());
129 EXPECT_TRUE(b1->IsValid());
Fan Xu021776e2018-12-05 13:34:48 -0800130 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), kDesc));
131 EXPECT_EQ(b1->user_metadata_size(), kUserMetadataSize);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700132}
133
Fan Xu021776e2018-12-05 13:34:48 -0800134TEST_F(BufferHubBufferTest, DuplicateAndImportBuffer) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700135 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
136 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800137 ASSERT_THAT(b1, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700138 EXPECT_TRUE(b1->IsValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700139
Fan Xu021776e2018-12-05 13:34:48 -0800140 native_handle_t* token = b1->Duplicate();
141 EXPECT_TRUE(token);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700142
143 // The detached buffer should still be valid.
144 EXPECT_TRUE(b1->IsConnected());
145 EXPECT_TRUE(b1->IsValid());
146
Fan Xu021776e2018-12-05 13:34:48 -0800147 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
148 native_handle_close(token);
149 native_handle_delete(token);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700150
Fan Xu021776e2018-12-05 13:34:48 -0800151 ASSERT_THAT(b2, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700152 EXPECT_TRUE(b2->IsValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700153
Fan Xu021776e2018-12-05 13:34:48 -0800154 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), b2->desc()));
155 EXPECT_EQ(b1->user_metadata_size(), b2->user_metadata_size());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700156
157 // These two buffer instances are based on the same physical buffer under the
158 // hood, so they should share the same id.
Fan Xu021776e2018-12-05 13:34:48 -0800159 EXPECT_EQ(b1->id(), b2->id());
Tianyu Jiang7e204b72018-10-26 15:39:18 -0700160 // We use client_state_mask() to tell those two instances apart.
Fan Xu021776e2018-12-05 13:34:48 -0800161 EXPECT_NE(b1->client_state_mask(), b2->client_state_mask());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700162
Tianyuf669f6a2018-10-10 15:34:32 -0700163 // Both buffer instances should be in released state currently.
Tianyu Jianga8df5f32019-01-14 18:42:12 -0800164 EXPECT_TRUE(b1->IsReleased());
165 EXPECT_TRUE(b2->IsReleased());
Fan Xu5cf47bc2019-01-15 15:02:15 -0800166
167 // The event fd should behave like duped event fds.
168 const BufferHubEventFd& eventFd1 = b1->eventFd();
Tianyu Jiangce232742019-01-29 10:17:31 -0800169 ASSERT_GE(eventFd1.get(), 0);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800170 const BufferHubEventFd& eventFd2 = b2->eventFd();
Tianyu Jiangce232742019-01-29 10:17:31 -0800171 ASSERT_GE(eventFd2.get(), 0);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800172
173 base::unique_fd epollFd(epoll_create(64));
174 ASSERT_GE(epollFd.get(), 0);
175
176 // Add eventFd1 to epoll set, and signal eventFd2.
177 epoll_event e = {.events = EPOLLIN | EPOLLET, .data = {.u32 = 0}};
Tianyu Jiangce232742019-01-29 10:17:31 -0800178 ASSERT_EQ(epoll_ctl(epollFd.get(), EPOLL_CTL_ADD, eventFd1.get(), &e), 0) << strerror(errno);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800179
180 std::array<epoll_event, 1> events;
181 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
182
183 eventFd2.signal();
184 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 1);
185
186 // The epoll fd is edge triggered, so it only responds to the eventFd once.
187 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
188
189 eventFd2.signal();
190 eventFd2.clear();
191 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
Fan Xu021776e2018-12-05 13:34:48 -0800192}
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700193
Fan Xu021776e2018-12-05 13:34:48 -0800194TEST_F(BufferHubBufferTest, ImportFreedBuffer) {
195 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
196 kUserMetadataSize);
197 ASSERT_THAT(b1, NotNull());
198 EXPECT_TRUE(b1->IsValid());
199
200 native_handle_t* token = b1->Duplicate();
201 EXPECT_TRUE(token);
202
203 // Explicitly destroy b1. Backend buffer should be freed and token becomes invalid
204 b1.reset();
205
206 // TODO(b/122543147): use a movalbe wrapper for token
207 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
208 native_handle_close(token);
209 native_handle_delete(token);
210
211 // Import should fail with INVALID_TOKEN
212 EXPECT_THAT(b2, IsNull());
213}
214
215// nullptr must not crash the service
216TEST_F(BufferHubBufferTest, ImportNullToken) {
217 auto b1 = BufferHubBuffer::Import(nullptr);
218 EXPECT_THAT(b1, IsNull());
219}
220
Fan Xu021776e2018-12-05 13:34:48 -0800221TEST_F(BufferHubBufferTest, ImportInvalidToken) {
222 native_handle_t* token = native_handle_create(/*numFds=*/0, /*numInts=*/1);
223 token->data[0] = 0;
224
225 auto b1 = BufferHubBuffer::Import(token);
226 native_handle_delete(token);
227
228 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700229}
230
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800231TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromReleasedState) {
Tianyu Jianga8df5f32019-01-14 18:42:12 -0800232 ASSERT_TRUE(b1->IsReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800233
234 // Successful gaining the buffer should change the buffer state bit of b1 to
235 // gained state, other client state bits to released state.
236 EXPECT_EQ(b1->Gain(), 0);
237 EXPECT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
238}
239
240TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromGainedState) {
241 ASSERT_EQ(b1->Gain(), 0);
242 auto current_buffer_state = b1->buffer_state();
243 ASSERT_TRUE(IsClientGained(current_buffer_state, b1ClientMask));
244
245 // Gaining from gained state by the same client should not return error.
246 EXPECT_EQ(b1->Gain(), 0);
247
248 // Gaining from gained state by another client should return error.
249 EXPECT_EQ(b2->Gain(), -EBUSY);
250}
251
252TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromAcquiredState) {
253 ASSERT_EQ(b1->Gain(), 0);
254 ASSERT_EQ(b1->Post(), 0);
255 ASSERT_EQ(b2->Acquire(), 0);
256 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
257
258 // Gaining from acquired state should fail.
259 EXPECT_EQ(b1->Gain(), -EBUSY);
260 EXPECT_EQ(b2->Gain(), -EBUSY);
261}
262
263TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromOtherClientInPostedState) {
264 ASSERT_EQ(b1->Gain(), 0);
265 ASSERT_EQ(b1->Post(), 0);
266 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
267
268 // Gaining a buffer who has other posted client should succeed.
269 EXPECT_EQ(b1->Gain(), 0);
270}
271
272TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromSelfInPostedState) {
273 ASSERT_EQ(b1->Gain(), 0);
274 ASSERT_EQ(b1->Post(), 0);
275 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
276
277 // A posted client should be able to gain the buffer when there is no other clients in
278 // acquired state.
279 EXPECT_EQ(b2->Gain(), 0);
280}
281
282TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromOtherInGainedState) {
283 ASSERT_EQ(b1->Gain(), 0);
284 ASSERT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
285
286 EXPECT_EQ(b2->Post(), -EBUSY);
287}
288
289TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromSelfInGainedState) {
290 ASSERT_EQ(b1->Gain(), 0);
291 ASSERT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
292
293 EXPECT_EQ(b1->Post(), 0);
294 auto current_buffer_state = b1->buffer_state();
295 EXPECT_TRUE(IsClientReleased(current_buffer_state, b1ClientMask));
296 EXPECT_TRUE(IsClientPosted(current_buffer_state, b2ClientMask));
297}
298
299TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromPostedState) {
300 ASSERT_EQ(b1->Gain(), 0);
301 ASSERT_EQ(b1->Post(), 0);
302 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
303
304 // Post from posted state should fail.
305 EXPECT_EQ(b1->Post(), -EBUSY);
306 EXPECT_EQ(b2->Post(), -EBUSY);
307}
308
309TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromAcquiredState) {
310 ASSERT_EQ(b1->Gain(), 0);
311 ASSERT_EQ(b1->Post(), 0);
312 ASSERT_EQ(b2->Acquire(), 0);
313 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
314
315 // Posting from acquired state should fail.
316 EXPECT_EQ(b1->Post(), -EBUSY);
317 EXPECT_EQ(b2->Post(), -EBUSY);
318}
319
320TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromReleasedState) {
Tianyu Jianga8df5f32019-01-14 18:42:12 -0800321 ASSERT_TRUE(b1->IsReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800322
323 // Posting from released state should fail.
324 EXPECT_EQ(b1->Post(), -EBUSY);
325 EXPECT_EQ(b2->Post(), -EBUSY);
326}
327
328TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInPostedState) {
329 ASSERT_EQ(b1->Gain(), 0);
330 ASSERT_EQ(b1->Post(), 0);
331 ASSERT_TRUE(IsClientPosted(b1->buffer_state(), b2ClientMask));
332
333 // Acquire from posted state should pass.
334 EXPECT_EQ(b2->Acquire(), 0);
335}
336
337TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromOtherInPostedState) {
338 ASSERT_EQ(b1->Gain(), 0);
339 ASSERT_EQ(b1->Post(), 0);
340 ASSERT_TRUE(IsClientPosted(b1->buffer_state(), b2ClientMask));
341
342 // Acquire from released state should fail, although there are other clients
343 // in posted state.
344 EXPECT_EQ(b1->Acquire(), -EBUSY);
345}
346
347TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInAcquiredState) {
348 ASSERT_EQ(b1->Gain(), 0);
349 ASSERT_EQ(b1->Post(), 0);
350 ASSERT_EQ(b2->Acquire(), 0);
351 auto current_buffer_state = b1->buffer_state();
352 ASSERT_TRUE(IsClientAcquired(current_buffer_state, b2ClientMask));
353
354 // Acquiring from acquired state by the same client should not error out.
355 EXPECT_EQ(b2->Acquire(), 0);
356}
357
358TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromReleasedState) {
Tianyu Jianga8df5f32019-01-14 18:42:12 -0800359 ASSERT_TRUE(b1->IsReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800360
361 // Acquiring form released state should fail.
362 EXPECT_EQ(b1->Acquire(), -EBUSY);
363 EXPECT_EQ(b2->Acquire(), -EBUSY);
364}
365
366TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromGainedState) {
367 ASSERT_EQ(b1->Gain(), 0);
368 ASSERT_TRUE(AnyClientGained(b1->buffer_state()));
369
370 // Acquiring from gained state should fail.
371 EXPECT_EQ(b1->Acquire(), -EBUSY);
372 EXPECT_EQ(b2->Acquire(), -EBUSY);
373}
374
375TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInReleasedState) {
Tianyu Jianga8df5f32019-01-14 18:42:12 -0800376 ASSERT_TRUE(b1->IsReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800377
378 EXPECT_EQ(b1->Release(), 0);
379}
380
381TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInGainedState) {
Tianyu Jianga8df5f32019-01-14 18:42:12 -0800382 ASSERT_TRUE(b1->IsReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800383 ASSERT_EQ(b1->Gain(), 0);
384 ASSERT_TRUE(AnyClientGained(b1->buffer_state()));
385
386 EXPECT_EQ(b1->Release(), 0);
387}
388
389TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInPostedState) {
390 ASSERT_EQ(b1->Gain(), 0);
391 ASSERT_EQ(b1->Post(), 0);
392 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
393
394 EXPECT_EQ(b2->Release(), 0);
395}
396
397TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInAcquiredState) {
398 ASSERT_EQ(b1->Gain(), 0);
399 ASSERT_EQ(b1->Post(), 0);
400 ASSERT_EQ(b2->Acquire(), 0);
401 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
402
403 EXPECT_EQ(b2->Release(), 0);
404}
405
Tianyu Jiangec97b762019-01-07 17:14:02 -0800406TEST_F(BufferHubBufferStateTransitionTest, BasicUsage) {
407 // 1 producer buffer and 1 consumer buffer initialised in testcase setup.
408 // Test if this set of basic operation succeed:
409 // Producer post three times to the consumer, and released by consumer.
410 for (int i = 0; i < 3; ++i) {
411 ASSERT_EQ(b1->Gain(), 0);
412 ASSERT_EQ(b1->Post(), 0);
413 ASSERT_EQ(b2->Acquire(), 0);
414 ASSERT_EQ(b2->Release(), 0);
415 }
416}
417
418TEST_F(BufferHubBufferTest, createNewConsumerAfterGain) {
419 // Create a poducer buffer and gain.
420 std::unique_ptr<BufferHubBuffer> b1 =
421 BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
422 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800423 ASSERT_THAT(b1, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800424 ASSERT_EQ(b1->Gain(), 0);
425
426 // Create a consumer of the buffer and test if the consumer can acquire the
427 // buffer if producer posts.
Fan Xu021776e2018-12-05 13:34:48 -0800428 // TODO(b/122543147): use a movalbe wrapper for token
429 native_handle_t* token = b1->Duplicate();
430 ASSERT_TRUE(token);
431
432 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
433 native_handle_close(token);
434 native_handle_delete(token);
435
436 ASSERT_THAT(b2, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800437 ASSERT_NE(b1->client_state_mask(), b2->client_state_mask());
438
439 ASSERT_EQ(b1->Post(), 0);
440 EXPECT_EQ(b2->Acquire(), 0);
441}
442
443TEST_F(BufferHubBufferTest, createNewConsumerAfterPost) {
444 // Create a poducer buffer and post.
445 std::unique_ptr<BufferHubBuffer> b1 =
446 BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
447 kUserMetadataSize);
448 ASSERT_EQ(b1->Gain(), 0);
449 ASSERT_EQ(b1->Post(), 0);
450
451 // Create a consumer of the buffer and test if the consumer can acquire the
452 // buffer if producer posts.
Fan Xu021776e2018-12-05 13:34:48 -0800453 // TODO(b/122543147): use a movalbe wrapper for token
454 native_handle_t* token = b1->Duplicate();
455 ASSERT_TRUE(token);
456
457 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
458 native_handle_close(token);
459 native_handle_delete(token);
460
461 ASSERT_THAT(b2, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800462 ASSERT_NE(b1->client_state_mask(), b2->client_state_mask());
463
464 EXPECT_EQ(b2->Acquire(), 0);
465}
466
Fan Xuca70b7b2018-10-31 13:20:12 -0700467} // namespace
Fan Xu021776e2018-12-05 13:34:48 -0800468
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700469} // namespace android