81 lines
2.3 KiB
C++
81 lines
2.3 KiB
C++
/*
|
|
* Copyright (C) 2017-2018 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#include "cl_api_tests.h"
|
|
#include "runtime/context/context.h"
|
|
#include "unit_tests/fixtures/device_host_queue_fixture.h"
|
|
#include "unit_tests/mocks/mock_kernel.h"
|
|
|
|
using namespace OCLRT;
|
|
namespace DeviceHostQueue {
|
|
typedef ::testing::Types<CommandQueue, DeviceQueue> QueueTypes;
|
|
|
|
template <typename T>
|
|
class clReleaseCommandQueueTypeTests : public DeviceHostQueueFixture<T> {};
|
|
|
|
TYPED_TEST_CASE(clReleaseCommandQueueTypeTests, QueueTypes);
|
|
|
|
TYPED_TEST(clReleaseCommandQueueTypeTests, returnsSucess) {
|
|
using BaseType = typename TypeParam::BaseType;
|
|
|
|
auto queue = this->createClQueue();
|
|
ASSERT_EQ(CL_SUCCESS, this->retVal);
|
|
auto qObject = castToObject<TypeParam>(static_cast<BaseType *>(queue));
|
|
ASSERT_NE(qObject, nullptr);
|
|
|
|
this->retVal = clReleaseCommandQueue(queue);
|
|
EXPECT_EQ(CL_SUCCESS, this->retVal);
|
|
}
|
|
|
|
TEST(clReleaseCommandQueueTypeTests, nullCommandQueueReturnsError) {
|
|
auto retVal = clReleaseCommandQueue(nullptr);
|
|
EXPECT_EQ(CL_INVALID_COMMAND_QUEUE, retVal);
|
|
}
|
|
} // namespace DeviceHostQueue
|
|
|
|
namespace ULT {
|
|
|
|
typedef api_tests clReleaseCommandQueueTests;
|
|
|
|
TEST_F(clReleaseCommandQueueTests, givenBlockedEnqueueWithOutputEventStoredAsVirtualEventWhenReleaseCommandQueueIsCalledThenInternalRefCountIsDecrementedAndQueueDeleted) {
|
|
cl_command_queue cmdQ = nullptr;
|
|
cl_queue_properties properties = 0;
|
|
Device *device = (Device *)devices[0];
|
|
MockKernelWithInternals kernelInternals(*device, pContext);
|
|
Kernel *kernel = kernelInternals.mockKernel;
|
|
|
|
cmdQ = clCreateCommandQueue(pContext, devices[0], properties, &retVal);
|
|
|
|
ASSERT_NE(nullptr, cmdQ);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
|
|
size_t offset[] = {0, 0, 0};
|
|
size_t gws[] = {1, 1, 1};
|
|
|
|
cl_int retVal = CL_SUCCESS;
|
|
cl_int success = CL_SUCCESS;
|
|
cl_event event = clCreateUserEvent(pContext, &retVal);
|
|
|
|
cl_event eventOut = nullptr;
|
|
|
|
EXPECT_EQ(success, retVal);
|
|
|
|
retVal = clEnqueueNDRangeKernel(cmdQ, kernel, 1, offset, gws, nullptr, 1, &event, &eventOut);
|
|
|
|
EXPECT_EQ(success, retVal);
|
|
EXPECT_NE(nullptr, eventOut);
|
|
|
|
clSetUserEventStatus(event, CL_COMPLETE);
|
|
|
|
clReleaseEvent(event);
|
|
clReleaseEvent(eventOut);
|
|
|
|
retVal = clReleaseCommandQueue(cmdQ);
|
|
EXPECT_EQ(success, retVal);
|
|
}
|
|
} // namespace ULT
|