testautomation_sdltest.c 61 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299
  1. /**
  2. * SDL_test test suite
  3. */
  4. #include <limits.h>
  5. #include <float.h>
  6. #include <SDL3/SDL.h>
  7. #include <SDL3/SDL_test.h>
  8. #include "testautomation_suites.h"
  9. /* Test case functions */
  10. /**
  11. * Calls to SDLTest_GenerateRunSeed()
  12. */
  13. static int sdltest_generateRunSeed(void *arg)
  14. {
  15. char *result;
  16. size_t i, l;
  17. int j;
  18. for (i = 1; i <= 10; i += 3) {
  19. result = SDLTest_GenerateRunSeed((int)i);
  20. SDLTest_AssertPass("Call to SDLTest_GenerateRunSeed()");
  21. SDLTest_AssertCheck(result != NULL, "Verify returned value is not NULL");
  22. if (result != NULL) {
  23. l = SDL_strlen(result);
  24. SDLTest_AssertCheck(l == i, "Verify length of returned value is %d, got: %d", (int)i, (int)l);
  25. SDL_free(result);
  26. }
  27. }
  28. /* Negative cases */
  29. for (j = -2; j <= 0; j++) {
  30. result = SDLTest_GenerateRunSeed(j);
  31. SDLTest_AssertPass("Call to SDLTest_GenerateRunSeed()");
  32. SDLTest_AssertCheck(result == NULL, "Verify returned value is not NULL");
  33. }
  34. return TEST_COMPLETED;
  35. }
  36. /**
  37. * Calls to SDLTest_GetFuzzerInvocationCount()
  38. */
  39. static int sdltest_getFuzzerInvocationCount(void *arg)
  40. {
  41. Uint8 result;
  42. int fuzzerCount1, fuzzerCount2;
  43. fuzzerCount1 = SDLTest_GetFuzzerInvocationCount();
  44. SDLTest_AssertPass("Call to SDLTest_GetFuzzerInvocationCount()");
  45. SDLTest_AssertCheck(fuzzerCount1 >= 0, "Verify returned value, expected: >=0, got: %d", fuzzerCount1);
  46. result = SDLTest_RandomUint8();
  47. SDLTest_AssertPass("Call to SDLTest_RandomUint8(), returned %d", result);
  48. fuzzerCount2 = SDLTest_GetFuzzerInvocationCount();
  49. SDLTest_AssertPass("Call to SDLTest_GetFuzzerInvocationCount()");
  50. SDLTest_AssertCheck(fuzzerCount2 > fuzzerCount1, "Verify returned value, expected: >%d, got: %d", fuzzerCount1, fuzzerCount2);
  51. return TEST_COMPLETED;
  52. }
  53. /**
  54. * Calls to random number generators
  55. */
  56. static int sdltest_randomNumber(void *arg)
  57. {
  58. Sint64 result;
  59. double dresult;
  60. Uint64 umax;
  61. Sint64 min, max;
  62. result = (Sint64)SDLTest_RandomUint8();
  63. umax = (1 << 8) - 1;
  64. SDLTest_AssertPass("Call to SDLTest_RandomUint8");
  65. SDLTest_AssertCheck(result >= 0 && result <= (Sint64)umax, "Verify result value, expected: [0,%" SDL_PRIu64 "], got: %" SDL_PRIs64, umax, result);
  66. result = (Sint64)SDLTest_RandomSint8();
  67. min = 0 - (1 << 7);
  68. max = (1 << 7) - 1;
  69. SDLTest_AssertPass("Call to SDLTest_RandomSint8");
  70. SDLTest_AssertCheck(result >= min && result <= max, "Verify result value, expected: [%" SDL_PRIs64 ",%" SDL_PRIs64 "], got: %" SDL_PRIs64, min, max, result);
  71. result = (Sint64)SDLTest_RandomUint16();
  72. umax = (1 << 16) - 1;
  73. SDLTest_AssertPass("Call to SDLTest_RandomUint16");
  74. SDLTest_AssertCheck(result >= 0 && result <= (Sint64)umax, "Verify result value, expected: [0,%" SDL_PRIu64 "], got: %" SDL_PRIs64, umax, result);
  75. result = (Sint64)SDLTest_RandomSint16();
  76. min = 0 - (1 << 15);
  77. max = (1 << 15) - 1;
  78. SDLTest_AssertPass("Call to SDLTest_RandomSint16");
  79. SDLTest_AssertCheck(result >= min && result <= max, "Verify result value, expected: [%" SDL_PRIs64 ",%" SDL_PRIs64 "], got: %" SDL_PRIs64, min, max, result);
  80. result = (Sint64)SDLTest_RandomUint32();
  81. umax = ((Uint64)1 << 32) - 1;
  82. SDLTest_AssertPass("Call to SDLTest_RandomUint32");
  83. SDLTest_AssertCheck(result >= 0 && result <= (Sint64)umax, "Verify result value, expected: [0,%" SDL_PRIu64 "], got: %" SDL_PRIs64, umax, result);
  84. result = (Sint64)SDLTest_RandomSint32();
  85. min = 0 - ((Sint64)1 << 31);
  86. max = ((Sint64)1 << 31) - 1;
  87. SDLTest_AssertPass("Call to SDLTest_RandomSint32");
  88. SDLTest_AssertCheck(result >= min && result <= max, "Verify result value, expected: [%" SDL_PRIs64 ",%" SDL_PRIs64 "], got: %" SDL_PRIs64, min, max, result);
  89. SDLTest_RandomUint64();
  90. SDLTest_AssertPass("Call to SDLTest_RandomUint64");
  91. result = SDLTest_RandomSint64();
  92. SDLTest_AssertPass("Call to SDLTest_RandomSint64");
  93. dresult = (double)SDLTest_RandomUnitFloat();
  94. SDLTest_AssertPass("Call to SDLTest_RandomUnitFloat");
  95. SDLTest_AssertCheck(dresult >= 0.0 && dresult < 1.0, "Verify result value, expected: [0.0,1.0[, got: %e", dresult);
  96. dresult = (double)SDLTest_RandomFloat();
  97. SDLTest_AssertPass("Call to SDLTest_RandomFloat");
  98. SDLTest_AssertCheck(dresult >= (double)(-FLT_MAX) && dresult <= (double)FLT_MAX, "Verify result value, expected: [%e,%e], got: %e", (double)(-FLT_MAX), (double)FLT_MAX, dresult);
  99. dresult = SDLTest_RandomUnitDouble();
  100. SDLTest_AssertPass("Call to SDLTest_RandomUnitDouble");
  101. SDLTest_AssertCheck(dresult >= 0.0 && dresult < 1.0, "Verify result value, expected: [0.0,1.0[, got: %e", dresult);
  102. dresult = SDLTest_RandomDouble();
  103. SDLTest_AssertPass("Call to SDLTest_RandomDouble");
  104. return TEST_COMPLETED;
  105. }
  106. /**
  107. * Calls to random boundary number generators for Uint8
  108. */
  109. static int sdltest_randomBoundaryNumberUint8(void *arg)
  110. {
  111. const char *expectedError = "That operation is not supported";
  112. const char *lastError;
  113. Uint64 uresult;
  114. /* Clean error messages */
  115. SDL_ClearError();
  116. SDLTest_AssertPass("SDL_ClearError()");
  117. /* RandomUintXBoundaryValue(10, 10, SDL_TRUE) returns 10 */
  118. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(10, 10, SDL_TRUE);
  119. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  120. SDLTest_AssertCheck(
  121. uresult == 10,
  122. "Validate result value for parameters (10,10,SDL_TRUE); expected: 10, got: %" SDL_PRIs64, uresult);
  123. /* RandomUintXBoundaryValue(10, 11, SDL_TRUE) returns 10, 11 */
  124. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(10, 11, SDL_TRUE);
  125. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  126. SDLTest_AssertCheck(
  127. uresult == 10 || uresult == 11,
  128. "Validate result value for parameters (10,11,SDL_TRUE); expected: 10|11, got: %" SDL_PRIs64, uresult);
  129. /* RandomUintXBoundaryValue(10, 12, SDL_TRUE) returns 10, 11, 12 */
  130. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(10, 12, SDL_TRUE);
  131. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  132. SDLTest_AssertCheck(
  133. uresult == 10 || uresult == 11 || uresult == 12,
  134. "Validate result value for parameters (10,12,SDL_TRUE); expected: 10|11|12, got: %" SDL_PRIs64, uresult);
  135. /* RandomUintXBoundaryValue(10, 13, SDL_TRUE) returns 10, 11, 12, 13 */
  136. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(10, 13, SDL_TRUE);
  137. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  138. SDLTest_AssertCheck(
  139. uresult == 10 || uresult == 11 || uresult == 12 || uresult == 13,
  140. "Validate result value for parameters (10,13,SDL_TRUE); expected: 10|11|12|13, got: %" SDL_PRIs64, uresult);
  141. /* RandomUintXBoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 */
  142. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(10, 20, SDL_TRUE);
  143. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  144. SDLTest_AssertCheck(
  145. uresult == 10 || uresult == 11 || uresult == 19 || uresult == 20,
  146. "Validate result value for parameters (10,20,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, uresult);
  147. /* RandomUintXBoundaryValue(20, 10, SDL_TRUE) returns 10, 11, 19 or 20 */
  148. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(20, 10, SDL_TRUE);
  149. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  150. SDLTest_AssertCheck(
  151. uresult == 10 || uresult == 11 || uresult == 19 || uresult == 20,
  152. "Validate result value for parameters (20,10,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, uresult);
  153. /* RandomUintXBoundaryValue(1, 20, SDL_FALSE) returns 0, 21 */
  154. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(1, 20, SDL_FALSE);
  155. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  156. SDLTest_AssertCheck(
  157. uresult == 0 || uresult == 21,
  158. "Validate result value for parameters (1,20,SDL_FALSE); expected: 0|21, got: %" SDL_PRIs64, uresult);
  159. /* RandomUintXBoundaryValue(0, 99, SDL_FALSE) returns 100 */
  160. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(0, 99, SDL_FALSE);
  161. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  162. SDLTest_AssertCheck(
  163. uresult == 100,
  164. "Validate result value for parameters (0,99,SDL_FALSE); expected: 100, got: %" SDL_PRIs64, uresult);
  165. /* RandomUintXBoundaryValue(1, 0xff, SDL_FALSE) returns 0 (no error) */
  166. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(1, 255, SDL_FALSE);
  167. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  168. SDLTest_AssertCheck(
  169. uresult == 0,
  170. "Validate result value for parameters (1,255,SDL_FALSE); expected: 0, got: %" SDL_PRIs64, uresult);
  171. lastError = SDL_GetError();
  172. SDLTest_AssertPass("SDL_GetError()");
  173. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  174. /* RandomUintXBoundaryValue(0, 0xfe, SDL_FALSE) returns 0xff (no error) */
  175. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(0, 254, SDL_FALSE);
  176. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  177. SDLTest_AssertCheck(
  178. uresult == 0xff,
  179. "Validate result value for parameters (0,254,SDL_FALSE); expected: 0xff, got: %" SDL_PRIs64, uresult);
  180. lastError = SDL_GetError();
  181. SDLTest_AssertPass("SDL_GetError()");
  182. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  183. /* RandomUintXBoundaryValue(0, 0xff, SDL_FALSE) returns 0 (sets error) */
  184. uresult = (Uint64)SDLTest_RandomUint8BoundaryValue(0, 255, SDL_FALSE);
  185. SDLTest_AssertPass("Call to SDLTest_RandomUint8BoundaryValue");
  186. SDLTest_AssertCheck(
  187. uresult == 0,
  188. "Validate result value for parameters(0,255,SDL_FALSE); expected: 0, got: %" SDL_PRIs64, uresult);
  189. lastError = SDL_GetError();
  190. SDLTest_AssertPass("SDL_GetError()");
  191. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  192. "SDL_GetError(): expected message '%s', was message: '%s'",
  193. expectedError,
  194. lastError);
  195. /* Clear error messages */
  196. SDL_ClearError();
  197. SDLTest_AssertPass("SDL_ClearError()");
  198. return TEST_COMPLETED;
  199. }
  200. /**
  201. * Calls to random boundary number generators for Uint16
  202. */
  203. static int sdltest_randomBoundaryNumberUint16(void *arg)
  204. {
  205. const char *expectedError = "That operation is not supported";
  206. const char *lastError;
  207. Uint64 uresult;
  208. /* Clean error messages */
  209. SDL_ClearError();
  210. SDLTest_AssertPass("SDL_ClearError()");
  211. /* RandomUintXBoundaryValue(10, 10, SDL_TRUE) returns 10 */
  212. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(10, 10, SDL_TRUE);
  213. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  214. SDLTest_AssertCheck(
  215. uresult == 10,
  216. "Validate result value for parameters (10,10,SDL_TRUE); expected: 10, got: %" SDL_PRIs64, uresult);
  217. /* RandomUintXBoundaryValue(10, 11, SDL_TRUE) returns 10, 11 */
  218. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(10, 11, SDL_TRUE);
  219. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  220. SDLTest_AssertCheck(
  221. uresult == 10 || uresult == 11,
  222. "Validate result value for parameters (10,11,SDL_TRUE); expected: 10|11, got: %" SDL_PRIs64, uresult);
  223. /* RandomUintXBoundaryValue(10, 12, SDL_TRUE) returns 10, 11, 12 */
  224. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(10, 12, SDL_TRUE);
  225. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  226. SDLTest_AssertCheck(
  227. uresult == 10 || uresult == 11 || uresult == 12,
  228. "Validate result value for parameters (10,12,SDL_TRUE); expected: 10|11|12, got: %" SDL_PRIs64, uresult);
  229. /* RandomUintXBoundaryValue(10, 13, SDL_TRUE) returns 10, 11, 12, 13 */
  230. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(10, 13, SDL_TRUE);
  231. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  232. SDLTest_AssertCheck(
  233. uresult == 10 || uresult == 11 || uresult == 12 || uresult == 13,
  234. "Validate result value for parameters (10,13,SDL_TRUE); expected: 10|11|12|13, got: %" SDL_PRIs64, uresult);
  235. /* RandomUintXBoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 */
  236. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(10, 20, SDL_TRUE);
  237. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  238. SDLTest_AssertCheck(
  239. uresult == 10 || uresult == 11 || uresult == 19 || uresult == 20,
  240. "Validate result value for parameters (10,20,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, uresult);
  241. /* RandomUintXBoundaryValue(20, 10, SDL_TRUE) returns 10, 11, 19 or 20 */
  242. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(20, 10, SDL_TRUE);
  243. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  244. SDLTest_AssertCheck(
  245. uresult == 10 || uresult == 11 || uresult == 19 || uresult == 20,
  246. "Validate result value for parameters (20,10,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, uresult);
  247. /* RandomUintXBoundaryValue(1, 20, SDL_FALSE) returns 0, 21 */
  248. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(1, 20, SDL_FALSE);
  249. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  250. SDLTest_AssertCheck(
  251. uresult == 0 || uresult == 21,
  252. "Validate result value for parameters (1,20,SDL_FALSE); expected: 0|21, got: %" SDL_PRIs64, uresult);
  253. /* RandomUintXBoundaryValue(0, 99, SDL_FALSE) returns 100 */
  254. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(0, 99, SDL_FALSE);
  255. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  256. SDLTest_AssertCheck(
  257. uresult == 100,
  258. "Validate result value for parameters (0,99,SDL_FALSE); expected: 100, got: %" SDL_PRIs64, uresult);
  259. /* RandomUintXBoundaryValue(1, 0xffff, SDL_FALSE) returns 0 (no error) */
  260. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(1, 0xffff, SDL_FALSE);
  261. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  262. SDLTest_AssertCheck(
  263. uresult == 0,
  264. "Validate result value for parameters (1,0xffff,SDL_FALSE); expected: 0, got: %" SDL_PRIs64, uresult);
  265. lastError = SDL_GetError();
  266. SDLTest_AssertPass("SDL_GetError()");
  267. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  268. /* RandomUintXBoundaryValue(0, 0xfffe, SDL_FALSE) returns 0xffff (no error) */
  269. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(0, 0xfffe, SDL_FALSE);
  270. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  271. SDLTest_AssertCheck(
  272. uresult == 0xffff,
  273. "Validate result value for parameters (0,0xfffe,SDL_FALSE); expected: 0xffff, got: %" SDL_PRIs64, uresult);
  274. lastError = SDL_GetError();
  275. SDLTest_AssertPass("SDL_GetError()");
  276. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  277. /* RandomUintXBoundaryValue(0, 0xffff, SDL_FALSE) returns 0 (sets error) */
  278. uresult = (Uint64)SDLTest_RandomUint16BoundaryValue(0, 0xffff, SDL_FALSE);
  279. SDLTest_AssertPass("Call to SDLTest_RandomUint16BoundaryValue");
  280. SDLTest_AssertCheck(
  281. uresult == 0,
  282. "Validate result value for parameters(0,0xffff,SDL_FALSE); expected: 0, got: %" SDL_PRIs64, uresult);
  283. lastError = SDL_GetError();
  284. SDLTest_AssertPass("SDL_GetError()");
  285. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  286. "SDL_GetError(): expected message '%s', was message: '%s'",
  287. expectedError,
  288. lastError);
  289. /* Clear error messages */
  290. SDL_ClearError();
  291. SDLTest_AssertPass("SDL_ClearError()");
  292. return TEST_COMPLETED;
  293. }
  294. /**
  295. * Calls to random boundary number generators for Uint32
  296. */
  297. static int sdltest_randomBoundaryNumberUint32(void *arg)
  298. {
  299. const char *expectedError = "That operation is not supported";
  300. const char *lastError;
  301. Uint64 uresult;
  302. /* Clean error messages */
  303. SDL_ClearError();
  304. SDLTest_AssertPass("SDL_ClearError()");
  305. /* RandomUintXBoundaryValue(10, 10, SDL_TRUE) returns 10 */
  306. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(10, 10, SDL_TRUE);
  307. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  308. SDLTest_AssertCheck(
  309. uresult == 10,
  310. "Validate result value for parameters (10,10,SDL_TRUE); expected: 10, got: %" SDL_PRIs64, uresult);
  311. /* RandomUintXBoundaryValue(10, 11, SDL_TRUE) returns 10, 11 */
  312. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(10, 11, SDL_TRUE);
  313. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  314. SDLTest_AssertCheck(
  315. uresult == 10 || uresult == 11,
  316. "Validate result value for parameters (10,11,SDL_TRUE); expected: 10|11, got: %" SDL_PRIs64, uresult);
  317. /* RandomUintXBoundaryValue(10, 12, SDL_TRUE) returns 10, 11, 12 */
  318. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(10, 12, SDL_TRUE);
  319. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  320. SDLTest_AssertCheck(
  321. uresult == 10 || uresult == 11 || uresult == 12,
  322. "Validate result value for parameters (10,12,SDL_TRUE); expected: 10|11|12, got: %" SDL_PRIs64, uresult);
  323. /* RandomUintXBoundaryValue(10, 13, SDL_TRUE) returns 10, 11, 12, 13 */
  324. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(10, 13, SDL_TRUE);
  325. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  326. SDLTest_AssertCheck(
  327. uresult == 10 || uresult == 11 || uresult == 12 || uresult == 13,
  328. "Validate result value for parameters (10,13,SDL_TRUE); expected: 10|11|12|13, got: %" SDL_PRIs64, uresult);
  329. /* RandomUintXBoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 */
  330. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(10, 20, SDL_TRUE);
  331. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  332. SDLTest_AssertCheck(
  333. uresult == 10 || uresult == 11 || uresult == 19 || uresult == 20,
  334. "Validate result value for parameters (10,20,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, uresult);
  335. /* RandomUintXBoundaryValue(20, 10, SDL_TRUE) returns 10, 11, 19 or 20 */
  336. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(20, 10, SDL_TRUE);
  337. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  338. SDLTest_AssertCheck(
  339. uresult == 10 || uresult == 11 || uresult == 19 || uresult == 20,
  340. "Validate result value for parameters (20,10,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, uresult);
  341. /* RandomUintXBoundaryValue(1, 20, SDL_FALSE) returns 0, 21 */
  342. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(1, 20, SDL_FALSE);
  343. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  344. SDLTest_AssertCheck(
  345. uresult == 0 || uresult == 21,
  346. "Validate result value for parameters (1,20,SDL_FALSE); expected: 0|21, got: %" SDL_PRIs64, uresult);
  347. /* RandomUintXBoundaryValue(0, 99, SDL_FALSE) returns 100 */
  348. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(0, 99, SDL_FALSE);
  349. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  350. SDLTest_AssertCheck(
  351. uresult == 100,
  352. "Validate result value for parameters (0,99,SDL_FALSE); expected: 100, got: %" SDL_PRIs64, uresult);
  353. /* RandomUintXBoundaryValue(1, 0xffffffff, SDL_FALSE) returns 0 (no error) */
  354. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(1, 0xffffffff, SDL_FALSE);
  355. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  356. SDLTest_AssertCheck(
  357. uresult == 0,
  358. "Validate result value for parameters (1,0xffffffff,SDL_FALSE); expected: 0, got: %" SDL_PRIs64, uresult);
  359. lastError = SDL_GetError();
  360. SDLTest_AssertPass("SDL_GetError()");
  361. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  362. /* RandomUintXBoundaryValue(0, 0xfffffffe, SDL_FALSE) returns 0xffffffff (no error) */
  363. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(0, 0xfffffffe, SDL_FALSE);
  364. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  365. SDLTest_AssertCheck(
  366. uresult == 0xffffffff,
  367. "Validate result value for parameters (0,0xfffffffe,SDL_FALSE); expected: 0xffffffff, got: %" SDL_PRIs64, uresult);
  368. lastError = SDL_GetError();
  369. SDLTest_AssertPass("SDL_GetError()");
  370. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  371. /* RandomUintXBoundaryValue(0, 0xffffffff, SDL_FALSE) returns 0 (sets error) */
  372. uresult = (Uint64)SDLTest_RandomUint32BoundaryValue(0, 0xffffffff, SDL_FALSE);
  373. SDLTest_AssertPass("Call to SDLTest_RandomUint32BoundaryValue");
  374. SDLTest_AssertCheck(
  375. uresult == 0,
  376. "Validate result value for parameters(0,0xffffffff,SDL_FALSE); expected: 0, got: %" SDL_PRIs64, uresult);
  377. lastError = SDL_GetError();
  378. SDLTest_AssertPass("SDL_GetError()");
  379. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  380. "SDL_GetError(): expected message '%s', was message: '%s'",
  381. expectedError,
  382. lastError);
  383. /* Clear error messages */
  384. SDL_ClearError();
  385. SDLTest_AssertPass("SDL_ClearError()");
  386. return TEST_COMPLETED;
  387. }
  388. /**
  389. * Calls to random boundary number generators for Uint64
  390. */
  391. static int sdltest_randomBoundaryNumberUint64(void *arg)
  392. {
  393. const char *expectedError = "That operation is not supported";
  394. const char *lastError;
  395. Uint64 uresult;
  396. /* Clean error messages */
  397. SDL_ClearError();
  398. SDLTest_AssertPass("SDL_ClearError()");
  399. /* RandomUintXBoundaryValue(10, 10, SDL_TRUE) returns 10 */
  400. uresult = SDLTest_RandomUint64BoundaryValue(10, 10, SDL_TRUE);
  401. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  402. SDLTest_AssertCheck(
  403. uresult == 10,
  404. "Validate result value for parameters (10,10,SDL_TRUE); expected: 10, got: %" SDL_PRIs64, uresult);
  405. /* RandomUintXBoundaryValue(10, 11, SDL_TRUE) returns 10, 11 */
  406. uresult = SDLTest_RandomUint64BoundaryValue(10, 11, SDL_TRUE);
  407. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  408. SDLTest_AssertCheck(
  409. uresult == 10 || uresult == 11,
  410. "Validate result value for parameters (10,11,SDL_TRUE); expected: 10|11, got: %" SDL_PRIs64, uresult);
  411. /* RandomUintXBoundaryValue(10, 12, SDL_TRUE) returns 10, 11, 12 */
  412. uresult = SDLTest_RandomUint64BoundaryValue(10, 12, SDL_TRUE);
  413. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  414. SDLTest_AssertCheck(
  415. uresult == 10 || uresult == 11 || uresult == 12,
  416. "Validate result value for parameters (10,12,SDL_TRUE); expected: 10|11|12, got: %" SDL_PRIs64, uresult);
  417. /* RandomUintXBoundaryValue(10, 13, SDL_TRUE) returns 10, 11, 12, 13 */
  418. uresult = SDLTest_RandomUint64BoundaryValue(10, 13, SDL_TRUE);
  419. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  420. SDLTest_AssertCheck(
  421. uresult == 10 || uresult == 11 || uresult == 12 || uresult == 13,
  422. "Validate result value for parameters (10,13,SDL_TRUE); expected: 10|11|12|13, got: %" SDL_PRIs64, uresult);
  423. /* RandomUintXBoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 */
  424. uresult = SDLTest_RandomUint64BoundaryValue(10, 20, SDL_TRUE);
  425. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  426. SDLTest_AssertCheck(
  427. uresult == 10 || uresult == 11 || uresult == 19 || uresult == 20,
  428. "Validate result value for parameters (10,20,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, uresult);
  429. /* RandomUintXBoundaryValue(20, 10, SDL_TRUE) returns 10, 11, 19 or 20 */
  430. uresult = SDLTest_RandomUint64BoundaryValue(20, 10, SDL_TRUE);
  431. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  432. SDLTest_AssertCheck(
  433. uresult == 10 || uresult == 11 || uresult == 19 || uresult == 20,
  434. "Validate result value for parameters (20,10,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, uresult);
  435. /* RandomUintXBoundaryValue(1, 20, SDL_FALSE) returns 0, 21 */
  436. uresult = SDLTest_RandomUint64BoundaryValue(1, 20, SDL_FALSE);
  437. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  438. SDLTest_AssertCheck(
  439. uresult == 0 || uresult == 21,
  440. "Validate result value for parameters (1,20,SDL_FALSE); expected: 0|21, got: %" SDL_PRIs64, uresult);
  441. /* RandomUintXBoundaryValue(0, 99, SDL_FALSE) returns 100 */
  442. uresult = SDLTest_RandomUint64BoundaryValue(0, 99, SDL_FALSE);
  443. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  444. SDLTest_AssertCheck(
  445. uresult == 100,
  446. "Validate result value for parameters (0,99,SDL_FALSE); expected: 100, got: %" SDL_PRIs64, uresult);
  447. /* RandomUintXBoundaryValue(1, 0xffffffffffffffff, SDL_FALSE) returns 0 (no error) */
  448. uresult = SDLTest_RandomUint64BoundaryValue(1, 0xffffffffffffffffULL, SDL_FALSE);
  449. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  450. SDLTest_AssertCheck(
  451. uresult == 0,
  452. "Validate result value for parameters (1,0xffffffffffffffff,SDL_FALSE); expected: 0, got: %" SDL_PRIs64, uresult);
  453. lastError = SDL_GetError();
  454. SDLTest_AssertPass("SDL_GetError()");
  455. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  456. /* RandomUintXBoundaryValue(0, 0xfffffffffffffffe, SDL_FALSE) returns 0xffffffffffffffff (no error) */
  457. uresult = SDLTest_RandomUint64BoundaryValue(0, 0xfffffffffffffffeULL, SDL_FALSE);
  458. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  459. SDLTest_AssertCheck(
  460. uresult == 0xffffffffffffffffULL,
  461. "Validate result value for parameters (0,0xfffffffffffffffe,SDL_FALSE); expected: 0xffffffffffffffff, got: %" SDL_PRIs64, uresult);
  462. lastError = SDL_GetError();
  463. SDLTest_AssertPass("SDL_GetError()");
  464. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  465. /* RandomUintXBoundaryValue(0, 0xffffffffffffffff, SDL_FALSE) returns 0 (sets error) */
  466. uresult = SDLTest_RandomUint64BoundaryValue(0, 0xffffffffffffffffULL, SDL_FALSE);
  467. SDLTest_AssertPass("Call to SDLTest_RandomUint64BoundaryValue");
  468. SDLTest_AssertCheck(
  469. uresult == 0,
  470. "Validate result value for parameters(0,0xffffffffffffffff,SDL_FALSE); expected: 0, got: %" SDL_PRIs64, uresult);
  471. lastError = SDL_GetError();
  472. SDLTest_AssertPass("SDL_GetError()");
  473. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  474. "SDL_GetError(): expected message '%s', was message: '%s'",
  475. expectedError,
  476. lastError);
  477. /* Clear error messages */
  478. SDL_ClearError();
  479. SDLTest_AssertPass("SDL_ClearError()");
  480. return TEST_COMPLETED;
  481. }
  482. /**
  483. * Calls to random boundary number generators for Sint8
  484. */
  485. static int sdltest_randomBoundaryNumberSint8(void *arg)
  486. {
  487. const char *expectedError = "That operation is not supported";
  488. const char *lastError;
  489. Sint64 sresult;
  490. /* Clean error messages */
  491. SDL_ClearError();
  492. SDLTest_AssertPass("SDL_ClearError()");
  493. /* RandomSintXBoundaryValue(10, 10, SDL_TRUE) returns 10 */
  494. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(10, 10, SDL_TRUE);
  495. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  496. SDLTest_AssertCheck(
  497. sresult == 10,
  498. "Validate result value for parameters (10,10,SDL_TRUE); expected: 10, got: %" SDL_PRIs64, sresult);
  499. /* RandomSintXBoundaryValue(10, 11, SDL_TRUE) returns 10, 11 */
  500. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(10, 11, SDL_TRUE);
  501. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  502. SDLTest_AssertCheck(
  503. sresult == 10 || sresult == 11,
  504. "Validate result value for parameters (10,11,SDL_TRUE); expected: 10|11, got: %" SDL_PRIs64, sresult);
  505. /* RandomSintXBoundaryValue(10, 12, SDL_TRUE) returns 10, 11, 12 */
  506. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(10, 12, SDL_TRUE);
  507. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  508. SDLTest_AssertCheck(
  509. sresult == 10 || sresult == 11 || sresult == 12,
  510. "Validate result value for parameters (10,12,SDL_TRUE); expected: 10|11|12, got: %" SDL_PRIs64, sresult);
  511. /* RandomSintXBoundaryValue(10, 13, SDL_TRUE) returns 10, 11, 12, 13 */
  512. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(10, 13, SDL_TRUE);
  513. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  514. SDLTest_AssertCheck(
  515. sresult == 10 || sresult == 11 || sresult == 12 || sresult == 13,
  516. "Validate result value for parameters (10,13,SDL_TRUE); expected: 10|11|12|13, got: %" SDL_PRIs64, sresult);
  517. /* RandomSintXBoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 */
  518. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(10, 20, SDL_TRUE);
  519. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  520. SDLTest_AssertCheck(
  521. sresult == 10 || sresult == 11 || sresult == 19 || sresult == 20,
  522. "Validate result value for parameters (10,20,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, sresult);
  523. /* RandomSintXBoundaryValue(20, 10, SDL_TRUE) returns 10, 11, 19 or 20 */
  524. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(20, 10, SDL_TRUE);
  525. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  526. SDLTest_AssertCheck(
  527. sresult == 10 || sresult == 11 || sresult == 19 || sresult == 20,
  528. "Validate result value for parameters (20,10,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, sresult);
  529. /* RandomSintXBoundaryValue(1, 20, SDL_FALSE) returns 0, 21 */
  530. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(1, 20, SDL_FALSE);
  531. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  532. SDLTest_AssertCheck(
  533. sresult == 0 || sresult == 21,
  534. "Validate result value for parameters (1,20,SDL_FALSE); expected: 0|21, got: %" SDL_PRIs64, sresult);
  535. /* RandomSintXBoundaryValue(SCHAR_MIN, 99, SDL_FALSE) returns 100 */
  536. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(SCHAR_MIN, 99, SDL_FALSE);
  537. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  538. SDLTest_AssertCheck(
  539. sresult == 100,
  540. "Validate result value for parameters (SCHAR_MIN,99,SDL_FALSE); expected: 100, got: %" SDL_PRIs64, sresult);
  541. /* RandomSintXBoundaryValue(SCHAR_MIN + 1, SCHAR_MAX, SDL_FALSE) returns SCHAR_MIN (no error) */
  542. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(SCHAR_MIN + 1, SCHAR_MAX, SDL_FALSE);
  543. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  544. SDLTest_AssertCheck(
  545. sresult == SCHAR_MIN,
  546. "Validate result value for parameters (SCHAR_MIN + 1,SCHAR_MAX,SDL_FALSE); expected: %d, got: %" SDL_PRIs64, SCHAR_MIN, sresult);
  547. lastError = SDL_GetError();
  548. SDLTest_AssertPass("SDL_GetError()");
  549. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  550. /* RandomSintXBoundaryValue(SCHAR_MIN, SCHAR_MAX - 1, SDL_FALSE) returns SCHAR_MAX (no error) */
  551. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(SCHAR_MIN, SCHAR_MAX - 1, SDL_FALSE);
  552. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  553. SDLTest_AssertCheck(
  554. sresult == SCHAR_MAX,
  555. "Validate result value for parameters (SCHAR_MIN,SCHAR_MAX - 1,SDL_FALSE); expected: %d, got: %" SDL_PRIs64, SCHAR_MAX, sresult);
  556. lastError = SDL_GetError();
  557. SDLTest_AssertPass("SDL_GetError()");
  558. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  559. /* RandomSintXBoundaryValue(SCHAR_MIN, SCHAR_MAX, SDL_FALSE) returns SCHAR_MIN (sets error) */
  560. sresult = (Sint64)SDLTest_RandomSint8BoundaryValue(SCHAR_MIN, SCHAR_MAX, SDL_FALSE);
  561. SDLTest_AssertPass("Call to SDLTest_RandomSint8BoundaryValue");
  562. SDLTest_AssertCheck(
  563. sresult == SCHAR_MIN,
  564. "Validate result value for parameters(SCHAR_MIN,SCHAR_MAX,SDL_FALSE); expected: %d, got: %" SDL_PRIs64, SCHAR_MIN, sresult);
  565. lastError = SDL_GetError();
  566. SDLTest_AssertPass("SDL_GetError()");
  567. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  568. "SDL_GetError(): expected message '%s', was message: '%s'",
  569. expectedError,
  570. lastError);
  571. /* Clear error messages */
  572. SDL_ClearError();
  573. SDLTest_AssertPass("SDL_ClearError()");
  574. return TEST_COMPLETED;
  575. }
  576. /**
  577. * Calls to random boundary number generators for Sint16
  578. */
  579. static int sdltest_randomBoundaryNumberSint16(void *arg)
  580. {
  581. const char *expectedError = "That operation is not supported";
  582. const char *lastError;
  583. Sint64 sresult;
  584. /* Clean error messages */
  585. SDL_ClearError();
  586. SDLTest_AssertPass("SDL_ClearError()");
  587. /* RandomSintXBoundaryValue(10, 10, SDL_TRUE) returns 10 */
  588. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(10, 10, SDL_TRUE);
  589. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  590. SDLTest_AssertCheck(
  591. sresult == 10,
  592. "Validate result value for parameters (10,10,SDL_TRUE); expected: 10, got: %" SDL_PRIs64, sresult);
  593. /* RandomSintXBoundaryValue(10, 11, SDL_TRUE) returns 10, 11 */
  594. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(10, 11, SDL_TRUE);
  595. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  596. SDLTest_AssertCheck(
  597. sresult == 10 || sresult == 11,
  598. "Validate result value for parameters (10,11,SDL_TRUE); expected: 10|11, got: %" SDL_PRIs64, sresult);
  599. /* RandomSintXBoundaryValue(10, 12, SDL_TRUE) returns 10, 11, 12 */
  600. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(10, 12, SDL_TRUE);
  601. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  602. SDLTest_AssertCheck(
  603. sresult == 10 || sresult == 11 || sresult == 12,
  604. "Validate result value for parameters (10,12,SDL_TRUE); expected: 10|11|12, got: %" SDL_PRIs64, sresult);
  605. /* RandomSintXBoundaryValue(10, 13, SDL_TRUE) returns 10, 11, 12, 13 */
  606. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(10, 13, SDL_TRUE);
  607. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  608. SDLTest_AssertCheck(
  609. sresult == 10 || sresult == 11 || sresult == 12 || sresult == 13,
  610. "Validate result value for parameters (10,13,SDL_TRUE); expected: 10|11|12|13, got: %" SDL_PRIs64, sresult);
  611. /* RandomSintXBoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 */
  612. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(10, 20, SDL_TRUE);
  613. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  614. SDLTest_AssertCheck(
  615. sresult == 10 || sresult == 11 || sresult == 19 || sresult == 20,
  616. "Validate result value for parameters (10,20,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, sresult);
  617. /* RandomSintXBoundaryValue(20, 10, SDL_TRUE) returns 10, 11, 19 or 20 */
  618. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(20, 10, SDL_TRUE);
  619. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  620. SDLTest_AssertCheck(
  621. sresult == 10 || sresult == 11 || sresult == 19 || sresult == 20,
  622. "Validate result value for parameters (20,10,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, sresult);
  623. /* RandomSintXBoundaryValue(1, 20, SDL_FALSE) returns 0, 21 */
  624. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(1, 20, SDL_FALSE);
  625. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  626. SDLTest_AssertCheck(
  627. sresult == 0 || sresult == 21,
  628. "Validate result value for parameters (1,20,SDL_FALSE); expected: 0|21, got: %" SDL_PRIs64, sresult);
  629. /* RandomSintXBoundaryValue(SHRT_MIN, 99, SDL_FALSE) returns 100 */
  630. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(SHRT_MIN, 99, SDL_FALSE);
  631. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  632. SDLTest_AssertCheck(
  633. sresult == 100,
  634. "Validate result value for parameters (SHRT_MIN,99,SDL_FALSE); expected: 100, got: %" SDL_PRIs64, sresult);
  635. /* RandomSintXBoundaryValue(SHRT_MIN + 1, SHRT_MAX, SDL_FALSE) returns SHRT_MIN (no error) */
  636. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(SHRT_MIN + 1, SHRT_MAX, SDL_FALSE);
  637. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  638. SDLTest_AssertCheck(
  639. sresult == SHRT_MIN,
  640. "Validate result value for parameters (SHRT_MIN+1,SHRT_MAX,SDL_FALSE); expected: %d, got: %" SDL_PRIs64, SHRT_MIN, sresult);
  641. lastError = SDL_GetError();
  642. SDLTest_AssertPass("SDL_GetError()");
  643. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  644. /* RandomSintXBoundaryValue(SHRT_MIN, SHRT_MAX - 1, SDL_FALSE) returns SHRT_MAX (no error) */
  645. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(SHRT_MIN, SHRT_MAX - 1, SDL_FALSE);
  646. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  647. SDLTest_AssertCheck(
  648. sresult == SHRT_MAX,
  649. "Validate result value for parameters (SHRT_MIN,SHRT_MAX - 1,SDL_FALSE); expected: %d, got: %" SDL_PRIs64, SHRT_MAX, sresult);
  650. lastError = SDL_GetError();
  651. SDLTest_AssertPass("SDL_GetError()");
  652. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  653. /* RandomSintXBoundaryValue(SHRT_MIN, SHRT_MAX, SDL_FALSE) returns 0 (sets error) */
  654. sresult = (Sint64)SDLTest_RandomSint16BoundaryValue(SHRT_MIN, SHRT_MAX, SDL_FALSE);
  655. SDLTest_AssertPass("Call to SDLTest_RandomSint16BoundaryValue");
  656. SDLTest_AssertCheck(
  657. sresult == SHRT_MIN,
  658. "Validate result value for parameters(SHRT_MIN,SHRT_MAX,SDL_FALSE); expected: %d, got: %" SDL_PRIs64, SHRT_MIN, sresult);
  659. lastError = SDL_GetError();
  660. SDLTest_AssertPass("SDL_GetError()");
  661. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  662. "SDL_GetError(): expected message '%s', was message: '%s'",
  663. expectedError,
  664. lastError);
  665. /* Clear error messages */
  666. SDL_ClearError();
  667. SDLTest_AssertPass("SDL_ClearError()");
  668. return TEST_COMPLETED;
  669. }
  670. /**
  671. * Calls to random boundary number generators for Sint32
  672. */
  673. static int sdltest_randomBoundaryNumberSint32(void *arg)
  674. {
  675. const char *expectedError = "That operation is not supported";
  676. const char *lastError;
  677. Sint64 sresult;
  678. #if ((ULONG_MAX) == (UINT_MAX))
  679. Sint32 long_min = LONG_MIN;
  680. Sint32 long_max = LONG_MAX;
  681. #else
  682. Sint32 long_min = INT_MIN;
  683. Sint32 long_max = INT_MAX;
  684. #endif
  685. /* Clean error messages */
  686. SDL_ClearError();
  687. SDLTest_AssertPass("SDL_ClearError()");
  688. /* RandomSintXBoundaryValue(10, 10, SDL_TRUE) returns 10 */
  689. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(10, 10, SDL_TRUE);
  690. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  691. SDLTest_AssertCheck(
  692. sresult == 10,
  693. "Validate result value for parameters (10,10,SDL_TRUE); expected: 10, got: %" SDL_PRIs64, sresult);
  694. /* RandomSintXBoundaryValue(10, 11, SDL_TRUE) returns 10, 11 */
  695. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(10, 11, SDL_TRUE);
  696. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  697. SDLTest_AssertCheck(
  698. sresult == 10 || sresult == 11,
  699. "Validate result value for parameters (10,11,SDL_TRUE); expected: 10|11, got: %" SDL_PRIs64, sresult);
  700. /* RandomSintXBoundaryValue(10, 12, SDL_TRUE) returns 10, 11, 12 */
  701. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(10, 12, SDL_TRUE);
  702. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  703. SDLTest_AssertCheck(
  704. sresult == 10 || sresult == 11 || sresult == 12,
  705. "Validate result value for parameters (10,12,SDL_TRUE); expected: 10|11|12, got: %" SDL_PRIs64, sresult);
  706. /* RandomSintXBoundaryValue(10, 13, SDL_TRUE) returns 10, 11, 12, 13 */
  707. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(10, 13, SDL_TRUE);
  708. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  709. SDLTest_AssertCheck(
  710. sresult == 10 || sresult == 11 || sresult == 12 || sresult == 13,
  711. "Validate result value for parameters (10,13,SDL_TRUE); expected: 10|11|12|13, got: %" SDL_PRIs64, sresult);
  712. /* RandomSintXBoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 */
  713. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(10, 20, SDL_TRUE);
  714. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  715. SDLTest_AssertCheck(
  716. sresult == 10 || sresult == 11 || sresult == 19 || sresult == 20,
  717. "Validate result value for parameters (10,20,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, sresult);
  718. /* RandomSintXBoundaryValue(20, 10, SDL_TRUE) returns 10, 11, 19 or 20 */
  719. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(20, 10, SDL_TRUE);
  720. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  721. SDLTest_AssertCheck(
  722. sresult == 10 || sresult == 11 || sresult == 19 || sresult == 20,
  723. "Validate result value for parameters (20,10,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, sresult);
  724. /* RandomSintXBoundaryValue(1, 20, SDL_FALSE) returns 0, 21 */
  725. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(1, 20, SDL_FALSE);
  726. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  727. SDLTest_AssertCheck(
  728. sresult == 0 || sresult == 21,
  729. "Validate result value for parameters (1,20,SDL_FALSE); expected: 0|21, got: %" SDL_PRIs64, sresult);
  730. /* RandomSintXBoundaryValue(LONG_MIN, 99, SDL_FALSE) returns 100 */
  731. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(long_min, 99, SDL_FALSE);
  732. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  733. SDLTest_AssertCheck(
  734. sresult == 100,
  735. "Validate result value for parameters (LONG_MIN,99,SDL_FALSE); expected: 100, got: %" SDL_PRIs64, sresult);
  736. /* RandomSintXBoundaryValue(LONG_MIN + 1, LONG_MAX, SDL_FALSE) returns LONG_MIN (no error) */
  737. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(long_min + 1, long_max, SDL_FALSE);
  738. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  739. SDLTest_AssertCheck(
  740. sresult == long_min,
  741. "Validate result value for parameters (LONG_MIN+1,LONG_MAX,SDL_FALSE); expected: %" SDL_PRIs32 ", got: %" SDL_PRIs64, long_min, sresult);
  742. lastError = SDL_GetError();
  743. SDLTest_AssertPass("SDL_GetError()");
  744. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  745. /* RandomSintXBoundaryValue(LONG_MIN, LONG_MAX - 1, SDL_FALSE) returns LONG_MAX (no error) */
  746. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(long_min, long_max - 1, SDL_FALSE);
  747. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  748. SDLTest_AssertCheck(
  749. sresult == long_max,
  750. "Validate result value for parameters (LONG_MIN,LONG_MAX - 1,SDL_FALSE); expected: %" SDL_PRIs32 ", got: %" SDL_PRIs64, long_max, sresult);
  751. lastError = SDL_GetError();
  752. SDLTest_AssertPass("SDL_GetError()");
  753. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  754. /* RandomSintXBoundaryValue(LONG_MIN, LONG_MAX, SDL_FALSE) returns 0 (sets error) */
  755. sresult = (Sint64)SDLTest_RandomSint32BoundaryValue(long_min, long_max, SDL_FALSE);
  756. SDLTest_AssertPass("Call to SDLTest_RandomSint32BoundaryValue");
  757. SDLTest_AssertCheck(
  758. sresult == long_min,
  759. "Validate result value for parameters(LONG_MIN,LONG_MAX,SDL_FALSE); expected: %" SDL_PRIs32 ", got: %" SDL_PRIs64, long_min, sresult);
  760. lastError = SDL_GetError();
  761. SDLTest_AssertPass("SDL_GetError()");
  762. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  763. "SDL_GetError(): expected message '%s', was message: '%s'",
  764. expectedError,
  765. lastError);
  766. /* Clear error messages */
  767. SDL_ClearError();
  768. SDLTest_AssertPass("SDL_ClearError()");
  769. return TEST_COMPLETED;
  770. }
  771. /**
  772. * Calls to random boundary number generators for Sint64
  773. */
  774. static int sdltest_randomBoundaryNumberSint64(void *arg)
  775. {
  776. const char *expectedError = "That operation is not supported";
  777. const char *lastError;
  778. Sint64 sresult;
  779. /* Clean error messages */
  780. SDL_ClearError();
  781. SDLTest_AssertPass("SDL_ClearError()");
  782. /* RandomSintXBoundaryValue(10, 10, SDL_TRUE) returns 10 */
  783. sresult = SDLTest_RandomSint64BoundaryValue(10, 10, SDL_TRUE);
  784. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  785. SDLTest_AssertCheck(
  786. sresult == 10,
  787. "Validate result value for parameters (10,10,SDL_TRUE); expected: 10, got: %" SDL_PRIs64, sresult);
  788. /* RandomSintXBoundaryValue(10, 11, SDL_TRUE) returns 10, 11 */
  789. sresult = SDLTest_RandomSint64BoundaryValue(10, 11, SDL_TRUE);
  790. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  791. SDLTest_AssertCheck(
  792. sresult == 10 || sresult == 11,
  793. "Validate result value for parameters (10,11,SDL_TRUE); expected: 10|11, got: %" SDL_PRIs64, sresult);
  794. /* RandomSintXBoundaryValue(10, 12, SDL_TRUE) returns 10, 11, 12 */
  795. sresult = SDLTest_RandomSint64BoundaryValue(10, 12, SDL_TRUE);
  796. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  797. SDLTest_AssertCheck(
  798. sresult == 10 || sresult == 11 || sresult == 12,
  799. "Validate result value for parameters (10,12,SDL_TRUE); expected: 10|11|12, got: %" SDL_PRIs64, sresult);
  800. /* RandomSintXBoundaryValue(10, 13, SDL_TRUE) returns 10, 11, 12, 13 */
  801. sresult = SDLTest_RandomSint64BoundaryValue(10, 13, SDL_TRUE);
  802. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  803. SDLTest_AssertCheck(
  804. sresult == 10 || sresult == 11 || sresult == 12 || sresult == 13,
  805. "Validate result value for parameters (10,13,SDL_TRUE); expected: 10|11|12|13, got: %" SDL_PRIs64, sresult);
  806. /* RandomSintXBoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 */
  807. sresult = SDLTest_RandomSint64BoundaryValue(10, 20, SDL_TRUE);
  808. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  809. SDLTest_AssertCheck(
  810. sresult == 10 || sresult == 11 || sresult == 19 || sresult == 20,
  811. "Validate result value for parameters (10,20,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, sresult);
  812. /* RandomSintXBoundaryValue(20, 10, SDL_TRUE) returns 10, 11, 19 or 20 */
  813. sresult = SDLTest_RandomSint64BoundaryValue(20, 10, SDL_TRUE);
  814. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  815. SDLTest_AssertCheck(
  816. sresult == 10 || sresult == 11 || sresult == 19 || sresult == 20,
  817. "Validate result value for parameters (20,10,SDL_TRUE); expected: 10|11|19|20, got: %" SDL_PRIs64, sresult);
  818. /* RandomSintXBoundaryValue(1, 20, SDL_FALSE) returns 0, 21 */
  819. sresult = SDLTest_RandomSint64BoundaryValue(1, 20, SDL_FALSE);
  820. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  821. SDLTest_AssertCheck(
  822. sresult == 0 || sresult == 21,
  823. "Validate result value for parameters (1,20,SDL_FALSE); expected: 0|21, got: %" SDL_PRIs64, sresult);
  824. /* RandomSintXBoundaryValue(LLONG_MIN, 99, SDL_FALSE) returns 100 */
  825. sresult = SDLTest_RandomSint64BoundaryValue(INT64_MIN, 99, SDL_FALSE);
  826. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  827. SDLTest_AssertCheck(
  828. sresult == 100,
  829. "Validate result value for parameters (LLONG_MIN,99,SDL_FALSE); expected: 100, got: %" SDL_PRIs64, sresult);
  830. /* RandomSintXBoundaryValue(LLONG_MIN + 1, LLONG_MAX, SDL_FALSE) returns LLONG_MIN (no error) */
  831. sresult = SDLTest_RandomSint64BoundaryValue(INT64_MIN + 1, INT64_MAX, SDL_FALSE);
  832. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  833. SDLTest_AssertCheck(
  834. sresult == INT64_MIN,
  835. "Validate result value for parameters (LLONG_MIN+1,LLONG_MAX,SDL_FALSE); expected: %" SDL_PRIs64 ", got: %" SDL_PRIs64, INT64_MIN, sresult);
  836. lastError = SDL_GetError();
  837. SDLTest_AssertPass("SDL_GetError()");
  838. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  839. /* RandomSintXBoundaryValue(LLONG_MIN, LLONG_MAX - 1, SDL_FALSE) returns LLONG_MAX (no error) */
  840. sresult = SDLTest_RandomSint64BoundaryValue(INT64_MIN, INT64_MAX - 1, SDL_FALSE);
  841. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  842. SDLTest_AssertCheck(
  843. sresult == INT64_MAX,
  844. "Validate result value for parameters (LLONG_MIN,LLONG_MAX - 1,SDL_FALSE); expected: %" SDL_PRIs64 ", got: %" SDL_PRIs64, INT64_MAX, sresult);
  845. lastError = SDL_GetError();
  846. SDLTest_AssertPass("SDL_GetError()");
  847. SDLTest_AssertCheck(lastError == NULL || lastError[0] == '\0', "Validate no error message was set");
  848. /* RandomSintXBoundaryValue(LLONG_MIN, LLONG_MAX, SDL_FALSE) returns 0 (sets error) */
  849. sresult = SDLTest_RandomSint64BoundaryValue(INT64_MIN, INT64_MAX, SDL_FALSE);
  850. SDLTest_AssertPass("Call to SDLTest_RandomSint64BoundaryValue");
  851. SDLTest_AssertCheck(
  852. sresult == INT64_MIN,
  853. "Validate result value for parameters(LLONG_MIN,LLONG_MAX,SDL_FALSE); expected: %" SDL_PRIs64 ", got: %" SDL_PRIs64, INT64_MIN, sresult);
  854. lastError = SDL_GetError();
  855. SDLTest_AssertPass("SDL_GetError()");
  856. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  857. "SDL_GetError(): expected message '%s', was message: '%s'",
  858. expectedError,
  859. lastError);
  860. /* Clear error messages */
  861. SDL_ClearError();
  862. SDLTest_AssertPass("SDL_ClearError()");
  863. return TEST_COMPLETED;
  864. }
  865. /**
  866. * Calls to SDLTest_RandomIntegerInRange
  867. */
  868. static int sdltest_randomIntegerInRange(void *arg)
  869. {
  870. Sint32 min, max;
  871. Sint32 result;
  872. #if ((ULONG_MAX) == (UINT_MAX))
  873. Sint32 long_min = LONG_MIN;
  874. Sint32 long_max = LONG_MAX;
  875. #else
  876. Sint32 long_min = INT_MIN;
  877. Sint32 long_max = INT_MAX;
  878. #endif
  879. /* Standard range */
  880. min = (Sint32)SDLTest_RandomSint16();
  881. max = min + (Sint32)SDLTest_RandomUint8() + 2;
  882. result = SDLTest_RandomIntegerInRange(min, max);
  883. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(min,max)");
  884. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  885. /* One Range */
  886. min = (Sint32)SDLTest_RandomSint16();
  887. max = min + 1;
  888. result = SDLTest_RandomIntegerInRange(min, max);
  889. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(min,min+1)");
  890. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  891. /* Zero range */
  892. min = (Sint32)SDLTest_RandomSint16();
  893. max = min;
  894. result = SDLTest_RandomIntegerInRange(min, max);
  895. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(min,min)");
  896. SDLTest_AssertCheck(min == result, "Validated returned value; expected: %" SDL_PRIs32 ", got: %" SDL_PRIs32, min, result);
  897. /* Zero range at zero */
  898. min = 0;
  899. max = 0;
  900. result = SDLTest_RandomIntegerInRange(min, max);
  901. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(0,0)");
  902. SDLTest_AssertCheck(result == 0, "Validated returned value; expected: 0, got: %" SDL_PRIs32, result);
  903. /* Swapped min-max */
  904. min = (Sint32)SDLTest_RandomSint16();
  905. max = min + (Sint32)SDLTest_RandomUint8() + 2;
  906. result = SDLTest_RandomIntegerInRange(max, min);
  907. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(max,min)");
  908. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  909. /* Range with min at integer limit */
  910. min = long_min;
  911. max = long_max + (Sint32)SDLTest_RandomSint16();
  912. result = SDLTest_RandomIntegerInRange(min, max);
  913. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(SINT32_MIN,...)");
  914. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  915. /* Range with max at integer limit */
  916. min = long_min - (Sint32)SDLTest_RandomSint16();
  917. max = long_max;
  918. result = SDLTest_RandomIntegerInRange(min, max);
  919. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(...,SINT32_MAX)");
  920. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  921. /* Full integer range */
  922. min = long_min;
  923. max = long_max;
  924. result = SDLTest_RandomIntegerInRange(min, max);
  925. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(SINT32_MIN,SINT32_MAX)");
  926. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  927. return TEST_COMPLETED;
  928. }
  929. /**
  930. * Calls to SDLTest_RandomAsciiString
  931. */
  932. static int sdltest_randomAsciiString(void *arg)
  933. {
  934. char *result;
  935. size_t len;
  936. int nonAsciiCharacters;
  937. size_t i;
  938. result = SDLTest_RandomAsciiString();
  939. SDLTest_AssertPass("Call to SDLTest_RandomAsciiString()");
  940. SDLTest_AssertCheck(result != NULL, "Validate that result is not NULL");
  941. if (result != NULL) {
  942. len = SDL_strlen(result);
  943. SDLTest_AssertCheck(len >= 1 && len <= 255, "Validate that result length; expected: len=[1,255], got: %d", (int)len);
  944. nonAsciiCharacters = 0;
  945. for (i = 0; i < len; i++) {
  946. if (SDL_iscntrl(result[i])) {
  947. nonAsciiCharacters++;
  948. }
  949. }
  950. SDLTest_AssertCheck(nonAsciiCharacters == 0, "Validate that result does not contain non-Ascii characters, got: %d", nonAsciiCharacters);
  951. if (nonAsciiCharacters) {
  952. SDLTest_LogError("Invalid result from generator: '%s'", result);
  953. }
  954. SDL_free(result);
  955. }
  956. return TEST_COMPLETED;
  957. }
  958. /**
  959. * Calls to SDLTest_RandomAsciiStringWithMaximumLength
  960. */
  961. static int sdltest_randomAsciiStringWithMaximumLength(void *arg)
  962. {
  963. const char *expectedError = "Parameter 'maxLength' is invalid";
  964. const char *lastError;
  965. char *result;
  966. size_t targetLen;
  967. size_t len;
  968. int nonAsciiCharacters;
  969. size_t i;
  970. targetLen = 16 + SDLTest_RandomUint8();
  971. result = SDLTest_RandomAsciiStringWithMaximumLength((int)targetLen);
  972. SDLTest_AssertPass("Call to SDLTest_RandomAsciiStringWithMaximumLength(%d)", (int)targetLen);
  973. SDLTest_AssertCheck(result != NULL, "Validate that result is not NULL");
  974. if (result != NULL) {
  975. len = SDL_strlen(result);
  976. SDLTest_AssertCheck(len >= 1 && len <= targetLen, "Validate that result length; expected: len=[1,%d], got: %d", (int)targetLen, (int)len);
  977. nonAsciiCharacters = 0;
  978. for (i = 0; i < len; i++) {
  979. if (SDL_iscntrl(result[i])) {
  980. nonAsciiCharacters++;
  981. }
  982. }
  983. SDLTest_AssertCheck(nonAsciiCharacters == 0, "Validate that result does not contain non-Ascii characters, got: %d", nonAsciiCharacters);
  984. if (nonAsciiCharacters) {
  985. SDLTest_LogError("Invalid result from generator: '%s'", result);
  986. }
  987. SDL_free(result);
  988. }
  989. /* Negative test */
  990. targetLen = 0;
  991. result = SDLTest_RandomAsciiStringWithMaximumLength((int)targetLen);
  992. SDLTest_AssertPass("Call to SDLTest_RandomAsciiStringWithMaximumLength(%d)", (int)targetLen);
  993. SDLTest_AssertCheck(result == NULL, "Validate that result is NULL");
  994. lastError = SDL_GetError();
  995. SDLTest_AssertPass("SDL_GetError()");
  996. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  997. "SDL_GetError(): expected message '%s', was message: '%s'",
  998. expectedError,
  999. lastError);
  1000. /* Clear error messages */
  1001. SDL_ClearError();
  1002. SDLTest_AssertPass("SDL_ClearError()");
  1003. return TEST_COMPLETED;
  1004. }
  1005. /**
  1006. * Calls to SDLTest_RandomAsciiStringOfSize
  1007. */
  1008. static int sdltest_randomAsciiStringOfSize(void *arg)
  1009. {
  1010. const char *expectedError = "Parameter 'size' is invalid";
  1011. const char *lastError;
  1012. char *result;
  1013. size_t targetLen;
  1014. size_t len;
  1015. int nonAsciiCharacters;
  1016. size_t i;
  1017. /* Positive test */
  1018. targetLen = 16 + SDLTest_RandomUint8();
  1019. result = SDLTest_RandomAsciiStringOfSize((int)targetLen);
  1020. SDLTest_AssertPass("Call to SDLTest_RandomAsciiStringOfSize(%d)", (int)targetLen);
  1021. SDLTest_AssertCheck(result != NULL, "Validate that result is not NULL");
  1022. if (result != NULL) {
  1023. len = SDL_strlen(result);
  1024. SDLTest_AssertCheck(len == targetLen, "Validate that result length; expected: len=%d, got: %d", (int)targetLen, (int)len);
  1025. nonAsciiCharacters = 0;
  1026. for (i = 0; i < len; i++) {
  1027. if (SDL_iscntrl(result[i])) {
  1028. nonAsciiCharacters++;
  1029. }
  1030. }
  1031. SDLTest_AssertCheck(nonAsciiCharacters == 0, "Validate that result does not contain non-ASCII characters, got: %d", nonAsciiCharacters);
  1032. if (nonAsciiCharacters) {
  1033. SDLTest_LogError("Invalid result from generator: '%s'", result);
  1034. }
  1035. SDL_free(result);
  1036. }
  1037. /* Negative test */
  1038. targetLen = 0;
  1039. result = SDLTest_RandomAsciiStringOfSize((int)targetLen);
  1040. SDLTest_AssertPass("Call to SDLTest_RandomAsciiStringOfSize(%d)", (int)targetLen);
  1041. SDLTest_AssertCheck(result == NULL, "Validate that result is NULL");
  1042. lastError = SDL_GetError();
  1043. SDLTest_AssertPass("SDL_GetError()");
  1044. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  1045. "SDL_GetError(): expected message '%s', was message: '%s'",
  1046. expectedError,
  1047. lastError);
  1048. /* Clear error messages */
  1049. SDL_ClearError();
  1050. SDLTest_AssertPass("SDL_ClearError()");
  1051. return TEST_COMPLETED;
  1052. }
  1053. /* ================= Test References ================== */
  1054. /* SDL_test test cases */
  1055. static const SDLTest_TestCaseReference sdltestTest1 = {
  1056. (SDLTest_TestCaseFp)sdltest_getFuzzerInvocationCount, "sdltest_getFuzzerInvocationCount", "Call to sdltest_GetFuzzerInvocationCount", TEST_ENABLED
  1057. };
  1058. static const SDLTest_TestCaseReference sdltestTest2 = {
  1059. (SDLTest_TestCaseFp)sdltest_randomNumber, "sdltest_randomNumber", "Calls to random number generators", TEST_ENABLED
  1060. };
  1061. static const SDLTest_TestCaseReference sdltestTest3 = {
  1062. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberUint8, "sdltest_randomBoundaryNumberUint8", "Calls to random boundary number generators for Uint8", TEST_ENABLED
  1063. };
  1064. static const SDLTest_TestCaseReference sdltestTest4 = {
  1065. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberUint16, "sdltest_randomBoundaryNumberUint16", "Calls to random boundary number generators for Uint16", TEST_ENABLED
  1066. };
  1067. static const SDLTest_TestCaseReference sdltestTest5 = {
  1068. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberUint32, "sdltest_randomBoundaryNumberUint32", "Calls to random boundary number generators for Uint32", TEST_ENABLED
  1069. };
  1070. static const SDLTest_TestCaseReference sdltestTest6 = {
  1071. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberUint64, "sdltest_randomBoundaryNumberUint64", "Calls to random boundary number generators for Uint64", TEST_ENABLED
  1072. };
  1073. static const SDLTest_TestCaseReference sdltestTest7 = {
  1074. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberSint8, "sdltest_randomBoundaryNumberSint8", "Calls to random boundary number generators for Sint8", TEST_ENABLED
  1075. };
  1076. static const SDLTest_TestCaseReference sdltestTest8 = {
  1077. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberSint16, "sdltest_randomBoundaryNumberSint16", "Calls to random boundary number generators for Sint16", TEST_ENABLED
  1078. };
  1079. static const SDLTest_TestCaseReference sdltestTest9 = {
  1080. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberSint32, "sdltest_randomBoundaryNumberSint32", "Calls to random boundary number generators for Sint32", TEST_ENABLED
  1081. };
  1082. static const SDLTest_TestCaseReference sdltestTest10 = {
  1083. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberSint64, "sdltest_randomBoundaryNumberSint64", "Calls to random boundary number generators for Sint64", TEST_ENABLED
  1084. };
  1085. static const SDLTest_TestCaseReference sdltestTest11 = {
  1086. (SDLTest_TestCaseFp)sdltest_randomIntegerInRange, "sdltest_randomIntegerInRange", "Calls to ranged random number generator", TEST_ENABLED
  1087. };
  1088. static const SDLTest_TestCaseReference sdltestTest12 = {
  1089. (SDLTest_TestCaseFp)sdltest_randomAsciiString, "sdltest_randomAsciiString", "Calls to default ASCII string generator", TEST_ENABLED
  1090. };
  1091. static const SDLTest_TestCaseReference sdltestTest13 = {
  1092. (SDLTest_TestCaseFp)sdltest_randomAsciiStringWithMaximumLength, "sdltest_randomAsciiStringWithMaximumLength", "Calls to random maximum length ASCII string generator", TEST_ENABLED
  1093. };
  1094. static const SDLTest_TestCaseReference sdltestTest14 = {
  1095. (SDLTest_TestCaseFp)sdltest_randomAsciiStringOfSize, "sdltest_randomAsciiStringOfSize", "Calls to fixed size ASCII string generator", TEST_ENABLED
  1096. };
  1097. static const SDLTest_TestCaseReference sdltestTest15 = {
  1098. (SDLTest_TestCaseFp)sdltest_generateRunSeed, "sdltest_generateRunSeed", "Checks internal harness function SDLTest_GenerateRunSeed", TEST_ENABLED
  1099. };
  1100. /* Sequence of SDL_test test cases */
  1101. static const SDLTest_TestCaseReference *sdltestTests[] = {
  1102. &sdltestTest1, &sdltestTest2, &sdltestTest3, &sdltestTest4, &sdltestTest5, &sdltestTest6,
  1103. &sdltestTest7, &sdltestTest8, &sdltestTest9, &sdltestTest10, &sdltestTest11, &sdltestTest12,
  1104. &sdltestTest13, &sdltestTest14, &sdltestTest15, NULL
  1105. };
  1106. /* SDL_test test suite (global) */
  1107. SDLTest_TestSuiteReference sdltestTestSuite = {
  1108. "SDLtest",
  1109. NULL,
  1110. sdltestTests,
  1111. NULL
  1112. };