1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- #include <open62541/server_config_default.h>
- #include "server/ua_server_internal.h"
- #include <check.h>
- #include "testing_clock.h"
- UA_Server *server = NULL;
- UA_Boolean *executed;
- static void setup(void) {
- server = UA_Server_new();
- UA_ServerConfig_setDefault(UA_Server_getConfig(server));
- UA_Server_run_startup(server);
- }
- static void teardown(void) {
- UA_Server_run_shutdown(server);
- UA_Server_delete(server);
- }
- static void
- dummyCallback(UA_Server *serverPtr, void *data) {
- *executed = true;
- }
- START_TEST(Server_addRemoveRepeatedCallback) {
- executed = UA_Boolean_new();
-
- UA_UInt64 id;
- UA_Server_addRepeatedCallback(server, dummyCallback, NULL, 10, &id);
-
- UA_fakeSleep(15);
- UA_Server_run_iterate(server, false);
-
- UA_realSleep(100);
- ck_assert_uint_eq(*executed, true);
- UA_Server_removeRepeatedCallback(server, id);
- UA_Boolean_delete(executed);
- }
- END_TEST
- UA_UInt64 *cbId;
- static void
- removeItselfCallback(UA_Server *serverPtr, void *data) {
- UA_Server_removeRepeatedCallback(serverPtr, *cbId);
- }
- START_TEST(Server_repeatedCallbackRemoveItself) {
- cbId = UA_UInt64_new();
- UA_Server_addRepeatedCallback(server, removeItselfCallback, NULL, 10, cbId);
- UA_fakeSleep(15);
- UA_Server_run_iterate(server, false);
- UA_UInt64_delete(cbId);
- }
- END_TEST
- static Suite* testSuite_Client(void) {
- Suite *s = suite_create("Server Callbacks");
- TCase *tc_server = tcase_create("Server Repeated Callbacks");
- tcase_add_checked_fixture(tc_server, setup, teardown);
- tcase_add_test(tc_server, Server_addRemoveRepeatedCallback);
- tcase_add_test(tc_server, Server_repeatedCallbackRemoveItself);
- suite_add_tcase(s, tc_server);
- return s;
- }
- int main(void) {
- Suite *s = testSuite_Client();
- SRunner *sr = srunner_create(s);
- srunner_set_fork_status(sr, CK_NOFORK);
- srunner_run_all(sr,CK_NORMAL);
- int number_failed = srunner_ntests_failed(sr);
- srunner_free(sr);
- return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
- }
|