mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-27 09:01:46 +00:00
417de87cb2
Based on the work for the Android surface callbacks, just finished being made generic since we'll need to reuse it.
105 lines
3.8 KiB
C++
105 lines
3.8 KiB
C++
// Copyright 2021, Collabora, Ltd.
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
/*!
|
|
* @file
|
|
* @brief Generic callback collection tests.
|
|
* @author Ryan Pavlik <ryan.pavlik@collabora.com>
|
|
*/
|
|
|
|
#include "catch/catch.hpp"
|
|
|
|
#include <util/u_generic_callbacks.hpp>
|
|
|
|
using xrt::auxiliary::util::GenericCallbacks;
|
|
|
|
enum class MyEvent
|
|
{
|
|
ACQUIRED,
|
|
LOST,
|
|
};
|
|
|
|
using mask_t = std::underlying_type_t<MyEvent>;
|
|
|
|
static bool
|
|
increment_userdata_int(MyEvent event, void *userdata)
|
|
{
|
|
*static_cast<int *>(userdata) += 1;
|
|
return true;
|
|
}
|
|
|
|
|
|
using callback_t = bool (*)(MyEvent event, void *userdata);
|
|
|
|
TEST_CASE("u_generic_callbacks")
|
|
{
|
|
GenericCallbacks<callback_t, MyEvent> callbacks;
|
|
// Simplest possible invoker.
|
|
auto invoker = [](MyEvent event, callback_t callback, void *userdata) { return callback(event, userdata); };
|
|
|
|
SECTION("call when empty")
|
|
{
|
|
CHECK(0 == callbacks.invokeCallbacks(MyEvent::ACQUIRED, invoker));
|
|
CHECK(0 == callbacks.invokeCallbacks(MyEvent::LOST, invoker));
|
|
CHECK(0 == callbacks.removeCallback(&increment_userdata_int, (mask_t)MyEvent::LOST, nullptr));
|
|
}
|
|
SECTION("same function, different mask and userdata")
|
|
{
|
|
int numAcquired = 0;
|
|
int numLost = 0;
|
|
REQUIRE_NOTHROW(callbacks.addCallback(increment_userdata_int, (mask_t)MyEvent::ACQUIRED, &numAcquired));
|
|
REQUIRE_NOTHROW(callbacks.addCallback(increment_userdata_int, (mask_t)MyEvent::LOST, &numLost));
|
|
SECTION("contains")
|
|
{
|
|
CHECK(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::LOST, &numLost));
|
|
CHECK_FALSE(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::LOST, &numAcquired));
|
|
}
|
|
SECTION("removal matching")
|
|
{
|
|
CHECK(0 ==
|
|
callbacks.removeCallback(increment_userdata_int, (mask_t)MyEvent::LOST, &numAcquired));
|
|
CHECK(0 ==
|
|
callbacks.removeCallback(increment_userdata_int, (mask_t)MyEvent::ACQUIRED, &numLost));
|
|
}
|
|
SECTION("duplicates, contains, and removal")
|
|
{
|
|
REQUIRE(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::ACQUIRED, &numAcquired));
|
|
REQUIRE_NOTHROW(
|
|
callbacks.addCallback(increment_userdata_int, (mask_t)MyEvent::ACQUIRED, &numAcquired));
|
|
CHECK(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::ACQUIRED, &numAcquired));
|
|
// Now we have two ACQUIRED and one LOST callback.
|
|
SECTION("max_remove")
|
|
{
|
|
CHECK(0 == callbacks.removeCallback(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired, 0, 0));
|
|
CHECK(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired));
|
|
|
|
CHECK(1 == callbacks.removeCallback(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired, 0, 1));
|
|
CHECK(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired));
|
|
}
|
|
SECTION("large max_remove")
|
|
{
|
|
CHECK(2 == callbacks.removeCallback(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired, 0, 3));
|
|
CHECK_FALSE(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired));
|
|
}
|
|
SECTION("num_skip")
|
|
{
|
|
CHECK(0 == callbacks.removeCallback(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired, 3));
|
|
CHECK(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired));
|
|
|
|
CHECK(1 == callbacks.removeCallback(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired, 1));
|
|
CHECK(callbacks.contains(increment_userdata_int, (mask_t)MyEvent::ACQUIRED,
|
|
&numAcquired));
|
|
}
|
|
}
|
|
CHECK(1 == callbacks.removeCallback(increment_userdata_int, (mask_t)MyEvent::LOST, &numLost));
|
|
}
|
|
}
|