/* * check_memory.c * * Created on: 10.04.2014 * Author: mrt */ #define _XOPEN_SOURCE 500 #include #include #include "opcua.h" #include "check.h" START_TEST (newAndEmptyObjectShallBeDeleted) { // given UA_Int32 retval; void* obj; // when retval = UA_[_i].new(&obj); retval |= UA_[_i].delete(obj); // then ck_assert_int_eq(retval,UA_SUCCESS); } END_TEST START_TEST (arrayCopyShallMakeADeepCopy) { // given UA_String **a1; UA_Array_new((void***)&a1,3,UA_STRING); UA_String_copycstring("a",a1[0]); UA_String_copycstring("bb",a1[1]); UA_String_copycstring("ccc",a1[2]); // when UA_String **a2; UA_Int32 retval = UA_Array_copy((void const*const*)a1,3,UA_STRING,(void ***)&a2); // then ck_assert_int_eq(retval,UA_SUCCESS); ck_assert_int_eq(((UA_String **)a1)[0]->length,1); ck_assert_int_eq(((UA_String **)a1)[1]->length,2); ck_assert_int_eq(((UA_String **)a1)[2]->length,3); ck_assert_int_eq(((UA_String **)a1)[0]->length,((UA_String **)a2)[0]->length); ck_assert_int_eq(((UA_String **)a1)[1]->length,((UA_String **)a2)[1]->length); ck_assert_int_eq(((UA_String **)a1)[2]->length,((UA_String **)a2)[2]->length); ck_assert_ptr_ne(((UA_String **)a1)[0]->data,((UA_String **)a2)[0]->data); ck_assert_ptr_ne(((UA_String **)a1)[1]->data,((UA_String **)a2)[1]->data); ck_assert_ptr_ne(((UA_String **)a1)[2]->data,((UA_String **)a2)[2]->data); ck_assert_int_eq(((UA_String **)a1)[0]->data[0],((UA_String **)a2)[0]->data[0]); ck_assert_int_eq(((UA_String **)a1)[1]->data[0],((UA_String **)a2)[1]->data[0]); ck_assert_int_eq(((UA_String **)a1)[2]->data[0],((UA_String **)a2)[2]->data[0]); // finally UA_Array_delete((void***)&a1,3,UA_STRING); UA_Array_delete((void***)&a2,3,UA_STRING); } END_TEST START_TEST (encodeShallYieldDecode) { // given void *obj1 = UA_NULL, *obj2 = UA_NULL; UA_ByteString msg1, msg2; UA_Int32 retval, pos = 0; retval = UA_[_i].new(&obj1); UA_ByteString_newMembers(&msg1,UA_[_i].calcSize(obj1)); retval = UA_[_i].encodeBinary(obj1, &pos, &msg1); // when UA_[_i].new(&obj2); pos = 0; retval = UA_[_i].decodeBinary(&msg1, &pos, obj2); UA_ByteString_newMembers(&msg2,UA_[_i].calcSize(obj2)); pos = 0; retval = UA_[_i].encodeBinary(obj2, &pos, &msg2); // then ck_assert_msg(UA_ByteString_compare(&msg1,&msg2)==0,"messages differ idx=%d,name=%s",_i,UA_[_i].name); ck_assert_int_eq(retval,UA_SUCCESS); // finally UA_[_i].delete(obj1); UA_[_i].delete(obj2); UA_ByteString_deleteMembers(&msg1); UA_ByteString_deleteMembers(&msg2); } END_TEST START_TEST (decodeShallFailWithTruncatedBufferButSurvive) { // given void *obj1 = UA_NULL, *obj2 = UA_NULL; UA_ByteString msg1; UA_Int32 pos; UA_[_i].new(&obj1); UA_ByteString_newMembers(&msg1,UA_[_i].calcSize(obj1)); pos = 0; UA_[_i].encodeBinary(obj1, &pos, &msg1); UA_[_i].delete(obj1); // when UA_[_i].new(&obj2); pos = 0; msg1.length = msg1.length / 2; //fprintf(stderr,"testing %s with half buffer\n",UA_[_i].name); UA_[_i].decodeBinary(&msg1, &pos, obj2); //then // finally //fprintf(stderr,"delete %s with half buffer\n",UA_[_i].name); UA_[_i].delete(obj2); UA_ByteString_deleteMembers(&msg1); } END_TEST START_TEST (decodeScalarBasicTypeFromRandomBufferShallSucceed) { // given void *obj1 = UA_NULL; UA_ByteString msg1; UA_Int32 retval, buflen; buflen = 256; UA_ByteString_newMembers(&msg1,buflen); // fixed size srandom(42); retval = UA_SUCCESS; for(int n=0;n<100;n++) { retval |= UA_[_i].new(&obj1); UA_Int32 i; for(i=0;i