check_types_range.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  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. #include "ua_types.h"
  5. #include "ua_types_generated_handling.h"
  6. #include "ua_util.h"
  7. #include "check.h"
  8. /* copied definition */
  9. UA_StatusCode parse_numericrange(const UA_String *str, UA_NumericRange *range);
  10. START_TEST(parseRange) {
  11. UA_NumericRange range;
  12. UA_String str = UA_STRING("1:2,0:3,5");
  13. UA_StatusCode retval = parse_numericrange(&str, &range);
  14. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  15. ck_assert_int_eq(range.dimensionsSize,3);
  16. ck_assert_int_eq(range.dimensions[0].min,1);
  17. ck_assert_int_eq(range.dimensions[0].max,2);
  18. ck_assert_int_eq(range.dimensions[1].min,0);
  19. ck_assert_int_eq(range.dimensions[1].max,3);
  20. ck_assert_int_eq(range.dimensions[2].min,5);
  21. ck_assert_int_eq(range.dimensions[2].max,5);
  22. UA_free(range.dimensions);
  23. } END_TEST
  24. START_TEST(parseRangeMinEqualMax) {
  25. UA_NumericRange range;
  26. UA_String str = UA_STRING("1:2,1");
  27. UA_StatusCode retval = parse_numericrange(&str, &range);
  28. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  29. ck_assert_int_eq(range.dimensionsSize,2);
  30. ck_assert_int_eq(range.dimensions[0].min,1);
  31. ck_assert_int_eq(range.dimensions[0].max,2);
  32. ck_assert_int_eq(range.dimensions[1].min,1);
  33. ck_assert_int_eq(range.dimensions[1].max,1);
  34. UA_free(range.dimensions);
  35. } END_TEST
  36. START_TEST(copySimpleArrayRange) {
  37. UA_Variant v, v2;
  38. UA_Variant_init(&v);
  39. UA_Variant_init(&v2);
  40. UA_UInt32 arr[5] = {1,2,3,4,5};
  41. UA_Variant_setArray(&v, arr, 5, &UA_TYPES[UA_TYPES_UINT32]);
  42. UA_NumericRange r;
  43. UA_String sr = UA_STRING("1:3");
  44. UA_StatusCode retval = parse_numericrange(&sr, &r);
  45. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  46. retval = UA_Variant_copyRange(&v, &v2, r);
  47. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  48. ck_assert_int_eq(3, v2.arrayLength);
  49. ck_assert_int_eq(2, *(UA_UInt32*)v2.data);
  50. UA_Variant_deleteMembers(&v2);
  51. UA_free(r.dimensions);
  52. }
  53. END_TEST
  54. START_TEST(copyIntoStringArrayRange) {
  55. UA_Variant v, v2;
  56. UA_Variant_init(&v);
  57. UA_Variant_init(&v2);
  58. UA_String arr[2];
  59. arr[0] = UA_STRING("abcd");
  60. arr[1] = UA_STRING("wxyz");
  61. UA_Variant_setArray(&v, arr, 5, &UA_TYPES[UA_TYPES_STRING]);
  62. UA_NumericRange r;
  63. UA_String sr = UA_STRING("0:1,1:2");
  64. UA_StatusCode retval = parse_numericrange(&sr, &r);
  65. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  66. retval = UA_Variant_copyRange(&v, &v2, r);
  67. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  68. ck_assert_int_eq(2, v2.arrayLength);
  69. UA_String s1 = UA_STRING("bc");
  70. UA_String s2 = UA_STRING("xy");
  71. UA_String *arr2 = v2.data;
  72. ck_assert(UA_String_equal(&arr2[0], &s1));
  73. ck_assert(UA_String_equal(&arr2[1], &s2));
  74. UA_Variant_deleteMembers(&v2);
  75. UA_free(r.dimensions);
  76. }
  77. END_TEST
  78. int main(void) {
  79. Suite *s = suite_create("Test Variant Range Access");
  80. TCase *tc = tcase_create("test cases");
  81. tcase_add_test(tc, parseRange);
  82. tcase_add_test(tc, parseRangeMinEqualMax);
  83. tcase_add_test(tc, copySimpleArrayRange);
  84. tcase_add_test(tc, copyIntoStringArrayRange);
  85. suite_add_tcase(s, tc);
  86. SRunner *sr = srunner_create(s);
  87. srunner_run_all (sr, CK_NORMAL);
  88. int number_failed = srunner_ntests_failed(sr);
  89. srunner_free(sr);
  90. return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
  91. }