2
0
mirror of https://github.com/boostorg/compute.git synced 2026-01-22 05:02:15 +00:00
Files
compute/test/test_buffer.cpp
2014-07-12 22:54:16 +04:00

138 lines
3.5 KiB
C++

//---------------------------------------------------------------------------//
// Copyright (c) 2013 Kyle Lutz <kyle.r.lutz@gmail.com>
//
// Distributed under the Boost Software License, Version 1.0
// See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt
//
// See http://kylelutz.github.com/compute for more information.
//---------------------------------------------------------------------------//
#define BOOST_TEST_MODULE TestBuffer
#include <boost/test/unit_test.hpp>
#include <boost/compute/buffer.hpp>
#include <boost/compute/system.hpp>
#include "context_setup.hpp"
namespace bc = boost::compute;
BOOST_AUTO_TEST_CASE(size)
{
bc::buffer buffer(context, 100);
BOOST_CHECK_EQUAL(buffer.size(), size_t(100));
BOOST_VERIFY(buffer.max_size() > buffer.size());
}
BOOST_AUTO_TEST_CASE(cl_context)
{
bc::buffer buffer(context, 100);
BOOST_VERIFY(buffer.get_context() == context);
}
BOOST_AUTO_TEST_CASE(equality_operator)
{
bc::buffer a(context, 10);
bc::buffer b(context, 10);
BOOST_VERIFY(a == a);
BOOST_VERIFY(b == b);
BOOST_VERIFY(!(a == b));
BOOST_VERIFY(a != b);
a = b;
BOOST_VERIFY(a == b);
BOOST_VERIFY(!(a != b));
}
BOOST_AUTO_TEST_CASE(construct_from_cl_mem)
{
// create cl_mem
cl_mem mem = clCreateBuffer(context, CL_MEM_READ_WRITE, 16, 0, 0);
BOOST_VERIFY(mem);
// create boost::compute::buffer
boost::compute::buffer buffer(mem);
// check buffer
BOOST_CHECK(buffer.get() == mem);
BOOST_CHECK(buffer.get_context() == context);
BOOST_CHECK_EQUAL(buffer.size(), size_t(16));
// cleanup cl_mem
clReleaseMemObject(mem);
}
BOOST_AUTO_TEST_CASE(reference_count)
{
using boost::compute::uint_;
boost::compute::buffer buf(context, 16);
BOOST_CHECK_GE(buf.reference_count(), uint_(1));
}
BOOST_AUTO_TEST_CASE(get_size)
{
boost::compute::buffer buf(context, 16);
BOOST_CHECK_EQUAL(buf.size(), size_t(16));
BOOST_CHECK_EQUAL(buf.get_info<CL_MEM_SIZE>(), size_t(16));
BOOST_CHECK_EQUAL(buf.get_info<size_t>(CL_MEM_SIZE), size_t(16));
}
#ifndef BOOST_COMPUTE_NO_RVALUE_REFERENCES
BOOST_AUTO_TEST_CASE(move_constructor)
{
boost::compute::buffer buffer1(context, 16);
BOOST_CHECK(buffer1.get() != 0);
BOOST_CHECK_EQUAL(buffer1.size(), size_t(16));
boost::compute::buffer buffer2(std::move(buffer1));
BOOST_CHECK(buffer1.get() == 0);
BOOST_CHECK(buffer2.get() != 0);
BOOST_CHECK_EQUAL(buffer2.size(), size_t(16));
}
#endif // BOOST_COMPUTE_NO_RVALUE_REFERENCES
BOOST_AUTO_TEST_CASE(clone_buffer)
{
boost::compute::buffer buffer1(context, 16);
boost::compute::buffer buffer2 = buffer1.clone(queue);
BOOST_CHECK(buffer1.get() != buffer2.get());
BOOST_CHECK_EQUAL(buffer1.size(), buffer2.size());
}
#ifdef CL_VERSION_1_1
static void BOOST_COMPUTE_CL_CALLBACK
destructor_callback_function(cl_mem memobj, void *user_data)
{
(void) memobj;
bool *flag = static_cast<bool *>(user_data);
*flag = true;
}
BOOST_AUTO_TEST_CASE(destructor_callback)
{
REQUIRES_OPENCL_VERSION(1,2);
bool invoked = false;
{
boost::compute::buffer buf(context, 128);
buf.set_destructor_callback(destructor_callback_function, &invoked);
}
BOOST_CHECK(invoked == true);
}
#endif // CL_VERSION_1_1
BOOST_AUTO_TEST_CASE(create_buffer_doctest)
{
//! [constructor]
boost::compute::buffer buf(context, 32 * sizeof(float));
//! [constructor]
BOOST_CHECK_EQUAL(buf.size(), 32 * sizeof(float));
}
BOOST_AUTO_TEST_SUITE_END()