1
0

testautomation_sdltest.c 61 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301
  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. #if 0 /* This test correctly triggers an asan warning: runtime error: signed integer overflow: 2147483647 + 4239 cannot be represented in type 'int' */
  910. /* Range with min at integer limit */
  911. min = long_min;
  912. max = long_max + (Sint32)SDLTest_RandomSint16();
  913. result = SDLTest_RandomIntegerInRange(min, max);
  914. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(SINT32_MIN,...)");
  915. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  916. #endif
  917. /* Range with max at integer limit */
  918. min = long_min - (Sint32)SDLTest_RandomSint16();
  919. max = long_max;
  920. result = SDLTest_RandomIntegerInRange(min, max);
  921. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(...,SINT32_MAX)");
  922. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  923. /* Full integer range */
  924. min = long_min;
  925. max = long_max;
  926. result = SDLTest_RandomIntegerInRange(min, max);
  927. SDLTest_AssertPass("Call to SDLTest_RandomIntegerInRange(SINT32_MIN,SINT32_MAX)");
  928. SDLTest_AssertCheck(min <= result && result <= max, "Validated returned value; expected: [%" SDL_PRIs32 ",%" SDL_PRIs32 "], got: %" SDL_PRIs32, min, max, result);
  929. return TEST_COMPLETED;
  930. }
  931. /**
  932. * Calls to SDLTest_RandomAsciiString
  933. */
  934. static int sdltest_randomAsciiString(void *arg)
  935. {
  936. char *result;
  937. size_t len;
  938. int nonAsciiCharacters;
  939. size_t i;
  940. result = SDLTest_RandomAsciiString();
  941. SDLTest_AssertPass("Call to SDLTest_RandomAsciiString()");
  942. SDLTest_AssertCheck(result != NULL, "Validate that result is not NULL");
  943. if (result != NULL) {
  944. len = SDL_strlen(result);
  945. SDLTest_AssertCheck(len >= 1 && len <= 255, "Validate that result length; expected: len=[1,255], got: %d", (int)len);
  946. nonAsciiCharacters = 0;
  947. for (i = 0; i < len; i++) {
  948. if (SDL_iscntrl(result[i])) {
  949. nonAsciiCharacters++;
  950. }
  951. }
  952. SDLTest_AssertCheck(nonAsciiCharacters == 0, "Validate that result does not contain non-Ascii characters, got: %d", nonAsciiCharacters);
  953. if (nonAsciiCharacters) {
  954. SDLTest_LogError("Invalid result from generator: '%s'", result);
  955. }
  956. SDL_free(result);
  957. }
  958. return TEST_COMPLETED;
  959. }
  960. /**
  961. * Calls to SDLTest_RandomAsciiStringWithMaximumLength
  962. */
  963. static int sdltest_randomAsciiStringWithMaximumLength(void *arg)
  964. {
  965. const char *expectedError = "Parameter 'maxLength' is invalid";
  966. const char *lastError;
  967. char *result;
  968. size_t targetLen;
  969. size_t len;
  970. int nonAsciiCharacters;
  971. size_t i;
  972. targetLen = 16 + SDLTest_RandomUint8();
  973. result = SDLTest_RandomAsciiStringWithMaximumLength((int)targetLen);
  974. SDLTest_AssertPass("Call to SDLTest_RandomAsciiStringWithMaximumLength(%d)", (int)targetLen);
  975. SDLTest_AssertCheck(result != NULL, "Validate that result is not NULL");
  976. if (result != NULL) {
  977. len = SDL_strlen(result);
  978. SDLTest_AssertCheck(len >= 1 && len <= targetLen, "Validate that result length; expected: len=[1,%d], got: %d", (int)targetLen, (int)len);
  979. nonAsciiCharacters = 0;
  980. for (i = 0; i < len; i++) {
  981. if (SDL_iscntrl(result[i])) {
  982. nonAsciiCharacters++;
  983. }
  984. }
  985. SDLTest_AssertCheck(nonAsciiCharacters == 0, "Validate that result does not contain non-Ascii characters, got: %d", nonAsciiCharacters);
  986. if (nonAsciiCharacters) {
  987. SDLTest_LogError("Invalid result from generator: '%s'", result);
  988. }
  989. SDL_free(result);
  990. }
  991. /* Negative test */
  992. targetLen = 0;
  993. result = SDLTest_RandomAsciiStringWithMaximumLength((int)targetLen);
  994. SDLTest_AssertPass("Call to SDLTest_RandomAsciiStringWithMaximumLength(%d)", (int)targetLen);
  995. SDLTest_AssertCheck(result == NULL, "Validate that result is NULL");
  996. lastError = SDL_GetError();
  997. SDLTest_AssertPass("SDL_GetError()");
  998. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  999. "SDL_GetError(): expected message '%s', was message: '%s'",
  1000. expectedError,
  1001. lastError);
  1002. /* Clear error messages */
  1003. SDL_ClearError();
  1004. SDLTest_AssertPass("SDL_ClearError()");
  1005. return TEST_COMPLETED;
  1006. }
  1007. /**
  1008. * Calls to SDLTest_RandomAsciiStringOfSize
  1009. */
  1010. static int sdltest_randomAsciiStringOfSize(void *arg)
  1011. {
  1012. const char *expectedError = "Parameter 'size' is invalid";
  1013. const char *lastError;
  1014. char *result;
  1015. size_t targetLen;
  1016. size_t len;
  1017. int nonAsciiCharacters;
  1018. size_t i;
  1019. /* Positive test */
  1020. targetLen = 16 + SDLTest_RandomUint8();
  1021. result = SDLTest_RandomAsciiStringOfSize((int)targetLen);
  1022. SDLTest_AssertPass("Call to SDLTest_RandomAsciiStringOfSize(%d)", (int)targetLen);
  1023. SDLTest_AssertCheck(result != NULL, "Validate that result is not NULL");
  1024. if (result != NULL) {
  1025. len = SDL_strlen(result);
  1026. SDLTest_AssertCheck(len == targetLen, "Validate that result length; expected: len=%d, got: %d", (int)targetLen, (int)len);
  1027. nonAsciiCharacters = 0;
  1028. for (i = 0; i < len; i++) {
  1029. if (SDL_iscntrl(result[i])) {
  1030. nonAsciiCharacters++;
  1031. }
  1032. }
  1033. SDLTest_AssertCheck(nonAsciiCharacters == 0, "Validate that result does not contain non-ASCII characters, got: %d", nonAsciiCharacters);
  1034. if (nonAsciiCharacters) {
  1035. SDLTest_LogError("Invalid result from generator: '%s'", result);
  1036. }
  1037. SDL_free(result);
  1038. }
  1039. /* Negative test */
  1040. targetLen = 0;
  1041. result = SDLTest_RandomAsciiStringOfSize((int)targetLen);
  1042. SDLTest_AssertPass("Call to SDLTest_RandomAsciiStringOfSize(%d)", (int)targetLen);
  1043. SDLTest_AssertCheck(result == NULL, "Validate that result is NULL");
  1044. lastError = SDL_GetError();
  1045. SDLTest_AssertPass("SDL_GetError()");
  1046. SDLTest_AssertCheck(lastError != NULL && SDL_strcmp(lastError, expectedError) == 0,
  1047. "SDL_GetError(): expected message '%s', was message: '%s'",
  1048. expectedError,
  1049. lastError);
  1050. /* Clear error messages */
  1051. SDL_ClearError();
  1052. SDLTest_AssertPass("SDL_ClearError()");
  1053. return TEST_COMPLETED;
  1054. }
  1055. /* ================= Test References ================== */
  1056. /* SDL_test test cases */
  1057. static const SDLTest_TestCaseReference sdltestTest1 = {
  1058. (SDLTest_TestCaseFp)sdltest_getFuzzerInvocationCount, "sdltest_getFuzzerInvocationCount", "Call to sdltest_GetFuzzerInvocationCount", TEST_ENABLED
  1059. };
  1060. static const SDLTest_TestCaseReference sdltestTest2 = {
  1061. (SDLTest_TestCaseFp)sdltest_randomNumber, "sdltest_randomNumber", "Calls to random number generators", TEST_ENABLED
  1062. };
  1063. static const SDLTest_TestCaseReference sdltestTest3 = {
  1064. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberUint8, "sdltest_randomBoundaryNumberUint8", "Calls to random boundary number generators for Uint8", TEST_ENABLED
  1065. };
  1066. static const SDLTest_TestCaseReference sdltestTest4 = {
  1067. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberUint16, "sdltest_randomBoundaryNumberUint16", "Calls to random boundary number generators for Uint16", TEST_ENABLED
  1068. };
  1069. static const SDLTest_TestCaseReference sdltestTest5 = {
  1070. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberUint32, "sdltest_randomBoundaryNumberUint32", "Calls to random boundary number generators for Uint32", TEST_ENABLED
  1071. };
  1072. static const SDLTest_TestCaseReference sdltestTest6 = {
  1073. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberUint64, "sdltest_randomBoundaryNumberUint64", "Calls to random boundary number generators for Uint64", TEST_ENABLED
  1074. };
  1075. static const SDLTest_TestCaseReference sdltestTest7 = {
  1076. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberSint8, "sdltest_randomBoundaryNumberSint8", "Calls to random boundary number generators for Sint8", TEST_ENABLED
  1077. };
  1078. static const SDLTest_TestCaseReference sdltestTest8 = {
  1079. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberSint16, "sdltest_randomBoundaryNumberSint16", "Calls to random boundary number generators for Sint16", TEST_ENABLED
  1080. };
  1081. static const SDLTest_TestCaseReference sdltestTest9 = {
  1082. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberSint32, "sdltest_randomBoundaryNumberSint32", "Calls to random boundary number generators for Sint32", TEST_ENABLED
  1083. };
  1084. static const SDLTest_TestCaseReference sdltestTest10 = {
  1085. (SDLTest_TestCaseFp)sdltest_randomBoundaryNumberSint64, "sdltest_randomBoundaryNumberSint64", "Calls to random boundary number generators for Sint64", TEST_ENABLED
  1086. };
  1087. static const SDLTest_TestCaseReference sdltestTest11 = {
  1088. (SDLTest_TestCaseFp)sdltest_randomIntegerInRange, "sdltest_randomIntegerInRange", "Calls to ranged random number generator", TEST_ENABLED
  1089. };
  1090. static const SDLTest_TestCaseReference sdltestTest12 = {
  1091. (SDLTest_TestCaseFp)sdltest_randomAsciiString, "sdltest_randomAsciiString", "Calls to default ASCII string generator", TEST_ENABLED
  1092. };
  1093. static const SDLTest_TestCaseReference sdltestTest13 = {
  1094. (SDLTest_TestCaseFp)sdltest_randomAsciiStringWithMaximumLength, "sdltest_randomAsciiStringWithMaximumLength", "Calls to random maximum length ASCII string generator", TEST_ENABLED
  1095. };
  1096. static const SDLTest_TestCaseReference sdltestTest14 = {
  1097. (SDLTest_TestCaseFp)sdltest_randomAsciiStringOfSize, "sdltest_randomAsciiStringOfSize", "Calls to fixed size ASCII string generator", TEST_ENABLED
  1098. };
  1099. static const SDLTest_TestCaseReference sdltestTest15 = {
  1100. (SDLTest_TestCaseFp)sdltest_generateRunSeed, "sdltest_generateRunSeed", "Checks internal harness function SDLTest_GenerateRunSeed", TEST_ENABLED
  1101. };
  1102. /* Sequence of SDL_test test cases */
  1103. static const SDLTest_TestCaseReference *sdltestTests[] = {
  1104. &sdltestTest1, &sdltestTest2, &sdltestTest3, &sdltestTest4, &sdltestTest5, &sdltestTest6,
  1105. &sdltestTest7, &sdltestTest8, &sdltestTest9, &sdltestTest10, &sdltestTest11, &sdltestTest12,
  1106. &sdltestTest13, &sdltestTest14, &sdltestTest15, NULL
  1107. };
  1108. /* SDL_test test suite (global) */
  1109. SDLTest_TestSuiteReference sdltestTestSuite = {
  1110. "SDLtest",
  1111. NULL,
  1112. sdltestTests,
  1113. NULL
  1114. };