check_types_range.c 3.2 KB

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