check_local_monitored_item.c 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /* This Source Code Form is subject to the terms of the Mozilla Public
  2. * License, v. 2.0. If a copy of the MPL was not distributed with this
  3. * file, You can obtain one at http://mozilla.org/MPL/2.0/.
  4. *
  5. * Copyright 2018 (c) basysKom GmbH <opensource@basyskom.com> (Author: Peter Rustler)
  6. */
  7. #include <open62541/client_subscriptions.h>
  8. #include <open62541/server.h>
  9. #include <open62541/server_config_default.h>
  10. #include <open62541/types.h>
  11. #include <stddef.h>
  12. #include "check.h"
  13. #include "testing_clock.h"
  14. #include "testing_networklayers.h"
  15. #ifdef UA_ENABLE_STATUSCODE_DESCRIPTIONS
  16. #define ASSERT_STATUSCODE(a,b) ck_assert_str_eq(UA_StatusCode_name(a),UA_StatusCode_name(b));
  17. #else
  18. #define ASSERT_STATUSCODE(a,b) ck_assert_uint_eq((a),(b));
  19. #endif
  20. UA_Server *server;
  21. UA_ServerConfig *config;
  22. size_t callbackCount = 0;
  23. UA_NodeId parentNodeId;
  24. UA_NodeId parentReferenceNodeId;
  25. UA_NodeId outNodeId;
  26. static void
  27. setup(void)
  28. {
  29. config = UA_ServerConfig_new_default();
  30. server = UA_Server_new(config);
  31. UA_StatusCode retval = UA_Server_run_startup(server);
  32. ASSERT_STATUSCODE(retval, UA_STATUSCODE_GOOD);
  33. /* Define the attribute of the uint32 variable node */
  34. UA_VariableAttributes attr = UA_VariableAttributes_default;
  35. UA_UInt32 myUint32 = 40;
  36. UA_Variant_setScalar(&attr.value, &myUint32, &UA_TYPES[UA_TYPES_UINT32]);
  37. attr.description = UA_LOCALIZEDTEXT("en-US","the answer");
  38. attr.displayName = UA_LOCALIZEDTEXT("en-US","the answer");
  39. attr.dataType = UA_TYPES[UA_TYPES_UINT32].typeId;
  40. attr.accessLevel = UA_ACCESSLEVELMASK_READ | UA_ACCESSLEVELMASK_WRITE;
  41. /* Add the variable node to the information model */
  42. UA_NodeId uint32NodeId = UA_NODEID_STRING(1, "the.answer");
  43. UA_QualifiedName uint32Name = UA_QUALIFIEDNAME(1, "the answer");
  44. parentNodeId = UA_NODEID_NUMERIC(0, UA_NS0ID_OBJECTSFOLDER);
  45. parentReferenceNodeId = UA_NODEID_NUMERIC(0, UA_NS0ID_ORGANIZES);
  46. UA_NodeId_init(&outNodeId);
  47. ASSERT_STATUSCODE(UA_Server_addVariableNode(server,
  48. uint32NodeId,
  49. parentNodeId,
  50. parentReferenceNodeId,
  51. uint32Name,
  52. UA_NODEID_NUMERIC(0, UA_NS0ID_BASEDATAVARIABLETYPE),
  53. attr,
  54. NULL,
  55. &outNodeId), UA_STATUSCODE_GOOD);
  56. }
  57. static void
  58. teardown(void)
  59. {
  60. /* cleanup */
  61. UA_NodeId_deleteMembers(&parentNodeId);
  62. UA_NodeId_deleteMembers(&parentReferenceNodeId);
  63. UA_NodeId_deleteMembers(&outNodeId);
  64. UA_Server_run_shutdown(server);
  65. UA_Server_delete(server);
  66. UA_ServerConfig_delete(config);
  67. }
  68. static void
  69. dataChangeNotificationCallback(UA_Server *thisServer,
  70. UA_UInt32 monitoredItemId,
  71. void *monitoredItemContext,
  72. const UA_NodeId *nodeId,
  73. void *nodeContext,
  74. UA_UInt32 attributeId,
  75. const UA_DataValue *value)
  76. {
  77. static UA_UInt32 lastValue = 100;
  78. UA_UInt32 currentValue = *((UA_UInt32*)value->value.data);
  79. ck_assert_uint_ne(lastValue, currentValue);
  80. lastValue = currentValue;
  81. callbackCount++;
  82. }
  83. START_TEST(Server_LocalMonitoredItem) {
  84. ck_assert_uint_eq(callbackCount, 0);
  85. UA_MonitoredItemCreateRequest monitorRequest =
  86. UA_MonitoredItemCreateRequest_default(outNodeId);
  87. monitorRequest.requestedParameters.samplingInterval = (double)100;
  88. monitorRequest.monitoringMode = UA_MONITORINGMODE_REPORTING;
  89. UA_MonitoredItemCreateResult result =
  90. UA_Server_createDataChangeMonitoredItem(server,
  91. UA_TIMESTAMPSTORETURN_BOTH,
  92. monitorRequest,
  93. NULL,
  94. &dataChangeNotificationCallback);
  95. ASSERT_STATUSCODE(result.statusCode, UA_STATUSCODE_GOOD);
  96. ck_assert_uint_eq(callbackCount, 1);
  97. UA_UInt32 count = 0;
  98. UA_Variant val;
  99. UA_Variant_setScalar(&val, &count, &UA_TYPES[UA_TYPES_UINT32]);
  100. for(size_t i = 0; i < 10; i++) {
  101. count++;
  102. UA_Server_writeValue(server, outNodeId, val);
  103. UA_fakeSleep(100);
  104. UA_Server_run_iterate(server, 1);
  105. }
  106. ck_assert_uint_eq(callbackCount, 11);
  107. }
  108. END_TEST
  109. static Suite* testSuite_Client(void)
  110. {
  111. Suite *s = suite_create("Local Monitored Item");
  112. TCase *tc_server = tcase_create("Local Monitored Item Basic");
  113. tcase_add_checked_fixture(tc_server, setup, teardown);
  114. tcase_add_test(tc_server, Server_LocalMonitoredItem);
  115. suite_add_tcase(s, tc_server);
  116. return s;
  117. }
  118. int main(void)
  119. {
  120. Suite *s = testSuite_Client();
  121. SRunner *sr = srunner_create(s);
  122. srunner_set_fork_status(sr, CK_NOFORK);
  123. srunner_run_all(sr,CK_NORMAL);
  124. int number_failed = srunner_ntests_failed(sr);
  125. srunner_free(sr);
  126. return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
  127. }