check_memory.c 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /*
  2. * check_memory.c
  3. *
  4. * Created on: 10.04.2014
  5. * Author: mrt
  6. */
  7. #include <stdio.h>
  8. #include <stdlib.h>
  9. #include "opcua.h"
  10. #include "check.h"
  11. START_TEST (checkEncodeShallYieldDecode)
  12. {
  13. void *obj1 = UA_NULL, *obj2 = UA_NULL;
  14. UA_ByteString msg1, msg2;
  15. // UA_ByteString x;
  16. UA_Int32 retval, pos;
  17. // printf("testing idx=%d,name=%s\n",_i,UA_[_i].name);
  18. // create src object
  19. retval = UA_[_i].new(&obj1);
  20. // printf("retval=%d, ",retval); x.length = UA_[_i].calcSize(UA_NULL); x.data = (UA_Byte*) obj1; UA_ByteString_printx_hex("obj1=",&x);
  21. // encode obj into buffer
  22. UA_ByteString_newMembers(&msg1,UA_[_i].calcSize(obj1));
  23. pos = 0;
  24. retval = UA_[_i].encodeBinary(obj1, &pos, &msg1);
  25. // printf("retval=%d, ",retval); x.length = pos; x.data = (UA_Byte*) msg1.data; UA_ByteString_printx_hex("msg1=",&x);
  26. // create dst object
  27. UA_[_i].new(&obj2);
  28. pos = 0;
  29. retval = UA_[_i].decodeBinary(&msg1, &pos, obj2);
  30. // printf("retval=%d, ",retval); x.length = UA_[_i].calcSize(UA_NULL); x.data = (UA_Byte*) obj2; UA_ByteString_printx_hex("obj2=",&x);
  31. UA_ByteString_newMembers(&msg2,UA_[_i].calcSize(obj2));
  32. pos = 0;
  33. retval = UA_[_i].encodeBinary(obj2, &pos, &msg2);
  34. // printf("retval=%d, ",retval); x.length = pos; x.data = (UA_Byte*) msg2.data; UA_ByteString_printx_hex("msg2=",&x);
  35. ck_assert_msg(UA_ByteString_compare(&msg1,&msg2)==0,"messages differ idx=%d,name=%s",_i,UA_[_i].name);
  36. ck_assert_int_eq(retval,UA_SUCCESS);
  37. }
  38. END_TEST
  39. int main() {
  40. int number_failed = 0;
  41. SRunner *sr;
  42. Suite *s = suite_create("testMemoryHandling");
  43. TCase *tc = tcase_create("Empty Objects");
  44. tcase_add_loop_test(tc, checkEncodeShallYieldDecode,23,UA_INVALIDTYPE-1);
  45. suite_add_tcase(s,tc);
  46. sr = srunner_create(s);
  47. srunner_set_fork_status(sr,CK_NOFORK);
  48. srunner_run_all(sr,CK_NORMAL);
  49. number_failed += srunner_ntests_failed(sr);
  50. srunner_free(sr);
  51. return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
  52. }