Procházet zdrojové kódy

test: use shared listener type, drop local definitions

Michele Caini před 2 roky
rodič
revize
72f718458b

+ 3 - 2
test/lib/dispatcher/plugin/main.cpp

@@ -2,6 +2,7 @@
 
 
 #include <gtest/gtest.h>
 #include <gtest/gtest.h>
 #include <common/boxed_type.h>
 #include <common/boxed_type.h>
+#include <common/listener.h>
 #include <cr.h>
 #include <cr.h>
 #include <entt/signal/dispatcher.hpp>
 #include <entt/signal/dispatcher.hpp>
 
 
@@ -15,11 +16,11 @@ struct listener {
 
 
 TEST(Lib, Dispatcher) {
 TEST(Lib, Dispatcher) {
     entt::dispatcher dispatcher;
     entt::dispatcher dispatcher;
-    listener listener;
+    test::listener<test::boxed_int> listener;
 
 
     ASSERT_EQ(listener.value, 0);
     ASSERT_EQ(listener.value, 0);
 
 
-    dispatcher.sink<test::boxed_int>().connect<&listener::on>(listener);
+    dispatcher.sink<test::boxed_int>().connect<&test::listener<test::boxed_int>::on>(listener);
 
 
     cr_plugin ctx;
     cr_plugin ctx;
     cr_plugin_load(ctx, PLUGIN);
     cr_plugin_load(ctx, PLUGIN);

+ 3 - 10
test/lib/dispatcher/shared/main.cpp

@@ -1,26 +1,19 @@
 #include <gtest/gtest.h>
 #include <gtest/gtest.h>
 #include <common/boxed_type.h>
 #include <common/boxed_type.h>
+#include <common/listener.h>
 #include <entt/core/attribute.h>
 #include <entt/core/attribute.h>
 #include <entt/core/utility.hpp>
 #include <entt/core/utility.hpp>
 #include <entt/signal/dispatcher.hpp>
 #include <entt/signal/dispatcher.hpp>
 
 
 ENTT_API void trigger(entt::dispatcher &);
 ENTT_API void trigger(entt::dispatcher &);
 
 
-struct listener {
-    void on(test::boxed_int msg) {
-        value = msg.value;
-    }
-
-    int value{};
-};
-
 TEST(Lib, Dispatcher) {
 TEST(Lib, Dispatcher) {
     entt::dispatcher dispatcher;
     entt::dispatcher dispatcher;
-    listener listener;
+    test::listener<test::boxed_int> listener;
 
 
     ASSERT_EQ(listener.value, 0);
     ASSERT_EQ(listener.value, 0);
 
 
-    dispatcher.sink<test::boxed_int>().connect<entt::overload<void(test::boxed_int)>(&listener::on)>(listener);
+    dispatcher.sink<test::boxed_int>().connect<entt::overload<void(test::boxed_int)>(&test::listener<test::boxed_int>::on)>(listener);
     trigger(dispatcher);
     trigger(dispatcher);
 
 
     ASSERT_EQ(listener.value, 2);
     ASSERT_EQ(listener.value, 2);