check_types_builtin.c 55 KB

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