testautomation_stdlib.c 72 KB

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