check_builtin.c 56 KB

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