check_pubsub_publishspeed.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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 (c) 2017 - 2018 Fraunhofer IOSB (Author: Andreas Ebner)
  6. */
  7. #include <open62541/plugin/pubsub_udp.h>
  8. #include <open62541/server_config_default.h>
  9. #include <open62541/server_pubsub.h>
  10. #include <open62541/types_generated_encoding_binary.h>
  11. #include "ua_server_internal.h"
  12. #include <check.h>
  13. #include <stdio.h>
  14. #include <time.h>
  15. UA_Server *server = NULL;
  16. UA_NodeId connection1, connection2, writerGroup1, writerGroup2, writerGroup3,
  17. publishedDataSet1, publishedDataSet2, dataSetWriter1, dataSetWriter2, dataSetWriter3;
  18. static void setup(void) {
  19. server = UA_Server_new();
  20. UA_ServerConfig *config = UA_Server_getConfig(server);
  21. UA_ServerConfig_setDefault(config);
  22. config->pubsubTransportLayers = (UA_PubSubTransportLayer*)
  23. UA_malloc(sizeof(UA_PubSubTransportLayer));
  24. config->pubsubTransportLayers[0] = UA_PubSubTransportLayerUDPMP();
  25. config->pubsubTransportLayersSize++;
  26. UA_PubSubConnectionConfig connectionConfig;
  27. memset(&connectionConfig, 0, sizeof(UA_PubSubConnectionConfig));
  28. connectionConfig.name = UA_STRING("UADP Connection");
  29. UA_NetworkAddressUrlDataType networkAddressUrl = {UA_STRING_NULL, UA_STRING("opc.udp://224.0.0.22:4840/")};
  30. UA_Variant_setScalar(&connectionConfig.address, &networkAddressUrl,
  31. &UA_TYPES[UA_TYPES_NETWORKADDRESSURLDATATYPE]);
  32. connectionConfig.transportProfileUri = UA_STRING("http://opcfoundation.org/UA-Profile/Transport/pubsub-udp-uadp");
  33. UA_Server_addPubSubConnection(server, &connectionConfig, &connection1);
  34. UA_WriterGroupConfig writerGroupConfig;
  35. memset(&writerGroupConfig, 0, sizeof(writerGroupConfig));
  36. writerGroupConfig.name = UA_STRING("WriterGroup 1");
  37. writerGroupConfig.publishingInterval = 10;
  38. writerGroupConfig.encodingMimeType = UA_PUBSUB_ENCODING_UADP;
  39. UA_Server_addWriterGroup(server, connection1, &writerGroupConfig, &writerGroup1);
  40. UA_PublishedDataSetConfig pdsConfig;
  41. memset(&pdsConfig, 0, sizeof(UA_PublishedDataSetConfig));
  42. pdsConfig.publishedDataSetType = UA_PUBSUB_DATASET_PUBLISHEDITEMS;
  43. pdsConfig.name = UA_STRING("PublishedDataSet 1");
  44. UA_Server_addPublishedDataSet(server, &pdsConfig, &publishedDataSet1);
  45. UA_DataSetWriterConfig dataSetWriterConfig;
  46. memset(&dataSetWriterConfig, 0, sizeof(dataSetWriterConfig));
  47. dataSetWriterConfig.name = UA_STRING("DataSetWriter 1");
  48. UA_Server_addDataSetWriter(server, writerGroup1, publishedDataSet1, &dataSetWriterConfig, &dataSetWriter1);
  49. UA_Server_run_startup(server);
  50. }
  51. static void teardown(void) {
  52. UA_Server_run_shutdown(server);
  53. UA_Server_delete(server);
  54. }
  55. START_TEST(PublishSpeedTest) {
  56. UA_DataSetFieldConfig dataSetFieldConfig;
  57. memset(&dataSetFieldConfig, 0, sizeof(UA_DataSetFieldConfig));
  58. dataSetFieldConfig.dataSetFieldType = UA_PUBSUB_DATASETFIELD_VARIABLE;
  59. dataSetFieldConfig.field.variable.fieldNameAlias = UA_STRING("Server localtime");
  60. dataSetFieldConfig.field.variable.promotedField = UA_FALSE;
  61. dataSetFieldConfig.field.variable.publishParameters.publishedVariable = UA_NODEID_NUMERIC(0, UA_NS0ID_SERVER_LOCALTIME);
  62. dataSetFieldConfig.field.variable.publishParameters.attributeId = UA_ATTRIBUTEID_VALUE;
  63. UA_Server_addDataSetField(server, publishedDataSet1, &dataSetFieldConfig, NULL);
  64. UA_WriterGroup *wg = UA_WriterGroup_findWGbyId(server, writerGroup1);
  65. printf("start sending 8000 publish messages via UDP\n");
  66. clock_t begin, finish;
  67. begin = clock();
  68. for(int i = 0; i < 8000; i++) {
  69. UA_WriterGroup_publishCallback(server, wg);
  70. }
  71. finish = clock();
  72. double time_spent = (double)(finish - begin) / CLOCKS_PER_SEC;
  73. printf("duration was %f s\n", time_spent);
  74. } END_TEST
  75. int main(void) {
  76. TCase *tc_publishspeed = tcase_create("Speed of the publisher");
  77. tcase_add_checked_fixture(tc_publishspeed, setup, teardown);
  78. tcase_add_test(tc_publishspeed, PublishSpeedTest);
  79. Suite *s = suite_create("PubSub Speed Test");
  80. suite_add_tcase(s, tc_publishspeed);
  81. SRunner *sr = srunner_create(s);
  82. srunner_set_fork_status(sr, CK_NOFORK);
  83. srunner_run_all(sr,CK_NORMAL);
  84. int number_failed = srunner_ntests_failed(sr);
  85. srunner_free(sr);
  86. return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
  87. }