check_builtin.c 52 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include "ua_types.h"
  4. #include "ua_types_encoding_binary.h"
  5. #include "ua_types_generated.h"
  6. #include "ua_types_generated_encoding_binary.h"
  7. //#include "ua_transport.h"
  8. #include "ua_util.h"
  9. #include "check.h"
  10. /* copied here from encoding_binary.c */
  11. enum UA_VARIANT_ENCODINGMASKTYPE_enum {
  12. UA_VARIANT_ENCODINGMASKTYPE_TYPEID_MASK = 0x3F, // bits 0:5
  13. UA_VARIANT_ENCODINGMASKTYPE_DIMENSIONS = (0x01 << 6), // bit 6
  14. UA_VARIANT_ENCODINGMASKTYPE_ARRAY = (0x01 << 7) // bit 7
  15. };
  16. START_TEST(UA_Byte_decodeShallCopyAndAdvancePosition) {
  17. // given
  18. UA_Byte dst;
  19. UA_Byte data[] = { 0x08 };
  20. UA_ByteString src = { 1, data };
  21. size_t pos = 0;
  22. // when
  23. UA_StatusCode retval = UA_Byte_decodeBinary(&src, &pos, &dst);
  24. // then
  25. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  26. ck_assert_uint_eq(pos, 1);
  27. ck_assert_uint_eq(pos, UA_calcSizeBinary(&dst, &UA_TYPES[UA_TYPES_BYTE]));
  28. ck_assert_uint_eq(dst, 0x08);
  29. }
  30. END_TEST
  31. START_TEST(UA_Byte_decodeShallModifyOnlyCurrentPosition) {
  32. // given
  33. UA_Byte dst[] = { 0xFF, 0xFF, 0xFF };
  34. UA_Byte data[] = { 0x08 };
  35. UA_ByteString src = { 1, data };
  36. size_t pos = 0;
  37. // when
  38. UA_StatusCode retval = UA_Byte_decodeBinary(&src, &pos, &dst[1]);
  39. // then
  40. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  41. ck_assert_int_eq(pos, 1);
  42. ck_assert_uint_eq(dst[0], 0xFF);
  43. ck_assert_uint_eq(dst[1], 0x08);
  44. ck_assert_uint_eq(dst[2], 0xFF);
  45. }
  46. END_TEST
  47. START_TEST(UA_Int16_decodeShallAssumeLittleEndian) {
  48. // given
  49. size_t pos = 0;
  50. UA_Byte data[] = {
  51. 0x01, 0x00, // 1
  52. 0x00, 0x01 // 256
  53. };
  54. UA_ByteString src = { 4, data };
  55. // when
  56. UA_Int16 val_01_00, val_00_01;
  57. UA_StatusCode retval = UA_Int16_decodeBinary(&src, &pos, &val_01_00);
  58. retval |= UA_Int16_decodeBinary(&src, &pos, &val_00_01);
  59. // then
  60. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  61. ck_assert_int_eq(val_01_00, 1);
  62. ck_assert_int_eq(val_00_01, 256);
  63. ck_assert_int_eq(pos, 4);
  64. }
  65. END_TEST
  66. START_TEST(UA_Int16_decodeShallRespectSign) {
  67. // given
  68. size_t pos = 0;
  69. UA_Byte data[] = {
  70. 0xFF, 0xFF, // -1
  71. 0x00, 0x80 // -32768
  72. };
  73. UA_ByteString src = { 4, data };
  74. // when
  75. UA_Int16 val_ff_ff, val_00_80;
  76. UA_StatusCode retval = UA_Int16_decodeBinary(&src, &pos, &val_ff_ff);
  77. retval |= UA_Int16_decodeBinary(&src, &pos, &val_00_80);
  78. // then
  79. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  80. ck_assert_int_eq(val_ff_ff, -1);
  81. ck_assert_int_eq(val_00_80, -32768);
  82. }
  83. END_TEST
  84. START_TEST(UA_UInt16_decodeShallNotRespectSign) {
  85. // given
  86. size_t pos = 0;
  87. UA_Byte data[] = {
  88. 0xFF, 0xFF, // (2^16)-1
  89. 0x00, 0x80 // (2^15)
  90. };
  91. UA_ByteString src = { 4, data };
  92. // when
  93. UA_UInt16 val_ff_ff, val_00_80;
  94. UA_StatusCode retval = UA_UInt16_decodeBinary(&src, &pos, &val_ff_ff);
  95. retval |= UA_UInt16_decodeBinary(&src, &pos, &val_00_80);
  96. // then
  97. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  98. ck_assert_int_eq(pos, 4);
  99. ck_assert_uint_eq(val_ff_ff, (0x01 << 16)-1);
  100. ck_assert_uint_eq(val_00_80, (0x01 << 15));
  101. }
  102. END_TEST
  103. START_TEST(UA_Int32_decodeShallAssumeLittleEndian) {
  104. // given
  105. size_t pos = 0;
  106. UA_Byte data[] = {
  107. 0x01, 0x00, 0x00, 0x00, // 1
  108. 0x00, 0x01, 0x00, 0x00 // 256
  109. };
  110. UA_ByteString src = { 8, data };
  111. // when
  112. UA_Int32 val_01_00, val_00_01;
  113. UA_StatusCode retval = UA_Int32_decodeBinary(&src, &pos, &val_01_00);
  114. retval |= UA_Int32_decodeBinary(&src, &pos, &val_00_01);
  115. // then
  116. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  117. ck_assert_int_eq(val_01_00, 1);
  118. ck_assert_int_eq(val_00_01, 256);
  119. ck_assert_int_eq(pos, 8);
  120. }
  121. END_TEST
  122. START_TEST(UA_Int32_decodeShallRespectSign) {
  123. // given
  124. size_t pos = 0;
  125. UA_Byte data[] = {
  126. 0xFF, 0xFF, 0xFF, 0xFF, // -1
  127. 0x00, 0x80, 0xFF, 0xFF // -32768
  128. };
  129. UA_ByteString src = { 8, data };
  130. // when
  131. UA_Int32 val_ff_ff, val_00_80;
  132. UA_StatusCode retval = UA_Int32_decodeBinary(&src, &pos, &val_ff_ff);
  133. retval |= UA_Int32_decodeBinary(&src, &pos, &val_00_80);
  134. // then
  135. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  136. ck_assert_int_eq(val_ff_ff, -1);
  137. ck_assert_int_eq(val_00_80, -32768);
  138. }
  139. END_TEST
  140. START_TEST(UA_UInt32_decodeShallNotRespectSign) {
  141. // given
  142. size_t pos = 0;
  143. UA_Byte data[] = {
  144. 0xFF, 0xFF, 0xFF, 0xFF, // (2^32)-1
  145. 0x00, 0x00, 0x00, 0x80 // (2^31)
  146. };
  147. UA_ByteString src = { 8, data };
  148. // when
  149. UA_UInt32 val_ff_ff, val_00_80;
  150. UA_StatusCode retval = UA_UInt32_decodeBinary(&src, &pos, &val_ff_ff);
  151. retval |= UA_UInt32_decodeBinary(&src, &pos, &val_00_80);
  152. // then
  153. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  154. ck_assert_int_eq(pos, 8);
  155. ck_assert_uint_eq(val_ff_ff, (UA_UInt32)( (0x01LL << 32 ) - 1 ));
  156. ck_assert_uint_eq(val_00_80, (UA_UInt32)(0x01 << 31));
  157. }
  158. END_TEST
  159. START_TEST(UA_UInt64_decodeShallNotRespectSign) {
  160. // given
  161. UA_ByteString rawMessage;
  162. UA_UInt64 expectedVal = 0xFF;
  163. expectedVal = expectedVal << 56;
  164. UA_Byte mem[8] = { 00, 00, 00, 00, 0x00, 0x00, 0x00, 0xFF };
  165. rawMessage.data = mem;
  166. rawMessage.length = 8;
  167. size_t pos = 0;
  168. UA_UInt64 val;
  169. // when
  170. UA_UInt64_decodeBinary(&rawMessage, &pos, &val);
  171. // then
  172. ck_assert_uint_eq(val, expectedVal);
  173. }
  174. END_TEST
  175. START_TEST(UA_Int64_decodeShallRespectSign) {
  176. // given
  177. UA_ByteString rawMessage;
  178. UA_Int64 expectedVal = 0xFF;
  179. expectedVal = expectedVal << 56;
  180. UA_Byte mem[8] = { 00, 00, 00, 00, 0x00, 0x00, 0x00, 0xFF };
  181. rawMessage.data = mem;
  182. rawMessage.length = 8;
  183. size_t pos = 0;
  184. UA_Int64 val;
  185. // when
  186. UA_Int64_decodeBinary(&rawMessage, &pos, &val);
  187. //then
  188. ck_assert_uint_eq(val, expectedVal);
  189. }
  190. END_TEST
  191. START_TEST(UA_Float_decodeShallWorkOnExample) {
  192. // given
  193. size_t pos = 0;
  194. UA_Byte data[] = { 0x00, 0x00, 0xD0, 0xC0 }; // -6.5
  195. UA_ByteString src = { 4, data };
  196. UA_Float dst;
  197. // when
  198. UA_StatusCode retval = UA_Float_decodeBinary(&src, &pos, &dst);
  199. // then
  200. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  201. ck_assert_int_eq(pos, 4);
  202. ck_assert(-6.5000001 < dst);
  203. ck_assert(dst < -6.49999999999);
  204. }
  205. END_TEST
  206. START_TEST(UA_Double_decodeShallGiveOne) {
  207. // given
  208. size_t pos = 0;
  209. UA_Byte data[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xF0, 0x3F }; // 1
  210. UA_ByteString src = { 8, data }; // 1
  211. UA_Double dst;
  212. // when
  213. UA_StatusCode retval = UA_Double_decodeBinary(&src, &pos, &dst);
  214. // then
  215. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  216. ck_assert_int_eq(pos, 8);
  217. ck_assert(0.9999999 < dst);
  218. ck_assert(dst < 1.00000000001);
  219. }
  220. END_TEST
  221. START_TEST(UA_Double_decodeShallGiveZero) {
  222. // given
  223. size_t pos = 0;
  224. UA_Byte data[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
  225. UA_ByteString src = { 8, data }; // 1
  226. UA_Double dst;
  227. // when
  228. UA_StatusCode retval = UA_Double_decodeBinary(&src, &pos, &dst);
  229. // then
  230. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  231. ck_assert_int_eq(pos, 8);
  232. ck_assert(-0.00000001 < dst);
  233. ck_assert(dst < 0.000000001);
  234. }
  235. END_TEST
  236. START_TEST(UA_Double_decodeShallGiveMinusTwo) {
  237. // given
  238. size_t pos = 0;
  239. UA_Byte data[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xC0 }; // -2
  240. UA_ByteString src = { 8, data };
  241. UA_Double dst;
  242. // when
  243. UA_StatusCode retval = UA_Double_decodeBinary(&src, &pos, &dst);
  244. // then
  245. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  246. ck_assert_int_eq(pos, 8);
  247. ck_assert(-1.9999999 > dst);
  248. ck_assert(dst > -2.00000000001);
  249. }
  250. END_TEST
  251. START_TEST(UA_Double_decodeShallGive2147483648) {
  252. // given
  253. size_t pos = 0;
  254. UA_Byte data[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x41 }; //2147483648
  255. UA_ByteString src = { 8, data }; // 1
  256. UA_Double dst;
  257. // when
  258. UA_StatusCode retval = UA_Double_decodeBinary(&src, &pos, &dst);
  259. // then
  260. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  261. ck_assert_int_eq(pos, 8);
  262. ck_assert(2147483647.9999999 <= dst);
  263. ck_assert(dst <= 2147483648.00000001);
  264. }
  265. END_TEST
  266. START_TEST(UA_String_decodeShallAllocateMemoryAndCopyString) {
  267. // given
  268. size_t pos = 0;
  269. UA_Byte data[] =
  270. { 0x08, 0x00, 0x00, 0x00, 'A', 'C', 'P', 'L', 'T', ' ', 'U', 'A', 0xFF, 0xFF, 0xFF, 0xFF, 0xFF };
  271. UA_ByteString src = { 16, data };
  272. UA_String dst;
  273. // when
  274. UA_StatusCode retval = UA_String_decodeBinary(&src, &pos, &dst);
  275. // then
  276. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  277. ck_assert_int_eq(dst.length, 8);
  278. ck_assert_int_eq(dst.data[3], 'L');
  279. ck_assert_uint_eq(pos, UA_calcSizeBinary(&dst, &UA_TYPES[UA_TYPES_STRING]));
  280. // finally
  281. UA_String_deleteMembers(&dst);
  282. }
  283. END_TEST
  284. START_TEST(UA_String_decodeWithNegativeSizeShallNotAllocateMemoryAndNullPtr) {
  285. // given
  286. size_t pos = 0;
  287. UA_Byte data[] =
  288. { 0xFF, 0xFF, 0xFF, 0xFF, 'A', 'C', 'P', 'L', 'T', ' ', 'U', 'A', 0xFF, 0xFF, 0xFF, 0xFF, 0xFF };
  289. UA_ByteString src = { 16, data };
  290. UA_String dst;
  291. // when
  292. UA_StatusCode retval = UA_String_decodeBinary(&src, &pos, &dst);
  293. // then
  294. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  295. ck_assert_int_eq(dst.length, 0);
  296. ck_assert_ptr_eq(dst.data, NULL);
  297. }
  298. END_TEST
  299. START_TEST(UA_String_decodeWithZeroSizeShallNotAllocateMemoryAndNullPtr) {
  300. // given
  301. size_t pos = 0;
  302. UA_Byte data[] =
  303. { 0x00, 0x00, 0x00, 0x00, 'A', 'C', 'P', 'L', 'T', ' ', 'U', 'A', 0xFF, 0xFF, 0xFF, 0xFF, 0xFF };
  304. UA_ByteString src = { 17, data };
  305. UA_String dst;
  306. // when
  307. UA_StatusCode retval = UA_String_decodeBinary(&src, &pos, &dst);
  308. // then
  309. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  310. ck_assert_int_eq(dst.length, 0);
  311. ck_assert_ptr_eq(dst.data, UA_EMPTY_ARRAY_SENTINEL);
  312. }
  313. END_TEST
  314. START_TEST(UA_NodeId_decodeTwoByteShallReadTwoBytesAndSetNamespaceToZero) {
  315. // given
  316. size_t pos = 0;
  317. UA_Byte data[] = { 0 /* UA_NODEIDTYPE_TWOBYTE */, 0x10 };
  318. UA_ByteString src = { 2, data };
  319. UA_NodeId dst;
  320. // when
  321. UA_StatusCode retval = UA_NodeId_decodeBinary(&src, &pos, &dst);
  322. // then
  323. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  324. ck_assert_int_eq(pos, 2);
  325. ck_assert_uint_eq(pos, UA_calcSizeBinary(&dst, &UA_TYPES[UA_TYPES_NODEID]));
  326. ck_assert_int_eq(dst.identifierType, UA_NODEIDTYPE_NUMERIC);
  327. ck_assert_int_eq(dst.identifier.numeric, 16);
  328. ck_assert_int_eq(dst.namespaceIndex, 0);
  329. }
  330. END_TEST
  331. START_TEST(UA_NodeId_decodeFourByteShallReadFourBytesAndRespectNamespace) {
  332. // given
  333. size_t pos = 0;
  334. UA_Byte data[] = { 1 /* UA_NODEIDTYPE_FOURBYTE */, 0x01, 0x00, 0x01 };
  335. UA_ByteString src = { 4, data };
  336. UA_NodeId dst;
  337. // when
  338. UA_StatusCode retval = UA_NodeId_decodeBinary(&src, &pos, &dst);
  339. // then
  340. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  341. ck_assert_int_eq(pos, 4);
  342. ck_assert_uint_eq(pos, UA_calcSizeBinary(&dst, &UA_TYPES[UA_TYPES_NODEID]));
  343. ck_assert_int_eq(dst.identifierType, UA_NODEIDTYPE_NUMERIC);
  344. ck_assert_int_eq(dst.identifier.numeric, 256);
  345. ck_assert_int_eq(dst.namespaceIndex, 1);
  346. }
  347. END_TEST
  348. START_TEST(UA_NodeId_decodeStringShallAllocateMemory) {
  349. // given
  350. size_t pos = 0;
  351. UA_Byte data[] = { UA_NODEIDTYPE_STRING, 0x01, 0x00, 0x03, 0x00, 0x00, 0x00, 'P', 'L', 'T' };
  352. UA_ByteString src = { 10, data };
  353. UA_NodeId dst;
  354. // when
  355. UA_StatusCode retval = UA_NodeId_decodeBinary(&src, &pos, &dst);
  356. // then
  357. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  358. ck_assert_int_eq(pos, 10);
  359. ck_assert_uint_eq(pos, UA_calcSizeBinary(&dst, &UA_TYPES[UA_TYPES_NODEID]));
  360. ck_assert_int_eq(dst.identifierType, UA_NODEIDTYPE_STRING);
  361. ck_assert_int_eq(dst.namespaceIndex, 1);
  362. ck_assert_int_eq(dst.identifier.string.length, 3);
  363. ck_assert_int_eq(dst.identifier.string.data[1], 'L');
  364. // finally
  365. UA_NodeId_deleteMembers(&dst);
  366. }
  367. END_TEST
  368. START_TEST(UA_Variant_decodeWithOutArrayFlagSetShallSetVTAndAllocateMemoryForArray) {
  369. // given
  370. size_t pos = 0;
  371. UA_Byte data[] = { UA_TYPES[UA_TYPES_INT32].typeId.identifier.numeric, 0xFF, 0x00, 0x00, 0x00 };
  372. UA_ByteString src = { 5, data };
  373. UA_Variant dst;
  374. // when
  375. UA_StatusCode retval = UA_Variant_decodeBinary(&src, &pos, &dst);
  376. // then
  377. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  378. ck_assert_int_eq(pos, 5);
  379. ck_assert_uint_eq(pos, UA_calcSizeBinary(&dst, &UA_TYPES[UA_TYPES_VARIANT]));
  380. //ck_assert_ptr_eq((const void *)dst.type, (const void *)&UA_TYPES[UA_TYPES_INT32]); //does not compile in gcc 4.6
  381. ck_assert_int_eq((uintptr_t)dst.type, (uintptr_t)&UA_TYPES[UA_TYPES_INT32]);
  382. ck_assert_int_eq(dst.arrayLength, 0);
  383. ck_assert_int_ne((uintptr_t)dst.data, 0);
  384. ck_assert_int_eq(*(UA_Int32 *)dst.data, 255);
  385. // finally
  386. UA_Variant_deleteMembers(&dst);
  387. }
  388. END_TEST
  389. START_TEST(UA_Variant_decodeWithArrayFlagSetShallSetVTAndAllocateMemoryForArray) {
  390. // given
  391. size_t pos = 0;
  392. UA_Byte data[] = { UA_TYPES[UA_TYPES_INT32].typeId.identifier.numeric | UA_VARIANT_ENCODINGMASKTYPE_ARRAY,
  393. 0x02, 0x00, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0xFF, 0xFF,
  394. 0xFF, 0xFF };
  395. UA_ByteString src = { 13, data };
  396. UA_Variant dst;
  397. // when
  398. UA_StatusCode retval = UA_Variant_decodeBinary(&src, &pos, &dst);
  399. // then
  400. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  401. ck_assert_int_eq(pos, 1+4+2*4);
  402. ck_assert_uint_eq(pos, UA_calcSizeBinary(&dst, &UA_TYPES[UA_TYPES_VARIANT]));
  403. //ck_assert_ptr_eq((const (void*))dst.type, (const void*)&UA_TYPES[UA_TYPES_INT32]); //does not compile in gcc 4.6
  404. ck_assert_int_eq((uintptr_t)dst.type,(uintptr_t)&UA_TYPES[UA_TYPES_INT32]);
  405. ck_assert_int_eq(dst.arrayLength, 2);
  406. ck_assert_int_eq(((UA_Int32 *)dst.data)[0], 255);
  407. ck_assert_int_eq(((UA_Int32 *)dst.data)[1], -1);
  408. // finally
  409. UA_Variant_deleteMembers(&dst);
  410. }
  411. END_TEST
  412. START_TEST(UA_Variant_decodeSingleExtensionObjectShallSetVTAndAllocateMemory){
  413. /* // given */
  414. /* size_t pos = 0; */
  415. /* UA_Variant dst; */
  416. /* UA_NodeId tmpNodeId; */
  417. /* UA_NodeId_init(&tmpNodeId); */
  418. /* tmpNodeId.identifier.numeric = 22; */
  419. /* tmpNodeId.namespaceIndex = 2; */
  420. /* tmpNodeId.identifierType = UA_NODEIDTYPE_NUMERIC; */
  421. /* UA_ExtensionObject tmpExtensionObject; */
  422. /* UA_ExtensionObject_init(&tmpExtensionObject); */
  423. /* tmpExtensionObject.encoding = UA_EXTENSIONOBJECT_ENCODED_BYTESTRING; */
  424. /* tmpExtensionObject.content.encoded.body = UA_ByteString_withSize(3); */
  425. /* tmpExtensionObject.content.encoded.body.data[0]= 10; */
  426. /* tmpExtensionObject.content.encoded.body.data[1]= 20; */
  427. /* tmpExtensionObject.content.encoded.body.data[2]= 30; */
  428. /* tmpExtensionObject.content.encoded.typeId = tmpNodeId; */
  429. /* UA_Variant tmpVariant; */
  430. /* UA_Variant_init(&tmpVariant); */
  431. /* tmpVariant.arrayDimensions = NULL; */
  432. /* tmpVariant.arrayDimensionsSize = -1; */
  433. /* tmpVariant.arrayLength = -1; */
  434. /* tmpVariant.storageType = UA_VARIANT_DATA_NODELETE; */
  435. /* tmpVariant.type = &UA_TYPES[UA_TYPES_EXTENSIONOBJECT]; */
  436. /* tmpVariant.data = &tmpExtensionObject; */
  437. /* UA_ByteString srcByteString = UA_ByteString_withSize(200); */
  438. /* pos = 0; */
  439. /* UA_Variant_encodeBinary(&tmpVariant,&srcByteString,&pos); */
  440. /* // when */
  441. /* pos = 0; */
  442. /* UA_StatusCode retval = UA_Variant_decodeBinary(&srcByteString, &pos, &dst); */
  443. /* // then */
  444. /* ck_assert_int_eq(retval, UA_STATUSCODE_GOOD); */
  445. /* // TODO!! */
  446. /* /\* ck_assert_int_eq(dst.encoding, UA_EXTENSIONOBJECT_DECODED); *\/ */
  447. /* /\* ck_assert_int_eq((uintptr_t)dst.content.decoded.type, (uintptr_t)&UA_TYPES[UA_TYPES_EXTENSIONOBJECT]); *\/ */
  448. /* /\* ck_assert_int_eq(dst.arrayLength, -1); *\/ */
  449. /* /\* ck_assert_int_eq(((UA_ExtensionObject *)dst.data)->body.data[0], 10); *\/ */
  450. /* /\* ck_assert_int_eq(((UA_ExtensionObject *)dst.data)->body.data[1], 20); *\/ */
  451. /* /\* ck_assert_int_eq(((UA_ExtensionObject *)dst.data)->body.data[2], 30); *\/ */
  452. /* /\* ck_assert_int_eq(((UA_ExtensionObject *)dst.data)->body.length, 3); *\/ */
  453. /* // finally */
  454. /* UA_Variant_deleteMembers(&dst); */
  455. /* UA_ByteString_deleteMembers(&srcByteString); */
  456. /* UA_ExtensionObject_deleteMembers(&tmpExtensionObject); */
  457. }
  458. END_TEST
  459. START_TEST(UA_Variant_decodeWithOutDeleteMembersShallFailInCheckMem) {
  460. // given
  461. size_t pos = 0;
  462. UA_Byte data[] = { UA_TYPES[UA_TYPES_INT32].typeId.identifier.numeric | UA_VARIANT_ENCODINGMASKTYPE_ARRAY,
  463. 0x02, 0x00, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF };
  464. UA_ByteString src = { 13, data };
  465. UA_Variant dst;
  466. // when
  467. UA_StatusCode retval = UA_Variant_decodeBinary(&src, &pos, &dst);
  468. // then
  469. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  470. // finally
  471. UA_Variant_deleteMembers(&dst);
  472. }
  473. END_TEST
  474. START_TEST(UA_Variant_decodeWithTooSmallSourceShallReturnWithError) {
  475. // given
  476. size_t pos = 0;
  477. UA_Byte data[] = { UA_TYPES[UA_TYPES_INT32].typeId.identifier.numeric | UA_VARIANT_ENCODINGMASKTYPE_ARRAY,
  478. 0x02, 0x00, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF };
  479. UA_ByteString src = { 4, data };
  480. UA_Variant dst;
  481. // when
  482. UA_StatusCode retval = UA_Variant_decodeBinary(&src, &pos, &dst);
  483. // then
  484. ck_assert_int_ne(retval, UA_STATUSCODE_GOOD);
  485. // finally
  486. UA_Variant_deleteMembers(&dst);
  487. }
  488. END_TEST
  489. START_TEST(UA_Byte_encode_test) {
  490. // given
  491. UA_Byte src;
  492. UA_Byte data[] = { 0x00, 0xFF };
  493. UA_ByteString dst = { 2, data };
  494. UA_Int32 retval = 0;
  495. size_t pos = 0;
  496. ck_assert_uint_eq(dst.data[1], 0xFF);
  497. src = 8;
  498. retval = UA_Byte_encodeBinary(&src, &dst, &pos);
  499. ck_assert_uint_eq(dst.data[0], 0x08);
  500. ck_assert_uint_eq(dst.data[1], 0xFF);
  501. ck_assert_int_eq(pos, 1);
  502. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  503. // Test2
  504. // given
  505. src = 0xFF;
  506. dst.data[1] = 0x00;
  507. pos = 0;
  508. retval = UA_Byte_encodeBinary(&src, &dst, &pos);
  509. ck_assert_int_eq(dst.data[0], 0xFF);
  510. ck_assert_int_eq(dst.data[1], 0x00);
  511. ck_assert_int_eq(pos, 1);
  512. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  513. }
  514. END_TEST
  515. START_TEST(UA_UInt16_encodeNegativeShallEncodeLittleEndian) {
  516. // given
  517. UA_UInt16 src;
  518. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55 };
  519. UA_ByteString dst = { 4, data };
  520. UA_StatusCode retval = 0;
  521. size_t pos = 0;
  522. // when test 1
  523. src = -1;
  524. retval = UA_UInt16_encodeBinary(&src, &dst, &pos);
  525. // then test 1
  526. ck_assert_int_eq(pos, 2);
  527. ck_assert_int_eq(dst.data[0], 0xFF);
  528. ck_assert_int_eq(dst.data[1], 0xFF);
  529. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  530. // when test 2
  531. src = -32768;
  532. retval = UA_UInt16_encodeBinary(&src, &dst, &pos);
  533. // then test 2
  534. ck_assert_int_eq(pos, 4);
  535. ck_assert_int_eq(dst.data[2], 0x00);
  536. ck_assert_int_eq(dst.data[3], 0x80);
  537. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  538. }
  539. END_TEST
  540. START_TEST(UA_UInt16_encodeShallEncodeLittleEndian) {
  541. // given
  542. UA_UInt16 src;
  543. UA_Byte data[] = { 0x55, 0x55,
  544. 0x55, 0x55 };
  545. UA_ByteString dst = { 4, data };
  546. UA_StatusCode retval = 0;
  547. size_t pos = 0;
  548. // when test 1
  549. src = 0;
  550. retval = UA_UInt16_encodeBinary(&src, &dst, &pos);
  551. // then test 1
  552. ck_assert_int_eq(pos, 2);
  553. ck_assert_int_eq(dst.data[0], 0x00);
  554. ck_assert_int_eq(dst.data[1], 0x00);
  555. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  556. // when test 2
  557. src = 32767;
  558. retval = UA_UInt16_encodeBinary(&src, &dst, &pos);
  559. // then test 2
  560. ck_assert_int_eq(pos, 4);
  561. ck_assert_int_eq(dst.data[2], 0xFF);
  562. ck_assert_int_eq(dst.data[3], 0x7F);
  563. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  564. }
  565. END_TEST
  566. START_TEST(UA_UInt32_encodeShallEncodeLittleEndian) {
  567. // given
  568. UA_UInt32 src;
  569. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  570. UA_ByteString dst = { 8, data };
  571. UA_StatusCode retval = 0;
  572. size_t pos = 0;
  573. // when test 1
  574. src = -1;
  575. retval = UA_UInt32_encodeBinary(&src, &dst, &pos);
  576. // then test 1
  577. ck_assert_int_eq(pos, 4);
  578. ck_assert_int_eq(dst.data[0], 0xFF);
  579. ck_assert_int_eq(dst.data[1], 0xFF);
  580. ck_assert_int_eq(dst.data[2], 0xFF);
  581. ck_assert_int_eq(dst.data[3], 0xFF);
  582. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  583. // when test 2
  584. src = 0x0101FF00;
  585. retval = UA_UInt32_encodeBinary(&src, &dst, &pos);
  586. // then test 2
  587. ck_assert_int_eq(pos, 8);
  588. ck_assert_int_eq(dst.data[4], 0x00);
  589. ck_assert_int_eq(dst.data[5], 0xFF);
  590. ck_assert_int_eq(dst.data[6], 0x01);
  591. ck_assert_int_eq(dst.data[7], 0x01);
  592. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  593. }
  594. END_TEST
  595. START_TEST(UA_Int32_encodeShallEncodeLittleEndian) {
  596. // given
  597. UA_Int32 src;
  598. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  599. UA_ByteString dst = { 8, data };
  600. UA_Int32 retval = 0;
  601. size_t pos = 0;
  602. // when test 1
  603. src = 1;
  604. retval = UA_Int32_encodeBinary(&src, &dst, &pos);
  605. // then test 1
  606. ck_assert_int_eq(pos, 4);
  607. ck_assert_int_eq(dst.data[0], 0x01);
  608. ck_assert_int_eq(dst.data[1], 0x00);
  609. ck_assert_int_eq(dst.data[2], 0x00);
  610. ck_assert_int_eq(dst.data[3], 0x00);
  611. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  612. // when test 2
  613. src = 0x7FFFFFFF;
  614. retval = UA_Int32_encodeBinary(&src, &dst, &pos);
  615. // then test 2
  616. ck_assert_int_eq(pos, 8);
  617. ck_assert_int_eq(dst.data[4], 0xFF);
  618. ck_assert_int_eq(dst.data[5], 0xFF);
  619. ck_assert_int_eq(dst.data[6], 0xFF);
  620. ck_assert_int_eq(dst.data[7], 0x7F);
  621. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  622. }
  623. END_TEST
  624. START_TEST(UA_Int32_encodeNegativeShallEncodeLittleEndian) {
  625. // given
  626. UA_Int32 src;
  627. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55,
  628. 0x55, 0x55, 0x55, 0x55 };
  629. UA_ByteString dst = { 8, data };
  630. UA_Int32 retval = 0;
  631. size_t pos = 0;
  632. // when test 1
  633. src = -1;
  634. retval = UA_Int32_encodeBinary(&src, &dst, &pos);
  635. // then test 1
  636. ck_assert_int_eq(pos, 4);
  637. ck_assert_int_eq(dst.data[0], 0xFF);
  638. ck_assert_int_eq(dst.data[1], 0xFF);
  639. ck_assert_int_eq(dst.data[2], 0xFF);
  640. ck_assert_int_eq(dst.data[3], 0xFF);
  641. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  642. }
  643. END_TEST
  644. START_TEST(UA_UInt64_encodeShallWorkOnExample) {
  645. // given
  646. UA_UInt64 src;
  647. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  648. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  649. UA_ByteString dst = { 16, data };
  650. UA_StatusCode retval = 0;
  651. size_t pos = 0;
  652. // when test 1
  653. src = -1;
  654. retval = UA_UInt64_encodeBinary(&src, &dst, &pos);
  655. // then test 1
  656. ck_assert_int_eq(pos, 8);
  657. ck_assert_int_eq(dst.data[0], 0xFF);
  658. ck_assert_int_eq(dst.data[1], 0xFF);
  659. ck_assert_int_eq(dst.data[2], 0xFF);
  660. ck_assert_int_eq(dst.data[3], 0xFF);
  661. ck_assert_int_eq(dst.data[4], 0xFF);
  662. ck_assert_int_eq(dst.data[5], 0xFF);
  663. ck_assert_int_eq(dst.data[6], 0xFF);
  664. ck_assert_int_eq(dst.data[7], 0xFF);
  665. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  666. // when test 2
  667. src = 0x7F0033AA44EE6611;
  668. retval = UA_UInt64_encodeBinary(&src, &dst, &pos);
  669. // then test 2
  670. ck_assert_int_eq(pos, 16);
  671. ck_assert_int_eq(dst.data[8], 0x11);
  672. ck_assert_int_eq(dst.data[9], 0x66);
  673. ck_assert_int_eq(dst.data[10], 0xEE);
  674. ck_assert_int_eq(dst.data[11], 0x44);
  675. ck_assert_int_eq(dst.data[12], 0xAA);
  676. ck_assert_int_eq(dst.data[13], 0x33);
  677. ck_assert_int_eq(dst.data[14], 0x00);
  678. ck_assert_int_eq(dst.data[15], 0x7F);
  679. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  680. }
  681. END_TEST
  682. START_TEST(UA_Int64_encodeShallEncodeLittleEndian) {
  683. // given
  684. UA_Int64 src;
  685. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  686. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  687. UA_ByteString dst = { 16, data };
  688. UA_Int32 retval = 0;
  689. size_t pos = 0;
  690. // when test 1
  691. src = 0x7F0033AA44EE6611;
  692. retval = UA_Int64_encodeBinary(&src, &dst, &pos);
  693. // then test 1
  694. ck_assert_int_eq(pos, 8);
  695. ck_assert_int_eq(dst.data[0], 0x11);
  696. ck_assert_int_eq(dst.data[1], 0x66);
  697. ck_assert_int_eq(dst.data[2], 0xEE);
  698. ck_assert_int_eq(dst.data[3], 0x44);
  699. ck_assert_int_eq(dst.data[4], 0xAA);
  700. ck_assert_int_eq(dst.data[5], 0x33);
  701. ck_assert_int_eq(dst.data[6], 0x00);
  702. ck_assert_int_eq(dst.data[7], 0x7F);
  703. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  704. }
  705. END_TEST
  706. START_TEST(UA_Int64_encodeNegativeShallEncodeLittleEndian) {
  707. // given
  708. UA_Int64 src;
  709. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  710. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  711. UA_ByteString dst = { 16, data };
  712. UA_Int32 retval = 0;
  713. size_t pos = 0;
  714. // when test 1
  715. src = -1;
  716. retval = UA_Int64_encodeBinary(&src, &dst, &pos);
  717. // then test 1
  718. ck_assert_int_eq(pos, 8);
  719. ck_assert_int_eq(dst.data[0], 0xFF);
  720. ck_assert_int_eq(dst.data[1], 0xFF);
  721. ck_assert_int_eq(dst.data[2], 0xFF);
  722. ck_assert_int_eq(dst.data[3], 0xFF);
  723. ck_assert_int_eq(dst.data[4], 0xFF);
  724. ck_assert_int_eq(dst.data[5], 0xFF);
  725. ck_assert_int_eq(dst.data[6], 0xFF);
  726. ck_assert_int_eq(dst.data[7], 0xFF);
  727. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  728. }
  729. END_TEST
  730. START_TEST(UA_Float_encodeShallWorkOnExample) {
  731. // given
  732. UA_Float src;
  733. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  734. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  735. UA_ByteString dst = { 16, data };
  736. UA_Int32 retval = 0;
  737. size_t pos = 0;
  738. // when test 1
  739. src = -6.5;
  740. retval = UA_Float_encodeBinary(&src, &dst, &pos);
  741. // then test 1
  742. ck_assert_int_eq(pos, 4);
  743. ck_assert_int_eq(dst.data[2], 0xD0);
  744. ck_assert_int_eq(dst.data[3], 0xC0);
  745. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  746. }
  747. END_TEST
  748. START_TEST(UA_Double_encodeShallWorkOnExample)
  749. {
  750. // given
  751. UA_Double src;
  752. UA_Byte data[] = { 0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
  753. 0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55
  754. };
  755. UA_ByteString dst = {16,data};
  756. UA_Int32 retval;
  757. size_t pos = 0;
  758. // when test 1
  759. src = -6.5;
  760. retval = UA_Double_encodeBinary(&src, &dst, &pos);
  761. // then test 1
  762. ck_assert_int_eq(pos, 8);
  763. ck_assert_int_eq(dst.data[6], 0x1A);
  764. ck_assert_int_eq(dst.data[7], 0xC0);
  765. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  766. }
  767. END_TEST
  768. START_TEST(UA_String_encodeShallWorkOnExample) {
  769. // given
  770. UA_String src;
  771. src.length = 11;
  772. UA_Byte mem[11] = "ACPLT OPCUA";
  773. src.data = mem;
  774. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  775. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  776. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  777. UA_ByteString dst = { 24, data };
  778. UA_Int32 retval = 0;
  779. size_t pos = 0;
  780. // when
  781. retval = UA_String_encodeBinary(&src, &dst, &pos);
  782. // then
  783. ck_assert_int_eq(pos, sizeof(UA_Int32)+11);
  784. ck_assert_uint_eq(pos, UA_calcSizeBinary(&src, &UA_TYPES[UA_TYPES_STRING]));
  785. ck_assert_int_eq(dst.data[0], 11);
  786. ck_assert_int_eq(dst.data[sizeof(UA_Int32)+0], 'A');
  787. ck_assert_int_eq(dst.data[sizeof(UA_Int32)+1], 'C');
  788. ck_assert_int_eq(dst.data[sizeof(UA_Int32)+2], 'P');
  789. ck_assert_int_eq(dst.data[sizeof(UA_Int32)+3], 'L');
  790. ck_assert_int_eq(dst.data[sizeof(UA_Int32)+4], 'T');
  791. ck_assert_int_eq(dst.data[sizeof(UA_Int32)+5], 0x20); //Space
  792. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  793. }
  794. END_TEST
  795. START_TEST(UA_ExpandedNodeId_encodeShallWorkOnExample) {
  796. // given
  797. UA_ExpandedNodeId src = UA_EXPANDEDNODEID_NUMERIC(0, 15);
  798. src.namespaceUri = UA_STRING("testUri");
  799. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  800. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  801. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  802. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  803. UA_ByteString dst = { 32, data };
  804. UA_Int32 retval = 0;
  805. size_t pos = 0;
  806. // when
  807. retval = UA_ExpandedNodeId_encodeBinary(&src, &dst, &pos);
  808. // then
  809. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  810. ck_assert_int_eq(pos, 13);
  811. ck_assert_uint_eq(pos, UA_calcSizeBinary(&src, &UA_TYPES[UA_TYPES_EXPANDEDNODEID]));
  812. ck_assert_int_eq(dst.data[0], 0x80); // namespaceuri flag
  813. }
  814. END_TEST
  815. START_TEST(UA_DataValue_encodeShallWorkOnExampleWithoutVariant) {
  816. // given
  817. UA_DataValue src;
  818. UA_DataValue_init(&src);
  819. src.serverTimestamp = 80;
  820. src.hasServerTimestamp = UA_TRUE;
  821. UA_Byte data[] = { 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  822. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55,
  823. 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55 };
  824. UA_ByteString dst = { 24, data };
  825. UA_Int32 retval = 0;
  826. size_t pos = 0;
  827. // when
  828. retval = UA_DataValue_encodeBinary(&src, &dst, &pos);
  829. // then
  830. ck_assert_int_eq(pos, 9); // represents the length
  831. ck_assert_uint_eq(pos, UA_calcSizeBinary(&src, &UA_TYPES[UA_TYPES_DATAVALUE]));
  832. ck_assert_int_eq(dst.data[0], 0x08); // encodingMask
  833. ck_assert_int_eq(dst.data[1], 80); // 8 Byte serverTimestamp
  834. ck_assert_int_eq(dst.data[2], 0);
  835. ck_assert_int_eq(dst.data[3], 0);
  836. ck_assert_int_eq(dst.data[4], 0);
  837. ck_assert_int_eq(dst.data[5], 0);
  838. ck_assert_int_eq(dst.data[6], 0);
  839. ck_assert_int_eq(dst.data[7], 0);
  840. ck_assert_int_eq(dst.data[8], 0);
  841. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  842. }
  843. END_TEST
  844. START_TEST(UA_DataValue_encodeShallWorkOnExampleWithVariant) {
  845. // given
  846. UA_DataValue src;
  847. UA_DataValue_init(&src);
  848. src.serverTimestamp = 80;
  849. src.hasValue = UA_TRUE;
  850. src.hasServerTimestamp = UA_TRUE;
  851. src.value.type = &UA_TYPES[UA_TYPES_INT32];
  852. src.value.arrayLength = 0; // one element (encoded as not an array)
  853. UA_Int32 vdata = 45;
  854. src.value.data = (void *)&vdata;
  855. UA_Byte data[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  856. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  857. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
  858. UA_ByteString dst = { 24, data };
  859. UA_Int32 retval = 0;
  860. size_t pos = 0;
  861. // when
  862. retval = UA_DataValue_encodeBinary(&src, &dst, &pos);
  863. // then
  864. ck_assert_int_eq(pos, 1+(1+4)+8); // represents the length
  865. ck_assert_uint_eq(pos, UA_calcSizeBinary(&src, &UA_TYPES[UA_TYPES_DATAVALUE]));
  866. ck_assert_int_eq(dst.data[0], 0x08 | 0x01); // encodingMask
  867. ck_assert_int_eq(dst.data[1], 0x06); // Variant's Encoding Mask - INT32
  868. ck_assert_int_eq(dst.data[2], 45); // the single value
  869. ck_assert_int_eq(dst.data[3], 0);
  870. ck_assert_int_eq(dst.data[4], 0);
  871. ck_assert_int_eq(dst.data[5], 0);
  872. ck_assert_int_eq(dst.data[6], 80); // the server timestamp
  873. ck_assert_int_eq(dst.data[7], 0);
  874. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  875. }
  876. END_TEST
  877. START_TEST(UA_DateTime_toStructShallWorkOnExample) {
  878. // given
  879. UA_DateTime src = 13974671891234567 + (11644473600 * 10000000); // ua counts since 1601, unix since 1970
  880. //1397467189... is Mon, 14 Apr 2014 09:19:49 GMT
  881. //...1234567 are the milli-, micro- and nanoseconds
  882. UA_DateTimeStruct dst;
  883. // when
  884. dst = UA_DateTime_toStruct(src);
  885. // then
  886. ck_assert_int_eq(dst.nanoSec, 700);
  887. ck_assert_int_eq(dst.microSec, 456);
  888. ck_assert_int_eq(dst.milliSec, 123);
  889. ck_assert_int_eq(dst.sec, 49);
  890. ck_assert_int_eq(dst.min, 19);
  891. ck_assert_int_eq(dst.hour, 9);
  892. ck_assert_int_eq(dst.day, 14);
  893. ck_assert_int_eq(dst.month, 4);
  894. ck_assert_int_eq(dst.year, 2014);
  895. }
  896. END_TEST
  897. START_TEST(UA_DateTime_toStringShallWorkOnExample) {
  898. // given
  899. UA_DateTime src = 13974671891234567 + (11644473600 * 10000000); // ua counts since 1601, unix since 1970
  900. //1397467189... is Mon, 14 Apr 2014 09:19:49 GMT
  901. //...1234567 are the milli-, micro- and nanoseconds
  902. UA_String dst;
  903. // when
  904. dst = UA_DateTime_toString(src);
  905. // then
  906. ck_assert_int_eq(dst.data[0], '0');
  907. ck_assert_int_eq(dst.data[1], '4');
  908. ck_assert_int_eq(dst.data[2], '/');
  909. ck_assert_int_eq(dst.data[3], '1');
  910. ck_assert_int_eq(dst.data[4], '4');
  911. UA_String_deleteMembers(&dst);
  912. }
  913. END_TEST
  914. START_TEST(UA_ExtensionObject_copyShallWorkOnExample) {
  915. // given
  916. /* UA_Byte data[3] = { 1, 2, 3 }; */
  917. /* UA_ExtensionObject value, valueCopied; */
  918. /* UA_ExtensionObject_init(&value); */
  919. /* UA_ExtensionObject_init(&valueCopied); */
  920. //Todo!!
  921. /* value.typeId = UA_TYPES[UA_TYPES_BYTE].typeId; */
  922. /* value.encoding = UA_EXTENSIONOBJECT_ENCODINGMASK_NOBODYISENCODED; */
  923. /* value.encoding = UA_EXTENSIONOBJECT_ENCODINGMASK_BODYISBYTESTRING; */
  924. /* value.body.data = data; */
  925. /* value.body.length = 3; */
  926. /* //when */
  927. /* UA_ExtensionObject_copy(&value, &valueCopied); */
  928. /* for(UA_Int32 i = 0;i < 3;i++) */
  929. /* ck_assert_int_eq(valueCopied.body.data[i], value.body.data[i]); */
  930. /* ck_assert_int_eq(valueCopied.encoding, value.encoding); */
  931. /* ck_assert_int_eq(valueCopied.typeId.identifierType, value.typeId.identifierType); */
  932. /* ck_assert_int_eq(valueCopied.typeId.identifier.numeric, value.typeId.identifier.numeric); */
  933. /* //finally */
  934. /* value.body.data = NULL; // we cannot free the static string */
  935. /* UA_ExtensionObject_deleteMembers(&value); */
  936. /* UA_ExtensionObject_deleteMembers(&valueCopied); */
  937. }
  938. END_TEST
  939. START_TEST(UA_Array_copyByteArrayShallWorkOnExample) {
  940. //given
  941. UA_String testString;
  942. UA_Byte *dstArray;
  943. UA_Int32 size = 5;
  944. UA_Int32 i = 0;
  945. testString.data = UA_malloc(size);
  946. testString.data[0] = 'O';
  947. testString.data[1] = 'P';
  948. testString.data[2] = 'C';
  949. testString.data[3] = 'U';
  950. testString.data[4] = 'A';
  951. testString.length = 5;
  952. //when
  953. UA_StatusCode retval;
  954. retval = UA_Array_copy((const void *)testString.data, 5, (void **)&dstArray, &UA_TYPES[UA_TYPES_BYTE]);
  955. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  956. //then
  957. for(i = 0;i < size;i++)
  958. ck_assert_int_eq(testString.data[i], dstArray[i]);
  959. //finally
  960. UA_String_deleteMembers(&testString);
  961. UA_free((void *)dstArray);
  962. }
  963. END_TEST
  964. START_TEST(UA_Array_copyUA_StringShallWorkOnExample) {
  965. // given
  966. UA_Int32 i, j;
  967. UA_String *srcArray = UA_Array_new(3, &UA_TYPES[UA_TYPES_STRING]);
  968. UA_String *dstArray;
  969. srcArray[0] = UA_STRING_ALLOC("open");
  970. srcArray[1] = UA_STRING_ALLOC("62541");
  971. srcArray[2] = UA_STRING_ALLOC("opc ua");
  972. //when
  973. UA_StatusCode retval;
  974. retval = UA_Array_copy((const void *)srcArray, 3, (void **)&dstArray, &UA_TYPES[UA_TYPES_STRING]);
  975. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  976. //then
  977. for(i = 0;i < 3;i++) {
  978. for(j = 0;j < 3;j++)
  979. ck_assert_int_eq(srcArray[i].data[j], dstArray[i].data[j]);
  980. ck_assert_int_eq(srcArray[i].length, dstArray[i].length);
  981. }
  982. //finally
  983. UA_Array_delete(srcArray, 3, &UA_TYPES[UA_TYPES_STRING]);
  984. UA_Array_delete(dstArray, 3, &UA_TYPES[UA_TYPES_STRING]);
  985. }
  986. END_TEST
  987. START_TEST(UA_DiagnosticInfo_copyShallWorkOnExample) {
  988. //given
  989. UA_DiagnosticInfo value, innerValue, copiedValue;
  990. UA_String testString = (UA_String){5, (UA_Byte*)"OPCUA"};
  991. UA_DiagnosticInfo_init(&value);
  992. UA_DiagnosticInfo_init(&innerValue);
  993. value.hasInnerDiagnosticInfo = UA_TRUE;
  994. value.innerDiagnosticInfo = &innerValue;
  995. value.hasAdditionalInfo = UA_TRUE;
  996. value.additionalInfo = testString;
  997. //when
  998. UA_DiagnosticInfo_copy(&value, &copiedValue);
  999. //then
  1000. for(size_t i = 0;i < testString.length;i++)
  1001. ck_assert_int_eq(copiedValue.additionalInfo.data[i], value.additionalInfo.data[i]);
  1002. ck_assert_int_eq(copiedValue.additionalInfo.length, value.additionalInfo.length);
  1003. ck_assert_int_eq(copiedValue.hasInnerDiagnosticInfo, value.hasInnerDiagnosticInfo);
  1004. ck_assert_int_eq(copiedValue.innerDiagnosticInfo->locale, value.innerDiagnosticInfo->locale);
  1005. ck_assert_int_eq(copiedValue.innerStatusCode, value.innerStatusCode);
  1006. ck_assert_int_eq(copiedValue.locale, value.locale);
  1007. ck_assert_int_eq(copiedValue.localizedText, value.localizedText);
  1008. ck_assert_int_eq(copiedValue.namespaceUri, value.namespaceUri);
  1009. ck_assert_int_eq(copiedValue.symbolicId, value.symbolicId);
  1010. //finally
  1011. value.additionalInfo.data = NULL; // do not delete the static string
  1012. value.innerDiagnosticInfo = NULL; // do not delete the static innerdiagnosticinfo
  1013. UA_DiagnosticInfo_deleteMembers(&value);
  1014. UA_DiagnosticInfo_deleteMembers(&copiedValue);
  1015. }
  1016. END_TEST
  1017. START_TEST(UA_ApplicationDescription_copyShallWorkOnExample) {
  1018. //given
  1019. UA_StatusCode retval = UA_STATUSCODE_GOOD;
  1020. UA_String appString = (UA_String){3, (UA_Byte*)"APP"};
  1021. UA_String discString = (UA_String){4, (UA_Byte*)"DISC"};
  1022. UA_String gateWayString = (UA_String){7, (UA_Byte*)"GATEWAY"};
  1023. UA_String srcArray[3];
  1024. srcArray[0] = (UA_String){ 6, (UA_Byte*)"__open" };
  1025. srcArray[1] = (UA_String){ 6, (UA_Byte*)"_62541" };
  1026. srcArray[2] = (UA_String){ 6, (UA_Byte*)"opc ua" };
  1027. UA_ApplicationDescription value, copiedValue;
  1028. UA_ApplicationDescription_init(&value);
  1029. value.applicationUri = appString;
  1030. value.discoveryProfileUri = discString;
  1031. value.gatewayServerUri = gateWayString;
  1032. value.discoveryUrlsSize = 3;
  1033. value.discoveryUrls = srcArray;
  1034. //when
  1035. retval = UA_ApplicationDescription_copy(&value, &copiedValue);
  1036. //then
  1037. ck_assert_int_eq(retval, UA_STATUSCODE_GOOD);
  1038. for(size_t i = 0; i < appString.length; i++)
  1039. ck_assert_int_eq(copiedValue.applicationUri.data[i], value.applicationUri.data[i]);
  1040. ck_assert_int_eq(copiedValue.applicationUri.length, value.applicationUri.length);
  1041. for(size_t i = 0; i < discString.length; i++)
  1042. ck_assert_int_eq(copiedValue.discoveryProfileUri.data[i], value.discoveryProfileUri.data[i]);
  1043. ck_assert_int_eq(copiedValue.discoveryProfileUri.length, value.discoveryProfileUri.length);
  1044. for(size_t i = 0; i < gateWayString.length; i++)
  1045. ck_assert_int_eq(copiedValue.gatewayServerUri.data[i], value.gatewayServerUri.data[i]);
  1046. ck_assert_int_eq(copiedValue.gatewayServerUri.length, value.gatewayServerUri.length);
  1047. //String Array Test
  1048. for(UA_Int32 i = 0;i < 3;i++) {
  1049. for(UA_Int32 j = 0;j < 6;j++)
  1050. ck_assert_int_eq(value.discoveryUrls[i].data[j], copiedValue.discoveryUrls[i].data[j]);
  1051. ck_assert_int_eq(value.discoveryUrls[i].length, copiedValue.discoveryUrls[i].length);
  1052. }
  1053. ck_assert_int_eq(copiedValue.discoveryUrls[0].data[2], 'o');
  1054. ck_assert_int_eq(copiedValue.discoveryUrls[0].data[3], 'p');
  1055. ck_assert_int_eq(copiedValue.discoveryUrlsSize, value.discoveryUrlsSize);
  1056. //finally
  1057. // UA_ApplicationDescription_deleteMembers(&value); // do not free the members as they are statically allocated
  1058. UA_ApplicationDescription_deleteMembers(&copiedValue);
  1059. }
  1060. END_TEST
  1061. START_TEST(UA_QualifiedName_copyShallWorkOnInputExample) {
  1062. // given
  1063. UA_String srcName = (UA_String){8, (UA_Byte*)"tEsT123!"};
  1064. UA_QualifiedName src = {5, srcName};
  1065. UA_QualifiedName dst;
  1066. // when
  1067. UA_StatusCode ret = UA_QualifiedName_copy(&src, &dst);
  1068. // then
  1069. ck_assert_int_eq(ret, UA_STATUSCODE_GOOD);
  1070. ck_assert_int_eq('E', dst.name.data[1]);
  1071. ck_assert_int_eq('!', dst.name.data[7]);
  1072. ck_assert_int_eq(8, dst.name.length);
  1073. ck_assert_int_eq(5, dst.namespaceIndex);
  1074. // finally
  1075. UA_QualifiedName_deleteMembers(&dst);
  1076. }
  1077. END_TEST
  1078. START_TEST(UA_Guid_copyShallWorkOnInputExample) {
  1079. //given
  1080. const UA_Guid src = {3, 45, 1222, {8, 7, 6, 5, 4, 3, 2, 1}};
  1081. UA_Guid dst;
  1082. //when
  1083. UA_StatusCode ret = UA_Guid_copy(&src, &dst);
  1084. //then
  1085. ck_assert_int_eq(ret, UA_STATUSCODE_GOOD);
  1086. ck_assert_int_eq(src.data1, dst.data1);
  1087. ck_assert_int_eq(src.data3, dst.data3);
  1088. ck_assert_int_eq(src.data4[4], dst.data4[4]);
  1089. //finally
  1090. }
  1091. END_TEST
  1092. START_TEST(UA_LocalizedText_copycstringShallWorkOnInputExample) {
  1093. // given
  1094. char src[8] = {'t', 'e', 'X', 't', '1', '2', '3', (char)0};
  1095. const UA_LocalizedText dst = UA_LOCALIZEDTEXT("", src);
  1096. // then
  1097. ck_assert_int_eq('1', dst.text.data[4]);
  1098. ck_assert_int_eq(0, dst.locale.length);
  1099. ck_assert_int_eq(7, dst.text.length);
  1100. }
  1101. END_TEST
  1102. START_TEST(UA_DataValue_copyShallWorkOnInputExample) {
  1103. // given
  1104. UA_Variant srcVariant;
  1105. UA_Variant_init(&srcVariant);
  1106. UA_DataValue src;
  1107. UA_DataValue_init(&src);
  1108. src.hasSourceTimestamp = UA_TRUE;
  1109. src.sourceTimestamp = 4;
  1110. src.hasSourcePicoseconds = UA_TRUE;
  1111. src.sourcePicoseconds = 77;
  1112. src.hasServerPicoseconds = UA_TRUE;
  1113. src.serverPicoseconds = 8;
  1114. UA_DataValue dst;
  1115. // when
  1116. UA_StatusCode ret = UA_DataValue_copy(&src, &dst);
  1117. // then
  1118. ck_assert_int_eq(ret, UA_STATUSCODE_GOOD);
  1119. ck_assert_int_eq(4, dst.sourceTimestamp);
  1120. ck_assert_int_eq(77, dst.sourcePicoseconds);
  1121. ck_assert_int_eq(8, dst.serverPicoseconds);
  1122. }
  1123. END_TEST
  1124. START_TEST(UA_Variant_copyShallWorkOnSingleValueExample) {
  1125. //given
  1126. UA_String testString = (UA_String){5, (UA_Byte*)"OPCUA"};
  1127. UA_Variant value, copiedValue;
  1128. UA_Variant_init(&value);
  1129. UA_Variant_init(&copiedValue);
  1130. value.data = UA_malloc(sizeof(UA_String));
  1131. *((UA_String*)value.data) = testString;
  1132. value.type = &UA_TYPES[UA_TYPES_STRING];
  1133. value.arrayLength = 1;
  1134. //when
  1135. UA_Variant_copy(&value, &copiedValue);
  1136. //then
  1137. UA_String copiedString = *(UA_String*)(copiedValue.data);
  1138. for(UA_Int32 i = 0;i < 5;i++)
  1139. ck_assert_int_eq(copiedString.data[i], testString.data[i]);
  1140. ck_assert_int_eq(copiedString.length, testString.length);
  1141. ck_assert_int_eq(value.arrayDimensionsSize, copiedValue.arrayDimensionsSize);
  1142. ck_assert_int_eq(value.arrayLength, copiedValue.arrayLength);
  1143. //finally
  1144. ((UA_String*)value.data)->data = NULL; // the string is statically allocated. do not free it.
  1145. UA_Variant_deleteMembers(&value);
  1146. UA_Variant_deleteMembers(&copiedValue);
  1147. }
  1148. END_TEST
  1149. START_TEST(UA_Variant_copyShallWorkOn1DArrayExample) {
  1150. // given
  1151. UA_String *srcArray = UA_Array_new(3, &UA_TYPES[UA_TYPES_STRING]);
  1152. srcArray[0] = UA_STRING_ALLOC("__open");
  1153. srcArray[1] = UA_STRING_ALLOC("_62541");
  1154. srcArray[2] = UA_STRING_ALLOC("opc ua");
  1155. UA_UInt32 *dimensions;
  1156. dimensions = UA_malloc(sizeof(UA_UInt32));
  1157. dimensions[0] = 3;
  1158. UA_Variant value, copiedValue;
  1159. UA_Variant_init(&value);
  1160. UA_Variant_init(&copiedValue);
  1161. value.arrayLength = 3;
  1162. value.data = (void *)srcArray;
  1163. value.arrayDimensionsSize = 1;
  1164. value.arrayDimensions = dimensions;
  1165. value.type = &UA_TYPES[UA_TYPES_STRING];
  1166. //when
  1167. UA_Variant_copy(&value, &copiedValue);
  1168. //then
  1169. UA_Int32 i1 = value.arrayDimensions[0];
  1170. UA_Int32 i2 = copiedValue.arrayDimensions[0];
  1171. ck_assert_int_eq(i1, i2);
  1172. for(UA_Int32 i = 0;i < 3;i++) {
  1173. for(UA_Int32 j = 0;j < 6;j++) {
  1174. ck_assert_int_eq(((UA_String *)value.data)[i].data[j],
  1175. ((UA_String *)copiedValue.data)[i].data[j]);
  1176. }
  1177. ck_assert_int_eq(((UA_String *)value.data)[i].length,
  1178. ((UA_String *)copiedValue.data)[i].length);
  1179. }
  1180. ck_assert_int_eq(((UA_String *)copiedValue.data)[0].data[2], 'o');
  1181. ck_assert_int_eq(((UA_String *)copiedValue.data)[0].data[3], 'p');
  1182. ck_assert_int_eq(value.arrayDimensionsSize, copiedValue.arrayDimensionsSize);
  1183. ck_assert_int_eq(value.arrayLength, copiedValue.arrayLength);
  1184. //finally
  1185. UA_Variant_deleteMembers(&value);
  1186. UA_Variant_deleteMembers(&copiedValue);
  1187. }
  1188. END_TEST
  1189. START_TEST(UA_Variant_copyShallWorkOn2DArrayExample) {
  1190. // given
  1191. UA_Int32 *srcArray = UA_Array_new(6, &UA_TYPES[UA_TYPES_INT32]);
  1192. srcArray[0] = 0;
  1193. srcArray[1] = 1;
  1194. srcArray[2] = 2;
  1195. srcArray[3] = 3;
  1196. srcArray[4] = 4;
  1197. srcArray[5] = 5;
  1198. UA_UInt32 *dimensions = UA_Array_new(2, &UA_TYPES[UA_TYPES_UINT32]);
  1199. UA_Int32 dim1 = 3;
  1200. UA_Int32 dim2 = 2;
  1201. dimensions[0] = dim1;
  1202. dimensions[1] = dim2;
  1203. UA_Variant value, copiedValue;
  1204. UA_Variant_init(&value);
  1205. UA_Variant_init(&copiedValue);
  1206. value.arrayLength = 6;
  1207. value.data = srcArray;
  1208. value.arrayDimensionsSize = 2;
  1209. value.arrayDimensions = dimensions;
  1210. value.type = &UA_TYPES[UA_TYPES_INT32];
  1211. //when
  1212. UA_Variant_copy(&value, &copiedValue);
  1213. //then
  1214. //1st dimension
  1215. UA_Int32 i1 = value.arrayDimensions[0];
  1216. UA_Int32 i2 = copiedValue.arrayDimensions[0];
  1217. ck_assert_int_eq(i1, i2);
  1218. ck_assert_int_eq(i1, dim1);
  1219. //2nd dimension
  1220. i1 = value.arrayDimensions[1];
  1221. i2 = copiedValue.arrayDimensions[1];
  1222. ck_assert_int_eq(i1, i2);
  1223. ck_assert_int_eq(i1, dim2);
  1224. for(UA_Int32 i = 0;i < 6;i++) {
  1225. i1 = ((UA_Int32 *)value.data)[i];
  1226. i2 = ((UA_Int32 *)copiedValue.data)[i];
  1227. ck_assert_int_eq(i1, i2);
  1228. ck_assert_int_eq(i2, i);
  1229. }
  1230. ck_assert_int_eq(value.arrayDimensionsSize, copiedValue.arrayDimensionsSize);
  1231. ck_assert_int_eq(value.arrayLength, copiedValue.arrayLength);
  1232. //finally
  1233. UA_Variant_deleteMembers(&value);
  1234. UA_Variant_deleteMembers(&copiedValue);
  1235. }
  1236. END_TEST
  1237. START_TEST(UA_ExtensionObject_encodeDecodeShallWorkOnExtensionObject) {
  1238. /* UA_Int32 val = 42; */
  1239. /* UA_VariableAttributes varAttr; */
  1240. /* UA_VariableAttributes_init(&varAttr); */
  1241. /* varAttr.dataType = UA_TYPES[UA_TYPES_INT32].typeId; */
  1242. /* UA_Variant_init(&varAttr.value); */
  1243. /* varAttr.value.type = &UA_TYPES[UA_TYPES_INT32]; */
  1244. /* varAttr.value.data = &val; */
  1245. /* varAttr.value.arrayLength = -1; */
  1246. /* varAttr.userWriteMask = 41; */
  1247. /* varAttr.specifiedAttributes |= UA_NODEATTRIBUTESMASK_DATATYPE; */
  1248. /* varAttr.specifiedAttributes |= UA_NODEATTRIBUTESMASK_VALUE; */
  1249. /* varAttr.specifiedAttributes |= UA_NODEATTRIBUTESMASK_USERWRITEMASK; */
  1250. /* /\* wrap it into a extension object attributes *\/ */
  1251. /* UA_ExtensionObject extensionObject; */
  1252. /* UA_ExtensionObject_init(&extensionObject); */
  1253. /* extensionObject.typeId = UA_TYPES[UA_TYPES_VARIABLEATTRIBUTES].typeId; */
  1254. /* UA_Byte extensionData[50]; */
  1255. /* extensionObject.body = (UA_ByteString){.data = extensionData, .length=50}; */
  1256. /* size_t posEncode = 0; */
  1257. /* UA_VariableAttributes_encodeBinary(&varAttr, &extensionObject.body, &posEncode); */
  1258. /* extensionObject.body.length = posEncode; */
  1259. /* extensionObject.encoding = UA_EXTENSIONOBJECT_ENCODINGMASK_BODYISBYTESTRING; */
  1260. /* UA_Byte data[50]; */
  1261. /* UA_ByteString dst = {.data = data, .length=50}; */
  1262. /* posEncode = 0; */
  1263. /* UA_ExtensionObject_encodeBinary(&extensionObject, &dst, &posEncode); */
  1264. /* UA_ExtensionObject extensionObjectDecoded; */
  1265. /* size_t posDecode = 0; */
  1266. /* UA_ExtensionObject_decodeBinary(&dst, &posDecode, &extensionObjectDecoded); */
  1267. /* ck_assert_int_eq(posEncode, posDecode); */
  1268. /* ck_assert_int_eq(extensionObjectDecoded.body.length, extensionObject.body.length); */
  1269. /* UA_VariableAttributes varAttrDecoded; */
  1270. /* UA_VariableAttributes_init(&varAttrDecoded); */
  1271. /* posDecode = 0; */
  1272. /* UA_VariableAttributes_decodeBinary(&extensionObjectDecoded.body, &posDecode, &varAttrDecoded); */
  1273. /* ck_assert_uint_eq(41, varAttrDecoded.userWriteMask); */
  1274. /* ck_assert_int_eq(-1, varAttrDecoded.value.arrayLength); */
  1275. /* // finally */
  1276. /* UA_ExtensionObject_deleteMembers(&extensionObjectDecoded); */
  1277. /* UA_Variant_deleteMembers(&varAttrDecoded.value); */
  1278. }
  1279. END_TEST
  1280. static Suite *testSuite_builtin(void) {
  1281. Suite *s = suite_create("Built-in Data Types 62541-6 Table 1");
  1282. TCase *tc_decode = tcase_create("decode");
  1283. tcase_add_test(tc_decode, UA_Byte_decodeShallCopyAndAdvancePosition);
  1284. tcase_add_test(tc_decode, UA_Byte_decodeShallModifyOnlyCurrentPosition);
  1285. tcase_add_test(tc_decode, UA_Int16_decodeShallAssumeLittleEndian);
  1286. tcase_add_test(tc_decode, UA_Int16_decodeShallRespectSign);
  1287. tcase_add_test(tc_decode, UA_UInt16_decodeShallNotRespectSign);
  1288. tcase_add_test(tc_decode, UA_Int32_decodeShallAssumeLittleEndian);
  1289. tcase_add_test(tc_decode, UA_Int32_decodeShallRespectSign);
  1290. tcase_add_test(tc_decode, UA_UInt32_decodeShallNotRespectSign);
  1291. tcase_add_test(tc_decode, UA_UInt64_decodeShallNotRespectSign);
  1292. tcase_add_test(tc_decode, UA_Int64_decodeShallRespectSign);
  1293. tcase_add_test(tc_decode, UA_Float_decodeShallWorkOnExample);
  1294. tcase_add_test(tc_decode, UA_Double_decodeShallGiveOne);
  1295. tcase_add_test(tc_decode, UA_Double_decodeShallGiveZero);
  1296. tcase_add_test(tc_decode, UA_Double_decodeShallGiveMinusTwo);
  1297. tcase_add_test(tc_decode, UA_Double_decodeShallGive2147483648);
  1298. tcase_add_test(tc_decode, UA_Byte_encode_test);
  1299. tcase_add_test(tc_decode, UA_String_decodeShallAllocateMemoryAndCopyString);
  1300. tcase_add_test(tc_decode, UA_String_decodeWithNegativeSizeShallNotAllocateMemoryAndNullPtr);
  1301. tcase_add_test(tc_decode, UA_String_decodeWithZeroSizeShallNotAllocateMemoryAndNullPtr);
  1302. tcase_add_test(tc_decode, UA_NodeId_decodeTwoByteShallReadTwoBytesAndSetNamespaceToZero);
  1303. tcase_add_test(tc_decode, UA_NodeId_decodeFourByteShallReadFourBytesAndRespectNamespace);
  1304. tcase_add_test(tc_decode, UA_NodeId_decodeStringShallAllocateMemory);
  1305. tcase_add_test(tc_decode, UA_Variant_decodeSingleExtensionObjectShallSetVTAndAllocateMemory);
  1306. tcase_add_test(tc_decode, UA_Variant_decodeWithOutArrayFlagSetShallSetVTAndAllocateMemoryForArray);
  1307. tcase_add_test(tc_decode, UA_Variant_decodeWithArrayFlagSetShallSetVTAndAllocateMemoryForArray);
  1308. tcase_add_test(tc_decode, UA_Variant_decodeWithOutDeleteMembersShallFailInCheckMem);
  1309. tcase_add_test(tc_decode, UA_Variant_decodeWithTooSmallSourceShallReturnWithError);
  1310. suite_add_tcase(s, tc_decode);
  1311. TCase *tc_encode = tcase_create("encode");
  1312. tcase_add_test(tc_encode, UA_Byte_encode_test);
  1313. tcase_add_test(tc_encode, UA_UInt16_encodeNegativeShallEncodeLittleEndian);
  1314. tcase_add_test(tc_encode, UA_UInt16_encodeShallEncodeLittleEndian);
  1315. tcase_add_test(tc_encode, UA_UInt32_encodeShallEncodeLittleEndian);
  1316. tcase_add_test(tc_encode, UA_Int32_encodeShallEncodeLittleEndian);
  1317. tcase_add_test(tc_encode, UA_Int32_encodeNegativeShallEncodeLittleEndian);
  1318. tcase_add_test(tc_encode, UA_UInt64_encodeShallWorkOnExample);
  1319. tcase_add_test(tc_encode, UA_Int64_encodeNegativeShallEncodeLittleEndian);
  1320. tcase_add_test(tc_encode, UA_Int64_encodeShallEncodeLittleEndian);
  1321. tcase_add_test(tc_encode, UA_Float_encodeShallWorkOnExample);
  1322. tcase_add_test(tc_encode, UA_Double_encodeShallWorkOnExample);
  1323. tcase_add_test(tc_encode, UA_String_encodeShallWorkOnExample);
  1324. tcase_add_test(tc_encode, UA_ExpandedNodeId_encodeShallWorkOnExample);
  1325. tcase_add_test(tc_encode, UA_DataValue_encodeShallWorkOnExampleWithoutVariant);
  1326. tcase_add_test(tc_encode, UA_DataValue_encodeShallWorkOnExampleWithVariant);
  1327. tcase_add_test(tc_encode, UA_ExtensionObject_encodeDecodeShallWorkOnExtensionObject);
  1328. suite_add_tcase(s, tc_encode);
  1329. TCase *tc_convert = tcase_create("convert");
  1330. tcase_add_test(tc_convert, UA_DateTime_toStructShallWorkOnExample);
  1331. tcase_add_test(tc_convert, UA_DateTime_toStringShallWorkOnExample);
  1332. suite_add_tcase(s, tc_convert);
  1333. TCase *tc_copy = tcase_create("copy");
  1334. tcase_add_test(tc_copy, UA_Array_copyByteArrayShallWorkOnExample);
  1335. tcase_add_test(tc_copy, UA_Array_copyUA_StringShallWorkOnExample);
  1336. tcase_add_test(tc_copy, UA_ExtensionObject_copyShallWorkOnExample);
  1337. tcase_add_test(tc_copy, UA_Variant_copyShallWorkOnSingleValueExample);
  1338. tcase_add_test(tc_copy, UA_Variant_copyShallWorkOn1DArrayExample);
  1339. tcase_add_test(tc_copy, UA_Variant_copyShallWorkOn2DArrayExample);
  1340. tcase_add_test(tc_copy, UA_DiagnosticInfo_copyShallWorkOnExample);
  1341. tcase_add_test(tc_copy, UA_ApplicationDescription_copyShallWorkOnExample);
  1342. tcase_add_test(tc_copy, UA_QualifiedName_copyShallWorkOnInputExample);
  1343. tcase_add_test(tc_copy, UA_Guid_copyShallWorkOnInputExample);
  1344. tcase_add_test(tc_copy, UA_LocalizedText_copycstringShallWorkOnInputExample);
  1345. tcase_add_test(tc_copy, UA_DataValue_copyShallWorkOnInputExample);
  1346. suite_add_tcase(s, tc_copy);
  1347. return s;
  1348. }
  1349. int main(void) {
  1350. int number_failed = 0;
  1351. Suite *s;
  1352. SRunner *sr;
  1353. s = testSuite_builtin();
  1354. sr = srunner_create(s);
  1355. srunner_set_fork_status(sr, CK_NOFORK);
  1356. srunner_run_all(sr, CK_NORMAL);
  1357. number_failed += srunner_ntests_failed(sr);
  1358. srunner_free(sr);
  1359. return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
  1360. }