123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- /* This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
- #include "check.h"
- #include "testing_clock.h"
- #include "tests/ua_namespace_tests_testnodeset.h"
- #include "ua_config_default.h"
- #include "ua_server.h"
- #include "ua_types.h"
- #include "unistd.h"
- UA_Server *server = NULL;
- UA_ServerConfig *config = NULL;
- UA_DataTypeArray customTypesArray = { NULL, UA_TYPES_TESTNODESET_COUNT, UA_TYPES_TESTNODESET};
- static void setup(void) {
- config = UA_ServerConfig_new_default();
- config->customDataTypes = &customTypesArray;
- server = UA_Server_new(config);
- UA_Server_run_startup(server);
- }
- static void teardown(void) {
- UA_Server_run_shutdown(server);
- UA_Server_delete(server);
- UA_ServerConfig_delete(config);
- }
- START_TEST(Server_addTestNodeset) {
- UA_StatusCode retval = ua_namespace_tests_testnodeset(server);
- ck_assert_uint_eq(retval, UA_STATUSCODE_GOOD);
- }
- END_TEST
- START_TEST(checkScalarValues) {
- UA_Variant out;
- UA_Variant_init(&out);
- // Point_scalar_Init
- UA_Server_readValue(server, UA_NODEID_NUMERIC(2, 10002), &out);
- ck_assert(UA_Variant_isScalar(&out));
- UA_Point *p = (UA_Point *)out.data;
- ck_assert(p->x == (UA_Double)1.0);
- ck_assert(p->y == (UA_Double)2.0);
- UA_Variant_clear(&out);
- // Point_scalar_noInit
- UA_Server_readValue(server, UA_NODEID_NUMERIC(2, 10005), &out);
- p = (UA_Point *)out.data;
- ck_assert(UA_Variant_isScalar(&out));
- ck_assert(p->x == (UA_Double)0.0);
- ck_assert(p->y == (UA_Double)0.0);
- UA_Variant_clear(&out);
- }
- END_TEST
- START_TEST(check1dimValues) {
- UA_Variant out;
- UA_Variant_init(&out);
- // Point_1dim_noInit
- UA_Server_readValue(server, UA_NODEID_NUMERIC(2, 10007), &out);
- ck_assert(!UA_Variant_isScalar(&out));
- ck_assert(out.arrayDimensionsSize == 0);
- UA_Variant_clear(&out);
- // Point_1dim_init
- UA_Server_readValue(server, UA_NODEID_NUMERIC(2, 10004), &out);
- UA_Point *p = (UA_Point *)out.data;
- ck_assert(!UA_Variant_isScalar(&out));
- ck_assert(out.arrayLength == 4);
- ck_assert(p[0].x == (UA_Double)1.0);
- ck_assert(p[3].y == (UA_Double)8.0);
- UA_Variant_clear(&out);
- }
- END_TEST
- START_TEST(readValueRank) {
- UA_Int32 rank;
- UA_Variant dims;
- // scalar
- UA_Server_readValueRank(server, UA_NODEID_NUMERIC(2, 10002), &rank);
- ck_assert_int_eq(rank, -1);
- UA_Server_readValueRank(server, UA_NODEID_NUMERIC(2, 10002), &rank);
- ck_assert_int_eq(rank, -1);
- UA_Variant_init(&dims);
- UA_Server_readArrayDimensions(server, UA_NODEID_NUMERIC(2, 10002), &dims);
- ck_assert_int_eq(dims.arrayLength, 0);
- UA_Variant_clear(&dims);
- // 1-dim
- UA_Server_readValueRank(server, UA_NODEID_NUMERIC(2, 10007), &rank);
- ck_assert_int_eq(rank, 1);
- UA_Server_readArrayDimensions(server, UA_NODEID_NUMERIC(2, 10007), &dims);
- ck_assert_int_eq(dims.arrayLength, 1);
- ck_assert_int_eq(*((UA_UInt32 *)dims.data), 0);
- UA_Variant_clear(&dims);
- UA_Server_readValueRank(server, UA_NODEID_NUMERIC(2, 10004), &rank);
- ck_assert_int_eq(rank, 1);
- UA_Server_readArrayDimensions(server, UA_NODEID_NUMERIC(2, 10004), &dims);
- ck_assert_int_eq(dims.arrayLength, 1);
- ck_assert_int_eq(*((UA_UInt32 *)dims.data), 4);
- UA_Variant_clear(&dims);
- // 2-dim
- UA_Server_readValueRank(server, UA_NODEID_NUMERIC(2, 10006), &rank);
- ck_assert_int_eq(rank, 2);
- UA_Server_readArrayDimensions(server, UA_NODEID_NUMERIC(2, 10006), &dims);
- ck_assert_int_eq(dims.arrayLength, 2);
- UA_UInt32 *dimensions = (UA_UInt32 *)dims.data;
- ck_assert_int_eq(dimensions[0], 2);
- ck_assert_int_eq(dimensions[1], 2);
- UA_Variant_clear(&dims);
- }
- END_TEST
- static Suite *testSuite_Client(void) {
- Suite *s = suite_create("Server Nodeset Compiler");
- TCase *tc_server = tcase_create("Server Testnodeset");
- tcase_add_unchecked_fixture(tc_server, setup, teardown);
- tcase_add_test(tc_server, Server_addTestNodeset);
- tcase_add_test(tc_server, checkScalarValues);
- tcase_add_test(tc_server, check1dimValues);
- tcase_add_test(tc_server, readValueRank);
- 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;
- }
|