testautomation_stdlib.c 76 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532
  1. /**
  2. * Standard C library routine test suite
  3. */
  4. #include <SDL3/SDL.h>
  5. #include <SDL3/SDL_test.h>
  6. #include "testautomation_suites.h"
  7. /* Test case functions */
  8. /**
  9. * Call to SDL_strnlen
  10. */
  11. static int SDLCALL stdlib_strnlen(void *arg)
  12. {
  13. size_t result;
  14. char *text_result;
  15. const char *text = "food";
  16. const char *expected;
  17. result = SDL_strnlen(text, 6);
  18. SDLTest_AssertPass("Call to SDL_strndup(\"food\", 6)");
  19. SDLTest_AssertCheck(result == 4, "Check result value, expected: 4, got: %d", (int)result);
  20. result = SDL_strnlen(text, 3);
  21. SDLTest_AssertPass("Call to SDL_strndup(\"food\", 3)");
  22. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", (int)result);
  23. text_result = SDL_strndup(text, 3);
  24. expected = "foo";
  25. SDLTest_AssertPass("Call to SDL_strndup(\"food\", 3)");
  26. SDLTest_AssertCheck(SDL_strcmp(text_result, expected) == 0, "Check text, expected: %s, got: %s", expected, text_result);
  27. SDL_free(text_result);
  28. return TEST_COMPLETED;
  29. }
  30. /**
  31. * Call to SDL_strlcpy
  32. */
  33. static int SDLCALL stdlib_strlcpy(void *arg)
  34. {
  35. size_t result;
  36. char text[1024];
  37. const char *expected;
  38. result = SDL_strlcpy(text, "foo", sizeof(text));
  39. expected = "foo";
  40. SDLTest_AssertPass("Call to SDL_strlcpy(\"foo\")");
  41. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  42. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), (int)result);
  43. result = SDL_strlcpy(text, "foo", 2);
  44. expected = "f";
  45. SDLTest_AssertPass("Call to SDL_strlcpy(\"foo\") with buffer size 2");
  46. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  47. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", (int)result);
  48. return TEST_COMPLETED;
  49. }
  50. /**
  51. * Call to SDL_strstr
  52. */
  53. static int SDLCALL stdlib_strstr(void *arg)
  54. {
  55. char *result;
  56. const char *text = "abcdef";
  57. const char *expected;
  58. result = SDL_strstr(text, "");
  59. expected = text;
  60. SDLTest_AssertPass("Call to SDL_strstr(text, \"\")");
  61. SDLTest_AssertCheck(result == expected, "Check result, expected: %s, got: %s", expected, result);
  62. result = SDL_strstr(text, "abc");
  63. expected = text;
  64. SDLTest_AssertPass("Call to SDL_strstr(text, \"abc\")");
  65. SDLTest_AssertCheck(result == expected, "Check result, expected: %s, got: %s", expected, result);
  66. result = SDL_strstr(text, "bcd");
  67. expected = text+1;
  68. SDLTest_AssertPass("Call to SDL_strstr(text, \"bcd\")");
  69. SDLTest_AssertCheck(result == expected, "Check result, expected: %s, got: %s", expected, result);
  70. result = SDL_strstr(text, "xyz");
  71. expected = NULL;
  72. SDLTest_AssertPass("Call to SDL_strstr(text, \"xyz\")");
  73. SDLTest_AssertCheck(result == expected, "Check result, expected: (null), got: %s", result);
  74. result = SDL_strnstr(text, "", SDL_strlen(text));
  75. expected = text;
  76. SDLTest_AssertPass("Call to SDL_strnstr(text, \"\", SDL_strlen(text))");
  77. SDLTest_AssertCheck(result == expected, "Check result, expected: %s, got: %s", expected, result);
  78. result = SDL_strnstr(text, "abc", SDL_strlen(text));
  79. expected = text;
  80. SDLTest_AssertPass("Call to SDL_strnstr(text, \"abc\", SDL_strlen(text))");
  81. SDLTest_AssertCheck(result == expected, "Check result, expected: %s, got: %s", expected, result);
  82. result = SDL_strnstr(text, "bcd", SDL_strlen(text));
  83. expected = text+1;
  84. SDLTest_AssertPass("Call to SDL_strnstr(text, \"bcd\", SDL_strlen(text))");
  85. SDLTest_AssertCheck(result == expected, "Check result, expected: %s, got: %s", expected, result);
  86. result = SDL_strnstr(text, "bcd", 3);
  87. expected = NULL;
  88. SDLTest_AssertPass("Call to SDL_strnstr(text, \"bcd\", 3)");
  89. SDLTest_AssertCheck(result == expected, "Check result, expected: (null), got: %s", result);
  90. result = SDL_strnstr(text, "xyz", 3);
  91. expected = NULL;
  92. SDLTest_AssertPass("Call to SDL_strnstr(text, \"xyz\", 3)");
  93. SDLTest_AssertCheck(result == expected, "Check result, expected: (null), got: %s", result);
  94. result = SDL_strnstr(text, "xyz", SDL_strlen(text)*100000);
  95. expected = NULL;
  96. SDLTest_AssertPass("Call to SDL_strnstr(text, \"xyz\", SDL_strlen(text)*100000)");
  97. SDLTest_AssertCheck(result == expected, "Check result, expected: (null), got: %s", result);
  98. return TEST_COMPLETED;
  99. }
  100. #if defined(HAVE_WFORMAT) || defined(HAVE_WFORMAT_EXTRA_ARGS)
  101. #pragma GCC diagnostic push
  102. #ifdef HAVE_WFORMAT
  103. #pragma GCC diagnostic ignored "-Wformat"
  104. #endif
  105. #ifdef HAVE_WFORMAT_EXTRA_ARGS
  106. #pragma GCC diagnostic ignored "-Wformat-extra-args"
  107. #endif
  108. #endif
  109. /**
  110. * Call to SDL_snprintf
  111. */
  112. static int SDLCALL stdlib_snprintf(void *arg)
  113. {
  114. int result;
  115. int predicted;
  116. char text[1024];
  117. const char *expected, *expected2, *expected3, *expected4, *expected5;
  118. size_t size;
  119. result = SDL_snprintf(text, sizeof(text), "%s", "foo");
  120. expected = "foo";
  121. SDLTest_AssertPass("Call to SDL_snprintf(\"%%s\", \"foo\")");
  122. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  123. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  124. result = SDL_snprintf(text, sizeof(text), "%10sA", "foo");
  125. expected = " fooA";
  126. SDLTest_AssertPass("Call to SDL_snprintf(\"%%10sA\", \"foo\")");
  127. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  128. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  129. result = SDL_snprintf(text, sizeof(text), "%-10sA", "foo");
  130. expected = "foo A";
  131. SDLTest_AssertPass("Call to SDL_snprintf(\"%%-10sA\", \"foo\")");
  132. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  133. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  134. result = SDL_snprintf(text, sizeof(text), "%S", L"foo");
  135. expected = "foo";
  136. SDLTest_AssertPass("Call to SDL_snprintf(\"%%S\", \"foo\")");
  137. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  138. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  139. result = SDL_snprintf(text, sizeof(text), "%ls", L"foo");
  140. expected = "foo";
  141. SDLTest_AssertPass("Call to SDL_snprintf(\"%%ls\", \"foo\")");
  142. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  143. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  144. result = SDL_snprintf(text, 2, "%s", "foo");
  145. expected = "f";
  146. SDLTest_AssertPass("Call to SDL_snprintf(\"%%s\", \"foo\") with buffer size 2");
  147. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  148. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", result);
  149. result = SDL_snprintf(NULL, 0, "%s", "foo");
  150. SDLTest_AssertPass("Call to SDL_snprintf(NULL, 0, \"%%s\", \"foo\")");
  151. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", result);
  152. result = SDL_snprintf(text, 2, "%s\n", "foo");
  153. expected = "f";
  154. SDLTest_AssertPass("Call to SDL_snprintf(\"%%s\\n\", \"foo\") with buffer size 2");
  155. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  156. SDLTest_AssertCheck(result == 4, "Check result value, expected: 4, got: %d", result);
  157. result = SDL_snprintf(text, sizeof(text), "%f", 0.0);
  158. predicted = SDL_snprintf(NULL, 0, "%f", 0.0);
  159. expected = "0.000000";
  160. SDLTest_AssertPass("Call to SDL_snprintf(\"%%f\", 0.0)");
  161. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  162. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  163. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  164. result = SDL_snprintf(text, sizeof(text), "%f", 1.0);
  165. predicted = SDL_snprintf(NULL, 0, "%f", 1.0);
  166. expected = "1.000000";
  167. SDLTest_AssertPass("Call to SDL_snprintf(\"%%f\", 1.0)");
  168. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  169. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  170. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  171. result = SDL_snprintf(text, sizeof(text), "%.f", 1.0);
  172. predicted = SDL_snprintf(NULL, 0, "%.f", 1.0);
  173. expected = "1";
  174. SDLTest_AssertPass("Call to SDL_snprintf(\"%%.f\", 1.0)");
  175. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  176. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  177. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  178. result = SDL_snprintf(text, sizeof(text), "%#.f", 1.0);
  179. predicted = SDL_snprintf(NULL, 0, "%#.f", 1.0);
  180. expected = "1.";
  181. SDLTest_AssertPass("Call to SDL_snprintf(\"%%#.f\", 1.0)");
  182. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  183. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  184. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  185. result = SDL_snprintf(text, sizeof(text), "%f", 1.0 + 1.0 / 3.0);
  186. predicted = SDL_snprintf(NULL, 0, "%f", 1.0 + 1.0 / 3.0);
  187. expected = "1.333333";
  188. SDLTest_AssertPass("Call to SDL_snprintf(\"%%f\", 1.0 + 1.0 / 3.0)");
  189. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  190. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  191. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  192. result = SDL_snprintf(text, sizeof(text), "%+f", 1.0 + 1.0 / 3.0);
  193. predicted = SDL_snprintf(NULL, 0, "%+f", 1.0 + 1.0 / 3.0);
  194. expected = "+1.333333";
  195. SDLTest_AssertPass("Call to SDL_snprintf(\"%%+f\", 1.0 + 1.0 / 3.0)");
  196. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  197. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  198. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  199. result = SDL_snprintf(text, sizeof(text), "%.2f", 1.0 + 1.0 / 3.0);
  200. predicted = SDL_snprintf(NULL, 0, "%.2f", 1.0 + 1.0 / 3.0);
  201. expected = "1.33";
  202. SDLTest_AssertPass("Call to SDL_snprintf(\"%%.2f\", 1.0 + 1.0 / 3.0)");
  203. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  204. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  205. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  206. result = SDL_snprintf(text, sizeof(text), "%6.2f", 1.0 + 1.0 / 3.0);
  207. predicted = SDL_snprintf(NULL, 0, "%6.2f", 1.0 + 1.0 / 3.0);
  208. expected = " 1.33";
  209. SDLTest_AssertPass("Call to SDL_snprintf(\"%%6.2f\", 1.0 + 1.0 / 3.0)");
  210. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  211. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  212. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  213. result = SDL_snprintf(text, sizeof(text), "%06.2f", 1.0 + 1.0 / 3.0);
  214. predicted = SDL_snprintf(NULL, 0, "%06.2f", 1.0 + 1.0 / 3.0);
  215. expected = "001.33";
  216. SDLTest_AssertPass("Call to SDL_snprintf(\"%%06.2f\", 1.0 + 1.0 / 3.0)");
  217. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  218. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  219. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  220. result = SDL_snprintf(text, 5, "%06.2f", 1.0 + 1.0 / 3.0);
  221. expected = "001.";
  222. SDLTest_AssertPass("Call to SDL_snprintf(\"%%06.2f\", 1.0 + 1.0 / 3.0) with buffer size 5");
  223. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  224. SDLTest_AssertCheck(result == 6, "Check result value, expected: 6, got: %d", result);
  225. result = SDL_snprintf(text, sizeof(text), "%06.0f", ((double)SDL_MAX_SINT64) * 1.5);
  226. predicted = SDL_snprintf(NULL, 0, "%06.0f", ((double)SDL_MAX_SINT64) * 1.5);
  227. expected = "13835058055282163712";
  228. SDLTest_AssertPass("Call to SDL_snprintf(\"%%06.2f\", SDL_MAX_SINT64 * 1.5)");
  229. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  230. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int)SDL_strlen(text), result);
  231. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  232. {
  233. static struct
  234. {
  235. int precision;
  236. float value;
  237. const char *expected_f;
  238. const char *expected_g;
  239. } f_and_g_test_cases[] = {
  240. { 6, 100.0f, "100.000000", "100" },
  241. { 6, -100.0f, "-100.000000", "-100" },
  242. { 6, 100.75f, "100.750000", "100.75" },
  243. { 6, -100.75f, "-100.750000", "-100.75" },
  244. { 6, ((100 * 60 * 1000) / 1001) / 100.0f, "59.939999", "59.94" },
  245. { 6, -((100 * 60 * 1000) / 1001) / 100.0f, "-59.939999", "-59.94" },
  246. { 6, ((100 * 120 * 1000) / 1001) / 100.0f, "119.879997", "119.88" },
  247. { 6, -((100 * 120 * 1000) / 1001) / 100.0f, "-119.879997", "-119.88" },
  248. { 6, 0.9999999f, "1.000000", "1" },
  249. { 6, -0.9999999f, "-1.000000", "-1" },
  250. { 5, 9.999999f, "10.00000", "10" },
  251. { 5, -9.999999f, "-10.00000", "-10" },
  252. };
  253. int i;
  254. for (i = 0; i < SDL_arraysize(f_and_g_test_cases); ++i) {
  255. float value = f_and_g_test_cases[i].value;
  256. int prec = f_and_g_test_cases[i].precision;
  257. result = SDL_snprintf(text, sizeof(text), "%.*f", prec, value);
  258. predicted = SDL_snprintf(NULL, 0, "%.*f", prec, value);
  259. expected = f_and_g_test_cases[i].expected_f;
  260. SDLTest_AssertPass("Call to SDL_snprintf(\"%%.5f\", %g)", value);
  261. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  262. SDLTest_AssertCheck(result == SDL_strlen(expected), "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  263. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  264. result = SDL_snprintf(text, sizeof(text), "%g", value);
  265. predicted = SDL_snprintf(NULL, 0, "%g", value);
  266. expected = f_and_g_test_cases[i].expected_g;
  267. SDLTest_AssertPass("Call to SDL_snprintf(\"%%g\", %g)", value);
  268. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  269. SDLTest_AssertCheck(result == SDL_strlen(expected), "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  270. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  271. }
  272. }
  273. size = 64;
  274. result = SDL_snprintf(text, sizeof(text), "%zu %s", size, "test");
  275. expected = "64 test";
  276. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"%%zu %%s\", size, \"test\")");
  277. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  278. SDLTest_AssertCheck(result == 7, "Check result value, expected: 7, got: %d", result);
  279. result = SDL_snprintf(text, sizeof(text), "%p", (void *)0x1234abcd);
  280. expected = "0x1234abcd";
  281. expected2 = "1234ABCD";
  282. expected3 = "000000001234ABCD";
  283. expected4 = "1234abcd";
  284. expected5 = "000000001234abcd";
  285. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"%%p\", 0x1234abcd)");
  286. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0 ||
  287. SDL_strcmp(text, expected2) == 0 ||
  288. SDL_strcmp(text, expected3) == 0 ||
  289. SDL_strcmp(text, expected4) == 0 ||
  290. SDL_strcmp(text, expected5) == 0,
  291. "Check text, expected: '%s', got: '%s'", expected, text);
  292. SDLTest_AssertCheck(result == SDL_strlen(expected) ||
  293. result == SDL_strlen(expected2) ||
  294. result == SDL_strlen(expected3) ||
  295. result == SDL_strlen(expected4) ||
  296. result == SDL_strlen(expected5),
  297. "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  298. result = SDL_snprintf(text, sizeof(text), "A %p B", (void *)0x1234abcd);
  299. expected = "A 0x1234abcd B";
  300. expected2 = "A 1234ABCD B";
  301. expected3 = "A 000000001234ABCD B";
  302. expected4 = "A 1234abcd B";
  303. expected5 = "A 000000001234abcd B";
  304. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"A %%p B\", 0x1234abcd)");
  305. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0 ||
  306. SDL_strcmp(text, expected2) == 0 ||
  307. SDL_strcmp(text, expected3) == 0 ||
  308. SDL_strcmp(text, expected4) == 0 ||
  309. SDL_strcmp(text, expected5) == 0,
  310. "Check text, expected: '%s', got: '%s'", expected, text);
  311. SDLTest_AssertCheck(result == SDL_strlen(expected) ||
  312. result == SDL_strlen(expected2) ||
  313. result == SDL_strlen(expected3) ||
  314. result == SDL_strlen(expected4) ||
  315. result == SDL_strlen(expected5),
  316. "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  317. const bool is_at_least_64bit_system = sizeof(void *) >= 8;
  318. if (is_at_least_64bit_system) {
  319. result = SDL_snprintf(text, sizeof(text), "%p", (void *)SDL_SINT64_C(0x1ba07bddf60));
  320. expected = "0x1ba07bddf60";
  321. expected2 = "000001BA07BDDF60";
  322. expected3 = "000001ba07bddf60";
  323. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"%%p\", 0x1ba07bddf60)");
  324. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0 ||
  325. SDL_strcmp(text, expected2) == 0 ||
  326. SDL_strcmp(text, expected3) == 0,
  327. "Check text, expected: '%s', got: '%s'", expected, text);
  328. SDLTest_AssertCheck(result == SDL_strlen(expected) ||
  329. result == SDL_strlen(expected2) ||
  330. result == SDL_strlen(expected3),
  331. "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  332. }
  333. return TEST_COMPLETED;
  334. }
  335. /**
  336. * Call to SDL_swprintf
  337. */
  338. static int SDLCALL stdlib_swprintf(void *arg)
  339. {
  340. int result;
  341. int predicted;
  342. wchar_t text[1024];
  343. const wchar_t *expected;
  344. size_t size;
  345. result = SDL_swprintf(text, SDL_arraysize(text), L"%s", "hello, world");
  346. expected = L"hello, world";
  347. SDLTest_AssertPass("Call to SDL_swprintf(\"%%s\", \"hello, world\")");
  348. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  349. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  350. result = SDL_swprintf(text, 2, L"%s", "hello, world");
  351. expected = L"h";
  352. SDLTest_AssertPass("Call to SDL_swprintf(\"%%s\", \"hello, world\") with buffer size 2");
  353. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  354. SDLTest_AssertCheck(result == 12, "Check result value, expected: 12, got: %d", result);
  355. result = SDL_swprintf(NULL, 0, L"%s", "hello, world");
  356. SDLTest_AssertPass("Call to SDL_swprintf(NULL, 0, \"%%s\", \"hello, world\")");
  357. SDLTest_AssertCheck(result == 12, "Check result value, expected: 12, got: %d", result);
  358. result = SDL_swprintf(text, SDL_arraysize(text), L"%s", "foo");
  359. expected = L"foo";
  360. SDLTest_AssertPass("Call to SDL_swprintf(\"%%s\", \"foo\")");
  361. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  362. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  363. result = SDL_swprintf(text, 2, L"%s", "foo");
  364. expected = L"f";
  365. SDLTest_AssertPass("Call to SDL_swprintf(\"%%s\", \"foo\") with buffer size 2");
  366. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  367. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", result);
  368. result = SDL_swprintf(NULL, 0, L"%s", "foo");
  369. SDLTest_AssertPass("Call to SDL_swprintf(NULL, 0, \"%%s\", \"foo\")");
  370. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", result);
  371. result = SDL_swprintf(text, 2, L"%s\n", "foo");
  372. expected = L"f";
  373. SDLTest_AssertPass("Call to SDL_swprintf(\"%%s\\n\", \"foo\") with buffer size 2");
  374. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  375. SDLTest_AssertCheck(result == 4, "Check result value, expected: 4, got: %d", result);
  376. result = SDL_swprintf(text, sizeof(text), L"%f", 0.0);
  377. predicted = SDL_swprintf(NULL, 0, L"%f", 0.0);
  378. expected = L"0.000000";
  379. SDLTest_AssertPass("Call to SDL_swprintf(\"%%f\", 0.0)");
  380. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  381. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  382. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  383. result = SDL_swprintf(text, sizeof(text), L"%f", 1.0);
  384. predicted = SDL_swprintf(NULL, 0, L"%f", 1.0);
  385. expected = L"1.000000";
  386. SDLTest_AssertPass("Call to SDL_swprintf(\"%%f\", 1.0)");
  387. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  388. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  389. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  390. result = SDL_swprintf(text, sizeof(text), L"%.f", 1.0);
  391. predicted = SDL_swprintf(NULL, 0, L"%.f", 1.0);
  392. expected = L"1";
  393. SDLTest_AssertPass("Call to SDL_swprintf(\"%%.f\", 1.0)");
  394. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  395. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  396. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  397. result = SDL_swprintf(text, sizeof(text), L"%#.f", 1.0);
  398. predicted = SDL_swprintf(NULL, 0, L"%#.f", 1.0);
  399. expected = L"1.";
  400. SDLTest_AssertPass("Call to SDL_swprintf(\"%%#.f\", 1.0)");
  401. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  402. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  403. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  404. result = SDL_swprintf(text, sizeof(text), L"%f", 1.0 + 1.0 / 3.0);
  405. predicted = SDL_swprintf(NULL, 0, L"%f", 1.0 + 1.0 / 3.0);
  406. expected = L"1.333333";
  407. SDLTest_AssertPass("Call to SDL_swprintf(\"%%f\", 1.0 + 1.0 / 3.0)");
  408. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  409. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  410. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  411. result = SDL_swprintf(text, sizeof(text), L"%+f", 1.0 + 1.0 / 3.0);
  412. predicted = SDL_swprintf(NULL, 0, L"%+f", 1.0 + 1.0 / 3.0);
  413. expected = L"+1.333333";
  414. SDLTest_AssertPass("Call to SDL_swprintf(\"%%+f\", 1.0 + 1.0 / 3.0)");
  415. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  416. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  417. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  418. result = SDL_swprintf(text, sizeof(text), L"%.2f", 1.0 + 1.0 / 3.0);
  419. predicted = SDL_swprintf(NULL, 0, L"%.2f", 1.0 + 1.0 / 3.0);
  420. expected = L"1.33";
  421. SDLTest_AssertPass("Call to SDL_swprintf(\"%%.2f\", 1.0 + 1.0 / 3.0)");
  422. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  423. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  424. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  425. result = SDL_swprintf(text, sizeof(text), L"%6.2f", 1.0 + 1.0 / 3.0);
  426. predicted = SDL_swprintf(NULL, 0, L"%6.2f", 1.0 + 1.0 / 3.0);
  427. expected = L" 1.33";
  428. SDLTest_AssertPass("Call to SDL_swprintf(\"%%6.2f\", 1.0 + 1.0 / 3.0)");
  429. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  430. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  431. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  432. result = SDL_swprintf(text, sizeof(text), L"%06.2f", 1.0 + 1.0 / 3.0);
  433. predicted = SDL_swprintf(NULL, 0, L"%06.2f", 1.0 + 1.0 / 3.0);
  434. expected = L"001.33";
  435. SDLTest_AssertPass("Call to SDL_swprintf(\"%%06.2f\", 1.0 + 1.0 / 3.0)");
  436. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  437. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  438. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  439. result = SDL_swprintf(text, 5, L"%06.2f", 1.0 + 1.0 / 3.0);
  440. expected = L"001.";
  441. SDLTest_AssertPass("Call to SDL_swprintf(\"%%06.2f\", 1.0 + 1.0 / 3.0) with buffer size 5");
  442. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  443. SDLTest_AssertCheck(result == 6, "Check result value, expected: 6, got: %d", result);
  444. {
  445. static struct
  446. {
  447. float value;
  448. const wchar_t *expected_f;
  449. const wchar_t *expected_g;
  450. } f_and_g_test_cases[] = {
  451. { 100.0f, L"100.000000", L"100" },
  452. { -100.0f, L"-100.000000", L"-100" },
  453. { 100.75f, L"100.750000", L"100.75" },
  454. { -100.75f, L"-100.750000", L"-100.75" },
  455. { ((100 * 60 * 1000) / 1001) / 100.0f, L"59.939999", L"59.94" },
  456. { -((100 * 60 * 1000) / 1001) / 100.0f, L"-59.939999", L"-59.94" },
  457. { ((100 * 120 * 1000) / 1001) / 100.0f, L"119.879997", L"119.88" },
  458. { -((100 * 120 * 1000) / 1001) / 100.0f, L"-119.879997", L"-119.88" },
  459. { 9.9999999f, L"10.000000", L"10" },
  460. { -9.9999999f, L"-10.000000", L"-10" },
  461. };
  462. int i;
  463. for (i = 0; i < SDL_arraysize(f_and_g_test_cases); ++i) {
  464. float value = f_and_g_test_cases[i].value;
  465. result = SDL_swprintf(text, sizeof(text), L"%f", value);
  466. predicted = SDL_swprintf(NULL, 0, L"%f", value);
  467. expected = f_and_g_test_cases[i].expected_f;
  468. SDLTest_AssertPass("Call to SDL_swprintf(\"%%f\", %g)", value);
  469. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  470. SDLTest_AssertCheck(result == SDL_wcslen(expected), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(expected), result);
  471. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  472. result = SDL_swprintf(text, sizeof(text), L"%g", value);
  473. predicted = SDL_swprintf(NULL, 0, L"%g", value);
  474. expected = f_and_g_test_cases[i].expected_g;
  475. SDLTest_AssertPass("Call to SDL_swprintf(\"%%g\", %g)", value);
  476. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  477. SDLTest_AssertCheck(result == SDL_wcslen(expected), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(expected), result);
  478. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  479. }
  480. }
  481. size = 64;
  482. result = SDL_swprintf(text, sizeof(text), L"%zu %s", size, "test");
  483. expected = L"64 test";
  484. SDLTest_AssertPass("Call to SDL_swprintf(text, sizeof(text), \"%%zu %%s\", size, \"test\")");
  485. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  486. SDLTest_AssertCheck(result == 7, "Check result value, expected: 7, got: %d", result);
  487. return TEST_COMPLETED;
  488. }
  489. #if defined(HAVE_WFORMAT) || defined(HAVE_WFORMAT_EXTRA_ARGS)
  490. #pragma GCC diagnostic pop
  491. #endif
  492. /**
  493. * Call to SDL_GetEnvironmentVariable() and SDL_SetEnvironmentVariable()
  494. */
  495. static int SDLCALL stdlib_getsetenv(void *arg)
  496. {
  497. SDL_Environment *env = SDL_GetEnvironment();
  498. const int nameLen = 16;
  499. char name[17];
  500. int counter;
  501. int result;
  502. char *value1;
  503. char *value2;
  504. char *expected;
  505. int overwrite;
  506. const char *text;
  507. /* Create a random name. This tests SDL_GetEnvironmentVariable, since we need to */
  508. /* make sure the variable is not set yet (it shouldn't). */
  509. do {
  510. for (counter = 0; counter < nameLen; counter++) {
  511. name[counter] = (char)SDLTest_RandomIntegerInRange(65, 90);
  512. }
  513. name[nameLen] = '\0';
  514. text = SDL_GetEnvironmentVariable(env, name);
  515. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%s')", name);
  516. if (text) {
  517. SDLTest_Log("Expected: NULL, Got: '%s' (%i)", text, (int)SDL_strlen(text));
  518. }
  519. } while (text);
  520. /* Create random values to set */
  521. value1 = SDLTest_RandomAsciiStringOfSize(10);
  522. value2 = SDLTest_RandomAsciiStringOfSize(10);
  523. /* Set value 1 without overwrite */
  524. overwrite = 0;
  525. expected = value1;
  526. result = SDL_SetEnvironmentVariable(env, name, value1, overwrite);
  527. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s','%s', %i)", name, value1, overwrite);
  528. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  529. /* Check value */
  530. text = SDL_GetEnvironmentVariable(env, name);
  531. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%s')", name);
  532. SDLTest_AssertCheck(text != NULL, "Verify returned text is not NULL");
  533. if (text != NULL) {
  534. SDLTest_AssertCheck(
  535. SDL_strcmp(text, expected) == 0,
  536. "Verify returned text, expected: %s, got: %s",
  537. expected,
  538. text);
  539. }
  540. /* Set value 2 with overwrite */
  541. overwrite = 1;
  542. expected = value2;
  543. result = SDL_SetEnvironmentVariable(env, name, value2, overwrite);
  544. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s','%s', %i)", name, value2, overwrite);
  545. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  546. /* Check value */
  547. text = SDL_GetEnvironmentVariable(env, name);
  548. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%s')", name);
  549. SDLTest_AssertCheck(text != NULL, "Verify returned text is not NULL");
  550. if (text != NULL) {
  551. SDLTest_AssertCheck(
  552. SDL_strcmp(text, expected) == 0,
  553. "Verify returned text, expected: %s, got: %s",
  554. expected,
  555. text);
  556. }
  557. /* Set value 1 without overwrite */
  558. overwrite = 0;
  559. expected = value2;
  560. result = SDL_SetEnvironmentVariable(env, name, value1, overwrite);
  561. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s','%s', %i)", name, value1, overwrite);
  562. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  563. /* Check value */
  564. text = SDL_GetEnvironmentVariable(env, name);
  565. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%s')", name);
  566. SDLTest_AssertCheck(text != NULL, "Verify returned text is not NULL");
  567. if (text != NULL) {
  568. SDLTest_AssertCheck(
  569. SDL_strcmp(text, expected) == 0,
  570. "Verify returned text, expected: %s, got: %s",
  571. expected,
  572. text);
  573. }
  574. /* Set value 1 with overwrite */
  575. overwrite = 1;
  576. expected = value1;
  577. result = SDL_SetEnvironmentVariable(env, name, value1, overwrite);
  578. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s','%s', %i)", name, value1, overwrite);
  579. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  580. /* Check value */
  581. text = SDL_GetEnvironmentVariable(env, name);
  582. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%s')", name);
  583. SDLTest_AssertCheck(text != NULL, "Verify returned text is not NULL");
  584. if (text != NULL) {
  585. SDLTest_AssertCheck(
  586. SDL_strcmp(text, expected) == 0,
  587. "Verify returned text, expected: %s, got: %s",
  588. expected,
  589. text);
  590. }
  591. /* Verify setenv() with empty string vs unsetenv() */
  592. result = SDL_SetEnvironmentVariable(env, "FOO", "1", 1);
  593. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, 'FOO','1', 1)");
  594. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  595. expected = "1";
  596. text = SDL_GetEnvironmentVariable(env, "FOO");
  597. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, 'FOO')");
  598. SDLTest_AssertCheck(text && SDL_strcmp(text, expected) == 0, "Verify returned text, expected: %s, got: %s", expected, text);
  599. result = SDL_SetEnvironmentVariable(env, "FOO", "", 1);
  600. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, 'FOO','', 1)");
  601. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  602. expected = "";
  603. text = SDL_GetEnvironmentVariable(env, "FOO");
  604. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, 'FOO')");
  605. SDLTest_AssertCheck(text && SDL_strcmp(text, expected) == 0, "Verify returned text, expected: '%s', got: '%s'", expected, text);
  606. result = SDL_UnsetEnvironmentVariable(env, "FOO");
  607. SDLTest_AssertPass("Call to SDL_UnsetEnvironmentVariable(env, 'FOO')");
  608. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  609. text = SDL_GetEnvironmentVariable(env, "FOO");
  610. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, 'FOO')");
  611. SDLTest_AssertCheck(text == NULL, "Verify returned text, expected: (null), got: %s", text);
  612. result = SDL_SetEnvironmentVariable(env, "FOO", "0", 0);
  613. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, 'FOO','0', 0)");
  614. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  615. expected = "0";
  616. text = SDL_GetEnvironmentVariable(env, "FOO");
  617. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, 'FOO')");
  618. SDLTest_AssertCheck(text && SDL_strcmp(text, expected) == 0, "Verify returned text, expected: %s, got: %s", expected, text);
  619. /* Negative cases */
  620. for (overwrite = 0; overwrite <= 1; overwrite++) {
  621. result = SDL_SetEnvironmentVariable(env, NULL, value1, overwrite);
  622. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, NULL,'%s', %i)", value1, overwrite);
  623. SDLTest_AssertCheck(result == false, "Check result, expected: 0, got: %i", result);
  624. result = SDL_SetEnvironmentVariable(env, "", value1, overwrite);
  625. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '','%s', %i)", value1, overwrite);
  626. SDLTest_AssertCheck(result == false, "Check result, expected: 0, got: %i", result);
  627. result = SDL_SetEnvironmentVariable(env, "=", value1, overwrite);
  628. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '=','%s', %i)", value1, overwrite);
  629. SDLTest_AssertCheck(result == false, "Check result, expected: 0, got: %i", result);
  630. result = SDL_SetEnvironmentVariable(env, name, NULL, overwrite);
  631. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s', NULL, %i)", name, overwrite);
  632. SDLTest_AssertCheck(result == false, "Check result, expected: 0, got: %i", result);
  633. }
  634. /* Clean up */
  635. SDL_free(value1);
  636. SDL_free(value2);
  637. return TEST_COMPLETED;
  638. }
  639. #if defined(HAVE_WFORMAT) || defined(HAVE_WFORMAT_EXTRA_ARGS)
  640. #pragma GCC diagnostic push
  641. #ifdef HAVE_WFORMAT
  642. #pragma GCC diagnostic ignored "-Wformat"
  643. #endif
  644. #ifdef HAVE_WFORMAT_EXTRA_ARGS
  645. #pragma GCC diagnostic ignored "-Wformat-extra-args"
  646. #endif
  647. #endif
  648. #define FMT_PRILLd "%" SDL_PRILLd
  649. #define FMT_PRILLdn "%" SDL_PRILLd "%" SDL_PRILL_PREFIX "n"
  650. #define FMT_PRILLu "%" SDL_PRILLu
  651. /**
  652. * Call to SDL_sscanf
  653. */
  654. static int SDLCALL stdlib_sscanf(void *arg)
  655. {
  656. int output;
  657. int result;
  658. int length;
  659. int expected_output;
  660. int expected_result;
  661. short short_output, expected_short_output, short_length;
  662. long long_output, expected_long_output, long_length;
  663. long long long_long_output, expected_long_long_output, long_long_length;
  664. size_t size_output, expected_size_output;
  665. void *ptr_output, *expected_ptr_output;
  666. char text[128], text2[128];
  667. unsigned int r = 0, g = 0, b = 0;
  668. expected_output = output = 123;
  669. expected_result = -1;
  670. result = SDL_sscanf("", "%i", &output);
  671. SDLTest_AssertPass("Call to SDL_sscanf(\"\", \"%%i\", &output)");
  672. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  673. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  674. expected_output = output = 123;
  675. expected_result = 0;
  676. result = SDL_sscanf("a", "%i", &output);
  677. SDLTest_AssertPass("Call to SDL_sscanf(\"a\", \"%%i\", &output)");
  678. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  679. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  680. output = 123;
  681. length = 0;
  682. expected_output = 2;
  683. expected_result = 1;
  684. result = SDL_sscanf("2", "%i%n", &output, &length);
  685. SDLTest_AssertPass("Call to SDL_sscanf(\"2\", \"%%i%%n\", &output, &length)");
  686. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  687. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  688. SDLTest_AssertCheck(length == 1, "Check length, expected: 1, got: %i", length);
  689. output = 123;
  690. length = 0;
  691. expected_output = 0xa;
  692. expected_result = 1;
  693. result = SDL_sscanf("aa", "%1x%n", &output, &length);
  694. SDLTest_AssertPass("Call to SDL_sscanf(\"aa\", \"%%1x%%n\", &output, &length)");
  695. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  696. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  697. SDLTest_AssertCheck(length == 1, "Check length, expected: 1, got: %i", length);
  698. expected_result = 3;
  699. result = SDL_sscanf("#026", "#%1x%1x%1x", &r, &g, &b);
  700. SDLTest_AssertPass("Call to SDL_sscanf(\"#026\", \"#%%1x%%1x%%1x\", &r, &g, &b)");
  701. expected_output = 0;
  702. SDLTest_AssertCheck(r == expected_output, "Check output for r, expected: %i, got: %i", expected_output, r);
  703. expected_output = 2;
  704. SDLTest_AssertCheck(g == expected_output, "Check output for g, expected: %i, got: %i", expected_output, g);
  705. expected_output = 6;
  706. SDLTest_AssertCheck(b == expected_output, "Check output for b, expected: %i, got: %i", expected_output, b);
  707. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  708. #define SIZED_TEST_CASE(type, var, printf_specifier, scanf_specifier) \
  709. var##_output = 123; \
  710. var##_length = 0; \
  711. expected_##var##_output = (type)(((unsigned type)(~0)) >> 1); \
  712. expected_result = 1; \
  713. result = SDL_snprintf(text, sizeof(text), printf_specifier, expected_##var##_output); \
  714. result = SDL_sscanf(text, scanf_specifier, &var##_output, &var##_length); \
  715. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", %s, &output, &length)", text, #scanf_specifier); \
  716. SDLTest_AssertCheck(expected_##var##_output == var##_output, "Check output, expected: " printf_specifier ", got: " printf_specifier, expected_##var##_output, var##_output); \
  717. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result); \
  718. SDLTest_AssertCheck(var##_length == (type)SDL_strlen(text), "Check length, expected: %i, got: %i", (int)SDL_strlen(text), (int)var##_length); \
  719. \
  720. var##_output = 123; \
  721. var##_length = 0; \
  722. expected_##var##_output = ~(type)(((unsigned type)(~0)) >> 1); \
  723. expected_result = 1; \
  724. result = SDL_snprintf(text, sizeof(text), printf_specifier, expected_##var##_output); \
  725. result = SDL_sscanf(text, scanf_specifier, &var##_output, &var##_length); \
  726. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", %s, &output, &length)", text, #scanf_specifier); \
  727. SDLTest_AssertCheck(expected_##var##_output == var##_output, "Check output, expected: " printf_specifier ", got: " printf_specifier, expected_##var##_output, var##_output); \
  728. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result); \
  729. SDLTest_AssertCheck(var##_length == (type)SDL_strlen(text), "Check length, expected: %i, got: %i", (int)SDL_strlen(text), (int)var##_length); \
  730. SIZED_TEST_CASE(short, short, "%hd", "%hd%hn")
  731. SIZED_TEST_CASE(long, long, "%ld", "%ld%ln")
  732. SIZED_TEST_CASE(long long, long_long, FMT_PRILLd, FMT_PRILLdn)
  733. size_output = 123;
  734. expected_size_output = ~((size_t)0);
  735. expected_result = 1;
  736. result = SDL_snprintf(text, sizeof(text), "%zu", expected_size_output);
  737. result = SDL_sscanf(text, "%zu", &size_output);
  738. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", \"%%zu\", &output)", text);
  739. SDLTest_AssertCheck(expected_size_output == size_output, "Check output, expected: %zu, got: %zu", expected_size_output, size_output);
  740. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  741. ptr_output = (void *)123;
  742. expected_ptr_output = (void *)0x1234567;
  743. expected_result = 1;
  744. result = SDL_snprintf(text, sizeof(text), "%p", expected_ptr_output);
  745. result = SDL_sscanf(text, "%p", &ptr_output);
  746. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", \"%%p\", &output)", text);
  747. SDLTest_AssertCheck(expected_ptr_output == ptr_output, "Check output, expected: %p, got: %p", expected_ptr_output, ptr_output);
  748. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  749. expected_result = 1;
  750. text[0] = '\0';
  751. result = SDL_sscanf("abc def", "%s", text);
  752. SDLTest_AssertPass("Call to SDL_sscanf(\"abc def\", \"%%s\", text)");
  753. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  754. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  755. expected_result = 1;
  756. text[0] = '\0';
  757. result = SDL_sscanf("abc,def", "%s", text);
  758. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%s\", text)");
  759. SDLTest_AssertCheck(SDL_strcmp(text, "abc,def") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  760. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  761. expected_result = 1;
  762. text[0] = '\0';
  763. result = SDL_sscanf("abc,def", "%[cba]", text);
  764. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[cba]\", text)");
  765. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  766. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  767. expected_result = 1;
  768. text[0] = '\0';
  769. result = SDL_sscanf("abc,def", "%[a-z]", text);
  770. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[z-a]\", text)");
  771. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  772. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  773. expected_result = 1;
  774. text[0] = '\0';
  775. result = SDL_sscanf("abc,def", "%[^,]", text);
  776. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[^,]\", text)");
  777. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  778. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  779. expected_result = 0;
  780. text[0] = '\0';
  781. result = SDL_sscanf("abc,def", "%[A-Z]", text);
  782. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[A-Z]\", text)");
  783. SDLTest_AssertCheck(SDL_strcmp(text, "") == 0, "Check output, expected: \"\", got: \"%s\"", text);
  784. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  785. expected_result = 2;
  786. text[0] = '\0';
  787. text2[0] = '\0';
  788. result = SDL_sscanf("abc,def", "%[abc],%[def]", text, text2);
  789. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[abc],%%[def]\", text)");
  790. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  791. SDLTest_AssertCheck(SDL_strcmp(text2, "def") == 0, "Check output, expected: \"def\", got: \"%s\"", text2);
  792. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  793. expected_result = 2;
  794. text[0] = '\0';
  795. text2[0] = '\0';
  796. result = SDL_sscanf("abc,def", "%[abc]%*[,]%[def]", text, text2);
  797. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[abc]%%*[,]%%[def]\", text)");
  798. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  799. SDLTest_AssertCheck(SDL_strcmp(text2, "def") == 0, "Check output, expected: \"def\", got: \"%s\"", text2);
  800. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  801. expected_result = 2;
  802. text[0] = '\0';
  803. text2[0] = '\0';
  804. result = SDL_sscanf("abc def", "%[abc] %[def]", text, text2);
  805. SDLTest_AssertPass("Call to SDL_sscanf(\"abc def\", \"%%[abc] %%[def]\", text)");
  806. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  807. SDLTest_AssertCheck(SDL_strcmp(text2, "def") == 0, "Check output, expected: \"def\", got: \"%s\"", text2);
  808. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  809. expected_result = 1;
  810. text[0] = '\0';
  811. result = SDL_sscanf("abc123XYZ", "%[a-zA-Z0-9]", text);
  812. SDLTest_AssertPass("Call to SDL_sscanf(\"abc123XYZ\", \"%%[a-zA-Z0-9]\", text)");
  813. SDLTest_AssertCheck(SDL_strcmp(text, "abc123XYZ") == 0, "Check output, expected: \"abc123XYZ\", got: \"%s\"", text);
  814. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  815. return TEST_COMPLETED;
  816. }
  817. #if defined(HAVE_WFORMAT) || defined(HAVE_WFORMAT_EXTRA_ARGS)
  818. #pragma GCC diagnostic pop
  819. #endif
  820. #ifdef _WIN64
  821. #define SIZE_FORMAT "I64u"
  822. #elif defined(SDL_PLATFORM_WIN32)
  823. #define SIZE_FORMAT "I32u"
  824. #else
  825. #define SIZE_FORMAT "zu"
  826. #endif
  827. /**
  828. * Call to SDL_aligned_alloc
  829. */
  830. static int SDLCALL stdlib_aligned_alloc(void *arg)
  831. {
  832. size_t i, alignment;
  833. void *ptr;
  834. for (i = 0; i < 2*sizeof(void *); ++i) {
  835. SDLTest_AssertPass("Call to SDL_aligned_alloc(%"SIZE_FORMAT")", i);
  836. ptr = SDL_aligned_alloc(i, 1);
  837. if (i < sizeof(void *)) {
  838. alignment = sizeof(void *);
  839. } else {
  840. alignment = i;
  841. }
  842. SDLTest_AssertCheck(ptr != NULL, "Check output, expected non-NULL, got: %p", ptr);
  843. SDLTest_AssertCheck((((size_t)ptr) % alignment) == 0, "Check output, expected aligned pointer, actual offset: %"SIZE_FORMAT, (((size_t)ptr) % alignment));
  844. if (ptr != NULL) {
  845. SDLTest_AssertPass("Filling memory to alignment value");
  846. SDL_memset(ptr, 0xAA, alignment);
  847. SDL_aligned_free(ptr);
  848. }
  849. }
  850. return TEST_COMPLETED;
  851. }
  852. typedef struct
  853. {
  854. size_t a;
  855. size_t b;
  856. size_t result;
  857. bool status;
  858. } overflow_test;
  859. static const overflow_test multiplications[] = {
  860. { 1, 1, 1, true },
  861. { 0, 0, 0, true },
  862. { SDL_SIZE_MAX, 0, 0, true },
  863. { SDL_SIZE_MAX, 1, SDL_SIZE_MAX, true },
  864. { SDL_SIZE_MAX / 2, 2, SDL_SIZE_MAX - (SDL_SIZE_MAX % 2), true },
  865. { SDL_SIZE_MAX / 23, 23, SDL_SIZE_MAX - (SDL_SIZE_MAX % 23), true },
  866. { (SDL_SIZE_MAX / 2) + 1, 2, 0, false },
  867. { (SDL_SIZE_MAX / 23) + 42, 23, 0, false },
  868. { SDL_SIZE_MAX, SDL_SIZE_MAX, 0, false },
  869. };
  870. static const overflow_test additions[] = {
  871. { 1, 1, 2, true },
  872. { 0, 0, 0, true },
  873. { SDL_SIZE_MAX, 0, SDL_SIZE_MAX, true },
  874. { SDL_SIZE_MAX - 1, 1, SDL_SIZE_MAX, true },
  875. { SDL_SIZE_MAX - 42, 23, SDL_SIZE_MAX - (42 - 23), true },
  876. { SDL_SIZE_MAX, 1, 0, false },
  877. { SDL_SIZE_MAX, 23, 0, false },
  878. { SDL_SIZE_MAX, SDL_SIZE_MAX, 0, false },
  879. };
  880. static int SDLCALL
  881. stdlib_overflow(void *arg)
  882. {
  883. size_t i;
  884. size_t useBuiltin;
  885. for (useBuiltin = 0; useBuiltin < 2; useBuiltin++) {
  886. if (useBuiltin) {
  887. SDLTest_Log("Using gcc/clang builtins if possible");
  888. } else {
  889. SDLTest_Log("Not using gcc/clang builtins");
  890. }
  891. for (i = 0; i < SDL_arraysize(multiplications); i++) {
  892. const overflow_test *t = &multiplications[i];
  893. int status;
  894. size_t result = ~t->result;
  895. if (useBuiltin) {
  896. status = SDL_size_mul_check_overflow(t->a, t->b, &result);
  897. } else {
  898. /* This disables the macro that tries to use a gcc/clang
  899. * builtin, so we test the fallback implementation instead. */
  900. status = (SDL_size_mul_check_overflow)(t->a, t->b, &result);
  901. }
  902. if (t->status) {
  903. SDLTest_AssertCheck(status,
  904. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should succeed",
  905. t->a, t->b);
  906. SDLTest_AssertCheck(result == t->result,
  907. "(%" SIZE_FORMAT " * %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  908. t->a, t->b, t->result, result);
  909. } else {
  910. SDLTest_AssertCheck(!status,
  911. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should fail",
  912. t->a, t->b);
  913. }
  914. if (t->a == t->b) {
  915. continue;
  916. }
  917. result = ~t->result;
  918. if (useBuiltin) {
  919. status = SDL_size_mul_check_overflow(t->b, t->a, &result);
  920. } else {
  921. status = (SDL_size_mul_check_overflow)(t->b, t->a, &result);
  922. }
  923. if (t->status) {
  924. SDLTest_AssertCheck(status,
  925. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should succeed",
  926. t->b, t->a);
  927. SDLTest_AssertCheck(result == t->result,
  928. "(%" SIZE_FORMAT " * %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  929. t->b, t->a, t->result, result);
  930. } else {
  931. SDLTest_AssertCheck(!status,
  932. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should fail",
  933. t->b, t->a);
  934. }
  935. }
  936. for (i = 0; i < SDL_arraysize(additions); i++) {
  937. const overflow_test *t = &additions[i];
  938. bool status;
  939. size_t result = ~t->result;
  940. if (useBuiltin) {
  941. status = SDL_size_add_check_overflow(t->a, t->b, &result);
  942. } else {
  943. status = (SDL_size_add_check_overflow)(t->a, t->b, &result);
  944. }
  945. if (t->status) {
  946. SDLTest_AssertCheck(status,
  947. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should succeed",
  948. t->a, t->b);
  949. SDLTest_AssertCheck(result == t->result,
  950. "(%" SIZE_FORMAT " + %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  951. t->a, t->b, t->result, result);
  952. } else {
  953. SDLTest_AssertCheck(!status,
  954. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should fail",
  955. t->a, t->b);
  956. }
  957. if (t->a == t->b) {
  958. continue;
  959. }
  960. result = ~t->result;
  961. if (useBuiltin) {
  962. status = SDL_size_add_check_overflow(t->b, t->a, &result);
  963. } else {
  964. status = (SDL_size_add_check_overflow)(t->b, t->a, &result);
  965. }
  966. if (t->status) {
  967. SDLTest_AssertCheck(status,
  968. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should succeed",
  969. t->b, t->a);
  970. SDLTest_AssertCheck(result == t->result,
  971. "(%" SIZE_FORMAT " + %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  972. t->b, t->a, t->result, result);
  973. } else {
  974. SDLTest_AssertCheck(!status,
  975. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should fail",
  976. t->b, t->a);
  977. }
  978. }
  979. }
  980. return TEST_COMPLETED;
  981. }
  982. static void format_for_description(char *buffer, size_t buflen, const char *text) {
  983. if (text == NULL) {
  984. SDL_strlcpy(buffer, "NULL", buflen);
  985. } else {
  986. SDL_snprintf(buffer, buflen, "\"%s\"", text);
  987. }
  988. }
  989. static int SDLCALL
  990. stdlib_iconv(void *arg)
  991. {
  992. struct {
  993. bool expect_success;
  994. const char *from_encoding;
  995. const char *text;
  996. const char *to_encoding;
  997. const char *expected;
  998. } inputs[] = {
  999. { false, "bogus-from-encoding", NULL, "bogus-to-encoding", NULL },
  1000. { false, "bogus-from-encoding", "hello world", "bogus-to-encoding", NULL },
  1001. { false, "bogus-from-encoding", "hello world", "ascii", NULL },
  1002. { true, "utf-8", NULL, "ascii", "" },
  1003. { true, "utf-8", "hello world", "ascii", "hello world" },
  1004. { true, "utf-8", "\xe2\x8c\xa8\xf0\x9f\x92\xbb", "utf-16le", "\x28\x23\x3d\xd8\xbb\xdc\x00" },
  1005. };
  1006. SDL_iconv_t cd;
  1007. size_t i;
  1008. for (i = 0; i < SDL_arraysize(inputs); i++) {
  1009. char to_encoding_str[32];
  1010. char from_encoding_str[32];
  1011. char text_str[32];
  1012. size_t len_text = 0;
  1013. int r;
  1014. char out_buffer[6];
  1015. const char *in_ptr;
  1016. size_t in_pos;
  1017. char *out_ptr;
  1018. char *output;
  1019. size_t iconv_result;
  1020. size_t out_len;
  1021. bool is_error;
  1022. size_t out_pos;
  1023. SDLTest_AssertPass("case %d", (int)i);
  1024. format_for_description(to_encoding_str, SDL_arraysize(to_encoding_str), inputs[i].to_encoding);
  1025. format_for_description(from_encoding_str, SDL_arraysize(from_encoding_str), inputs[i].from_encoding);
  1026. format_for_description(text_str, SDL_arraysize(text_str), inputs[i].text);
  1027. if (inputs[i].text) {
  1028. len_text = SDL_strlen(inputs[i].text) + 1;
  1029. }
  1030. SDLTest_AssertPass("About to call SDL_iconv_open(%s, %s)", to_encoding_str, from_encoding_str);
  1031. cd = SDL_iconv_open(inputs[i].to_encoding, inputs[i].from_encoding);
  1032. if (inputs[i].expect_success) {
  1033. SDLTest_AssertCheck(cd != (SDL_iconv_t)SDL_ICONV_ERROR, "result must NOT be SDL_ICONV_ERROR");
  1034. } else {
  1035. SDLTest_AssertCheck(cd == (SDL_iconv_t)SDL_ICONV_ERROR, "result must be SDL_ICONV_ERROR");
  1036. }
  1037. in_ptr = inputs[i].text;
  1038. in_pos = 0;
  1039. out_pos = 0;
  1040. do {
  1041. size_t in_left;
  1042. size_t count_written;
  1043. size_t count_read;
  1044. in_left = len_text - in_pos;
  1045. out_ptr = out_buffer;
  1046. out_len = SDL_arraysize(out_buffer);
  1047. SDLTest_AssertPass("About to call SDL_iconv(cd, %s+%d, .., dest, ..)", text_str, (int)in_pos);
  1048. iconv_result = SDL_iconv(cd, &in_ptr, &in_left, &out_ptr, &out_len);
  1049. count_written = SDL_arraysize(out_buffer) - out_len;
  1050. count_read = in_ptr - inputs[i].text - in_pos;
  1051. in_pos += count_read;
  1052. is_error = iconv_result == SDL_ICONV_ERROR
  1053. || iconv_result == SDL_ICONV_EILSEQ
  1054. || iconv_result == SDL_ICONV_EINVAL;
  1055. if (inputs[i].expect_success) {
  1056. SDLTest_AssertCheck(!is_error, "result must NOT be an error code");
  1057. SDLTest_AssertCheck(count_written > 0 || inputs[i].expected[out_pos] == '\0', "%" SDL_PRIu64 " bytes have been written", (Uint64)count_written);
  1058. SDLTest_AssertCheck(out_pos <= SDL_strlen(inputs[i].expected), "Data written by SDL_iconv cannot be longer then reference output");
  1059. SDLTest_CompareMemory(out_buffer, count_written, inputs[i].expected + out_pos, count_written);
  1060. } else {
  1061. SDLTest_AssertCheck(is_error, "result must be an error code");
  1062. break;
  1063. }
  1064. out_pos += count_written;
  1065. if (count_written == 0) {
  1066. break;
  1067. }
  1068. if (count_read == 0) {
  1069. SDLTest_AssertCheck(false, "SDL_iconv wrote data, but read no data");
  1070. break;
  1071. }
  1072. } while (!is_error && in_pos < len_text);
  1073. SDLTest_AssertPass("About to call SDL_iconv_close(cd)");
  1074. r = SDL_iconv_close(cd);
  1075. if (inputs[i].expect_success) {
  1076. SDLTest_AssertCheck(r == 0, "result must be 0");
  1077. } else {
  1078. SDLTest_AssertCheck(r == -1, "result must be -1");
  1079. }
  1080. SDLTest_AssertPass("About to call SDL_iconv_string(%s, %s, %s, %" SDL_PRIu64 ")",
  1081. to_encoding_str, from_encoding_str, text_str, (Uint64)len_text);
  1082. output = SDL_iconv_string(inputs[i].to_encoding, inputs[i].from_encoding, inputs[i].text, len_text);
  1083. if (inputs[i].expect_success) {
  1084. SDLTest_AssertCheck(output != NULL, "result must NOT be NULL");
  1085. SDLTest_AssertCheck(SDL_strncmp(inputs[i].expected, output, SDL_strlen(inputs[i].expected)) == 0,
  1086. "converted string should be correct");
  1087. } else {
  1088. SDLTest_AssertCheck(output == NULL, "result must be NULL");
  1089. }
  1090. SDL_free(output);
  1091. }
  1092. return TEST_COMPLETED;
  1093. }
  1094. static int SDLCALL
  1095. stdlib_strpbrk(void *arg)
  1096. {
  1097. struct {
  1098. const char *input;
  1099. const char *accept;
  1100. int expected[3]; /* negative if NULL */
  1101. } test_cases[] = {
  1102. { "", "", { -1, -1, -1 } },
  1103. { "abc", "", { -1, -1, -1 } },
  1104. { "Abc", "a", { -1, -1, -1 } },
  1105. { "abc", "a", { 0, -1, -1 } },
  1106. { "abcbd", "bbbb", { 1, 3, -1 } },
  1107. { "a;b;c", ";", { 1, 3, -1 } },
  1108. { "a;b;c", ",", { -1, -1, -1 } },
  1109. { "a:bbbb;c", ";:", { 1, 6, -1 } },
  1110. { "Hello\tS DL\n", " \t\r\n", { 5, 7, 10 } },
  1111. };
  1112. int i;
  1113. for (i = 0; i < SDL_arraysize(test_cases); i++) {
  1114. int j;
  1115. const char *input = test_cases[i].input;
  1116. for (j = 0; j < SDL_arraysize(test_cases[i].expected); j++) {
  1117. char *result;
  1118. SDLTest_AssertPass("About to call SDL_strpbrk(\"%s\", \"%s\")", input, test_cases[i].accept);
  1119. result = SDL_strpbrk(input, test_cases[i].accept);
  1120. if (test_cases[i].expected[j] < 0) {
  1121. SDLTest_AssertCheck(result == NULL, "Expected NULL, got %p", result);
  1122. } else {
  1123. SDLTest_AssertCheck(result == test_cases[i].input + test_cases[i].expected[j], "Expected %p, got %p", test_cases[i].input + test_cases[i].expected[j], result);
  1124. input = test_cases[i].input + test_cases[i].expected[j] + 1;
  1125. }
  1126. }
  1127. }
  1128. return TEST_COMPLETED;
  1129. }
  1130. static int SDLCALL stdlib_wcstol(void *arg)
  1131. {
  1132. const long long_max = (~0UL) >> 1;
  1133. const long long_min = ((~0UL) >> 1) + 1UL;
  1134. #define WCSTOL_TEST_CASE(str, base, expected_result, expected_endp_offset) do { \
  1135. const wchar_t *s = str; \
  1136. long r, expected_r = expected_result; \
  1137. wchar_t *ep, *expected_ep = (wchar_t *)s + expected_endp_offset; \
  1138. r = SDL_wcstol(s, &ep, base); \
  1139. SDLTest_AssertPass("Call to SDL_wcstol(" #str ", &endp, " #base ")"); \
  1140. SDLTest_AssertCheck(r == expected_r, "Check result value, expected: %ld, got: %ld", expected_r, r); \
  1141. SDLTest_AssertCheck(ep == expected_ep, "Check endp value, expected: %p, got: %p", expected_ep, ep); \
  1142. } while (0)
  1143. // infer decimal
  1144. WCSTOL_TEST_CASE(L"\t 123abcxyz", 0, 123, 6); // skip leading space
  1145. WCSTOL_TEST_CASE(L"+123abcxyz", 0, 123, 4);
  1146. WCSTOL_TEST_CASE(L"-123abcxyz", 0, -123, 4);
  1147. WCSTOL_TEST_CASE(L"99999999999999999999abcxyz", 0, long_max, 20);
  1148. WCSTOL_TEST_CASE(L"-99999999999999999999abcxyz", 0, long_min, 21);
  1149. // infer hexadecimal
  1150. WCSTOL_TEST_CASE(L"0x123abcxyz", 0, 0x123abc, 8);
  1151. WCSTOL_TEST_CASE(L"0X123ABCXYZ", 0, 0x123abc, 8); // uppercase X
  1152. // infer octal
  1153. WCSTOL_TEST_CASE(L"0123abcxyz", 0, 0123, 4);
  1154. // arbitrary bases
  1155. WCSTOL_TEST_CASE(L"00110011", 2, 51, 8);
  1156. WCSTOL_TEST_CASE(L"-uvwxyz", 32, -991, 3);
  1157. WCSTOL_TEST_CASE(L"ZzZzZzZzZzZzZ", 36, long_max, 13);
  1158. WCSTOL_TEST_CASE(L"-0", 10, 0, 2);
  1159. WCSTOL_TEST_CASE(L" - 1", 0, 0, 0); // invalid input
  1160. // values near the bounds of the type
  1161. const bool long_is_32bit = sizeof(long) == 4;
  1162. if (long_is_32bit) {
  1163. WCSTOL_TEST_CASE(L"2147483647", 10, 2147483647, 10);
  1164. WCSTOL_TEST_CASE(L"2147483648", 10, 2147483647, 10);
  1165. WCSTOL_TEST_CASE(L"-2147483648", 10, -2147483647L - 1, 11);
  1166. WCSTOL_TEST_CASE(L"-2147483649", 10, -2147483647L - 1, 11);
  1167. WCSTOL_TEST_CASE(L"-9999999999999999999999999999999999999999", 10, -2147483647L - 1, 41);
  1168. }
  1169. #undef WCSTOL_TEST_CASE
  1170. return TEST_COMPLETED;
  1171. }
  1172. static int SDLCALL stdlib_strtox(void *arg)
  1173. {
  1174. const unsigned long long ullong_max = ~0ULL;
  1175. #define STRTOX_TEST_CASE(func_name, type, format_spec, str, base, expected_result, expected_endp_offset) do { \
  1176. const char *s = str; \
  1177. type r, expected_r = expected_result; \
  1178. char *ep, *expected_ep = (char *)s + expected_endp_offset; \
  1179. r = func_name(s, &ep, base); \
  1180. SDLTest_AssertPass("Call to " #func_name "(" #str ", &endp, " #base ")"); \
  1181. SDLTest_AssertCheck(r == expected_r, "Check result value, expected: " format_spec ", got: " format_spec, expected_r, r); \
  1182. SDLTest_AssertCheck(ep == expected_ep, "Check endp value, expected: %p, got: %p", expected_ep, ep); \
  1183. } while (0)
  1184. // infer decimal
  1185. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "\t 123abcxyz", 0, 123, 6); // skip leading space
  1186. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "+123abcxyz", 0, 123, 4);
  1187. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "+123abcxyz", 0, 123, 4);
  1188. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "-123abcxyz", 0, -123, 4);
  1189. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "9999999999999999999999999999999999999999abcxyz", 0, ullong_max, 40);
  1190. // infer hexadecimal
  1191. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "0x123abcxyz", 0, 0x123abc, 8);
  1192. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "0X123ABCXYZ", 0, 0x123abc, 8); // uppercase X
  1193. // infer octal
  1194. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "0123abcxyz", 0, 0123, 4);
  1195. // arbitrary bases
  1196. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "00110011", 2, 51, 8);
  1197. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "-uvwxyz", 32, -991, 3);
  1198. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "ZzZzZzZzZzZzZzZzZzZzZzZzZ", 36, ullong_max, 25);
  1199. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "0", 0, 0, 1);
  1200. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "0", 10, 0, 1);
  1201. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "-0", 0, 0, 2);
  1202. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "-0", 10, 0, 2);
  1203. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, " - 1", 0, 0, 0); // invalid input
  1204. // We know that SDL_strtol, SDL_strtoul and SDL_strtoll share the same code path as SDL_strtoull under the hood,
  1205. // so the most interesting test cases are those close to the bounds of the integer type.
  1206. // For simplicity, we only run long/long long tests when they are 32-bit/64-bit, respectively.
  1207. // Suppressing warnings would be difficult otherwise.
  1208. // Since the CI runs the tests against a variety of targets, this should be fine in practice.
  1209. const bool long_is_32bit = sizeof(long) == 4;
  1210. if (long_is_32bit) {
  1211. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "0", 0, 0, 1);
  1212. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "0", 10, 0, 1);
  1213. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "-0", 0, 0, 2);
  1214. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "-0", 10, 0, 2);
  1215. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "2147483647", 10, 2147483647, 10);
  1216. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "2147483648", 10, 2147483647, 10);
  1217. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "-2147483648", 10, -2147483647L - 1, 11);
  1218. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "-2147483649", 10, -2147483647L - 1, 11);
  1219. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "-9999999999999999999999999999999999999999", 10, -2147483647L - 1, 41);
  1220. STRTOX_TEST_CASE(SDL_strtoul, unsigned long, "%lu", "4294967295", 10, 4294967295UL, 10);
  1221. STRTOX_TEST_CASE(SDL_strtoul, unsigned long, "%lu", "4294967296", 10, 4294967295UL, 10);
  1222. STRTOX_TEST_CASE(SDL_strtoul, unsigned long, "%lu", "-4294967295", 10, 1, 11);
  1223. }
  1224. const bool long_long_is_64bit = sizeof(long long) == 8;
  1225. if (long_long_is_64bit) {
  1226. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "0", 0, 0LL, 1);
  1227. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "0", 10, 0LL, 1);
  1228. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "-0", 0, 0LL, 2);
  1229. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "-0", 10, 0LL, 2);
  1230. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "9223372036854775807", 10, 9223372036854775807LL, 19);
  1231. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "9223372036854775808", 10, 9223372036854775807LL, 19);
  1232. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "-9223372036854775808", 10, -9223372036854775807LL - 1, 20);
  1233. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "-9223372036854775809", 10, -9223372036854775807LL - 1, 20);
  1234. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "-9999999999999999999999999999999999999999", 10, -9223372036854775807LL - 1, 41);
  1235. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLd, "18446744073709551615", 10, 18446744073709551615ULL, 20);
  1236. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLd, "18446744073709551616", 10, 18446744073709551615ULL, 20);
  1237. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLd, "-18446744073709551615", 10, 1, 21);
  1238. }
  1239. #undef STRTOX_TEST_CASE
  1240. return TEST_COMPLETED;
  1241. }
  1242. static int SDLCALL stdlib_strtod(void *arg)
  1243. {
  1244. #define STRTOD_TEST_CASE(str, expected_result, expected_endp_offset) do { \
  1245. const char *s = str; \
  1246. double r, expected_r = expected_result; \
  1247. char *ep, *expected_ep = (char *)s + expected_endp_offset; \
  1248. r = SDL_strtod(s, &ep); \
  1249. SDLTest_AssertPass("Call to SDL_strtod(" #str ", &endp)"); \
  1250. SDLTest_AssertCheck(r == expected_r, "Check result value, expected: %f, got: %f", expected_r, r); \
  1251. SDLTest_AssertCheck(ep == expected_ep, "Check endp value, expected: %p, got: %p", expected_ep, ep); \
  1252. } while (0)
  1253. STRTOD_TEST_CASE("\t 123.75abcxyz", 123.75, 9); // skip leading space
  1254. STRTOD_TEST_CASE("+999.555", 999.555, 8);
  1255. STRTOD_TEST_CASE("-999.555", -999.555, 8);
  1256. #undef STRTOD_TEST_CASE
  1257. return TEST_COMPLETED;
  1258. }
  1259. /* ================= Test References ================== */
  1260. /* Standard C routine test cases */
  1261. static const SDLTest_TestCaseReference stdlibTest_strnlen = {
  1262. stdlib_strnlen, "stdlib_strnlen", "Call to SDL_strnlen", TEST_ENABLED
  1263. };
  1264. static const SDLTest_TestCaseReference stdlibTest_strlcpy = {
  1265. stdlib_strlcpy, "stdlib_strlcpy", "Call to SDL_strlcpy", TEST_ENABLED
  1266. };
  1267. static const SDLTest_TestCaseReference stdlibTest_strstr = {
  1268. stdlib_strstr, "stdlib_strstr", "Call to SDL_strstr", TEST_ENABLED
  1269. };
  1270. static const SDLTest_TestCaseReference stdlibTest_snprintf = {
  1271. stdlib_snprintf, "stdlib_snprintf", "Call to SDL_snprintf", TEST_ENABLED
  1272. };
  1273. static const SDLTest_TestCaseReference stdlibTest_swprintf = {
  1274. stdlib_swprintf, "stdlib_swprintf", "Call to SDL_swprintf", TEST_ENABLED
  1275. };
  1276. static const SDLTest_TestCaseReference stdlibTest_getsetenv = {
  1277. stdlib_getsetenv, "stdlib_getsetenv", "Call to SDL_GetEnvironmentVariable and SDL_SetEnvironmentVariable", TEST_ENABLED
  1278. };
  1279. static const SDLTest_TestCaseReference stdlibTest_sscanf = {
  1280. stdlib_sscanf, "stdlib_sscanf", "Call to SDL_sscanf", TEST_ENABLED
  1281. };
  1282. static const SDLTest_TestCaseReference stdlibTest_aligned_alloc = {
  1283. stdlib_aligned_alloc, "stdlib_aligned_alloc", "Call to SDL_aligned_alloc", TEST_ENABLED
  1284. };
  1285. static const SDLTest_TestCaseReference stdlibTestOverflow = {
  1286. stdlib_overflow, "stdlib_overflow", "Overflow detection", TEST_ENABLED
  1287. };
  1288. static const SDLTest_TestCaseReference stdlibTest_iconv = {
  1289. stdlib_iconv, "stdlib_iconv", "Calls to SDL_iconv", TEST_ENABLED
  1290. };
  1291. static const SDLTest_TestCaseReference stdlibTest_strpbrk = {
  1292. stdlib_strpbrk, "stdlib_strpbrk", "Calls to SDL_strpbrk", TEST_ENABLED
  1293. };
  1294. static const SDLTest_TestCaseReference stdlibTest_wcstol = {
  1295. stdlib_wcstol, "stdlib_wcstol", "Calls to SDL_wcstol", TEST_ENABLED
  1296. };
  1297. static const SDLTest_TestCaseReference stdlibTest_strtox = {
  1298. stdlib_strtox, "stdlib_strtox", "Calls to SDL_strtol, SDL_strtoul, SDL_strtoll and SDL_strtoull", TEST_ENABLED
  1299. };
  1300. static const SDLTest_TestCaseReference stdlibTest_strtod = {
  1301. stdlib_strtod, "stdlib_strtod", "Calls to SDL_strtod", TEST_ENABLED
  1302. };
  1303. /* Sequence of Standard C routine test cases */
  1304. static const SDLTest_TestCaseReference *stdlibTests[] = {
  1305. &stdlibTest_strnlen,
  1306. &stdlibTest_strlcpy,
  1307. &stdlibTest_strstr,
  1308. &stdlibTest_snprintf,
  1309. &stdlibTest_swprintf,
  1310. &stdlibTest_getsetenv,
  1311. &stdlibTest_sscanf,
  1312. &stdlibTest_aligned_alloc,
  1313. &stdlibTestOverflow,
  1314. &stdlibTest_iconv,
  1315. &stdlibTest_strpbrk,
  1316. &stdlibTest_wcstol,
  1317. &stdlibTest_strtox,
  1318. &stdlibTest_strtod,
  1319. NULL
  1320. };
  1321. /* Standard C routine test suite (global) */
  1322. SDLTest_TestSuiteReference stdlibTestSuite = {
  1323. "Stdlib",
  1324. NULL,
  1325. stdlibTests,
  1326. NULL
  1327. };