testautomation_stdlib.c 72 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476
  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. {
  226. static struct
  227. {
  228. int precision;
  229. float value;
  230. const char *expected_f;
  231. const char *expected_g;
  232. } f_and_g_test_cases[] = {
  233. { 6, 100.0f, "100.000000", "100" },
  234. { 6, -100.0f, "-100.000000", "-100" },
  235. { 6, 100.75f, "100.750000", "100.75" },
  236. { 6, -100.75f, "-100.750000", "-100.75" },
  237. { 6, ((100 * 60 * 1000) / 1001) / 100.0f, "59.939999", "59.94" },
  238. { 6, -((100 * 60 * 1000) / 1001) / 100.0f, "-59.939999", "-59.94" },
  239. { 6, ((100 * 120 * 1000) / 1001) / 100.0f, "119.879997", "119.88" },
  240. { 6, -((100 * 120 * 1000) / 1001) / 100.0f, "-119.879997", "-119.88" },
  241. { 6, 0.9999999f, "1.000000", "1" },
  242. { 6, -0.9999999f, "-1.000000", "-1" },
  243. { 5, 9.999999f, "10.00000", "10" },
  244. { 5, -9.999999f, "-10.00000", "-10" },
  245. };
  246. int i;
  247. for (i = 0; i < SDL_arraysize(f_and_g_test_cases); ++i) {
  248. float value = f_and_g_test_cases[i].value;
  249. int prec = f_and_g_test_cases[i].precision;
  250. result = SDL_snprintf(text, sizeof(text), "%.*f", prec, value);
  251. predicted = SDL_snprintf(NULL, 0, "%.*f", prec, value);
  252. expected = f_and_g_test_cases[i].expected_f;
  253. SDLTest_AssertPass("Call to SDL_snprintf(\"%%.5f\", %g)", value);
  254. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  255. SDLTest_AssertCheck(result == SDL_strlen(expected), "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  256. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  257. result = SDL_snprintf(text, sizeof(text), "%g", value);
  258. predicted = SDL_snprintf(NULL, 0, "%g", value);
  259. expected = f_and_g_test_cases[i].expected_g;
  260. SDLTest_AssertPass("Call to SDL_snprintf(\"%%g\", %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. }
  265. }
  266. size = 64;
  267. result = SDL_snprintf(text, sizeof(text), "%zu %s", size, "test");
  268. expected = "64 test";
  269. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"%%zu %%s\", size, \"test\")");
  270. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  271. SDLTest_AssertCheck(result == 7, "Check result value, expected: 7, got: %d", result);
  272. result = SDL_snprintf(text, sizeof(text), "%p", (void *)0x1234abcd);
  273. expected = "0x1234abcd";
  274. expected2 = "1234ABCD";
  275. expected3 = "000000001234ABCD";
  276. expected4 = "1234abcd";
  277. expected5 = "000000001234abcd";
  278. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"%%p\", 0x1234abcd)");
  279. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0 ||
  280. SDL_strcmp(text, expected2) == 0 ||
  281. SDL_strcmp(text, expected3) == 0 ||
  282. SDL_strcmp(text, expected4) == 0 ||
  283. SDL_strcmp(text, expected5) == 0,
  284. "Check text, expected: '%s', got: '%s'", expected, text);
  285. SDLTest_AssertCheck(result == SDL_strlen(expected) ||
  286. result == SDL_strlen(expected2) ||
  287. result == SDL_strlen(expected3) ||
  288. result == SDL_strlen(expected4) ||
  289. result == SDL_strlen(expected5),
  290. "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  291. result = SDL_snprintf(text, sizeof(text), "A %p B", (void *)0x1234abcd);
  292. expected = "A 0x1234abcd B";
  293. expected2 = "A 1234ABCD B";
  294. expected3 = "A 000000001234ABCD B";
  295. expected4 = "A 1234abcd B";
  296. expected5 = "A 000000001234abcd B";
  297. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"A %%p B\", 0x1234abcd)");
  298. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0 ||
  299. SDL_strcmp(text, expected2) == 0 ||
  300. SDL_strcmp(text, expected3) == 0 ||
  301. SDL_strcmp(text, expected4) == 0 ||
  302. SDL_strcmp(text, expected5) == 0,
  303. "Check text, expected: '%s', got: '%s'", expected, text);
  304. SDLTest_AssertCheck(result == SDL_strlen(expected) ||
  305. result == SDL_strlen(expected2) ||
  306. result == SDL_strlen(expected3) ||
  307. result == SDL_strlen(expected4) ||
  308. result == SDL_strlen(expected5),
  309. "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  310. if (sizeof(void *) >= 8) {
  311. result = SDL_snprintf(text, sizeof(text), "%p", (void *)0x1ba07bddf60L);
  312. expected = "0x1ba07bddf60";
  313. expected2 = "000001BA07BDDF60";
  314. expected3 = "000001ba07bddf60";
  315. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"%%p\", 0x1ba07bddf60)");
  316. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0 ||
  317. SDL_strcmp(text, expected2) == 0 ||
  318. SDL_strcmp(text, expected3) == 0,
  319. "Check text, expected: '%s', got: '%s'", expected, text);
  320. SDLTest_AssertCheck(result == SDL_strlen(expected) ||
  321. result == SDL_strlen(expected2) ||
  322. result == SDL_strlen(expected3),
  323. "Check result value, expected: %d, got: %d", (int)SDL_strlen(expected), result);
  324. }
  325. return TEST_COMPLETED;
  326. }
  327. /**
  328. * Call to SDL_swprintf
  329. */
  330. static int SDLCALL stdlib_swprintf(void *arg)
  331. {
  332. int result;
  333. int predicted;
  334. wchar_t text[1024];
  335. const wchar_t *expected;
  336. size_t size;
  337. result = SDL_swprintf(text, SDL_arraysize(text), L"%s", "foo");
  338. expected = L"foo";
  339. SDLTest_AssertPass("Call to SDL_swprintf(\"%%s\", \"foo\")");
  340. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  341. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  342. result = SDL_swprintf(text, 2, L"%s", "foo");
  343. expected = L"f";
  344. SDLTest_AssertPass("Call to SDL_swprintf(\"%%s\", \"foo\") with buffer size 2");
  345. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  346. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", result);
  347. result = SDL_swprintf(NULL, 0, L"%s", "foo");
  348. SDLTest_AssertPass("Call to SDL_swprintf(NULL, 0, \"%%s\", \"foo\")");
  349. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", result);
  350. result = SDL_swprintf(text, 2, L"%s\n", "foo");
  351. expected = L"f";
  352. SDLTest_AssertPass("Call to SDL_swprintf(\"%%s\\n\", \"foo\") with buffer size 2");
  353. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  354. SDLTest_AssertCheck(result == 4, "Check result value, expected: 4, got: %d", result);
  355. result = SDL_swprintf(text, sizeof(text), L"%f", 0.0);
  356. predicted = SDL_swprintf(NULL, 0, L"%f", 0.0);
  357. expected = L"0.000000";
  358. SDLTest_AssertPass("Call to SDL_swprintf(\"%%f\", 0.0)");
  359. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  360. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  361. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  362. result = SDL_swprintf(text, sizeof(text), L"%f", 1.0);
  363. predicted = SDL_swprintf(NULL, 0, L"%f", 1.0);
  364. expected = L"1.000000";
  365. SDLTest_AssertPass("Call to SDL_swprintf(\"%%f\", 1.0)");
  366. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  367. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  368. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  369. result = SDL_swprintf(text, sizeof(text), L"%.f", 1.0);
  370. predicted = SDL_swprintf(NULL, 0, L"%.f", 1.0);
  371. expected = L"1";
  372. SDLTest_AssertPass("Call to SDL_swprintf(\"%%.f\", 1.0)");
  373. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: %S, got: %S", expected, text);
  374. SDLTest_AssertCheck(result == SDL_wcslen(text), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(text), result);
  375. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  376. result = SDL_swprintf(text, sizeof(text), L"%#.f", 1.0);
  377. predicted = SDL_swprintf(NULL, 0, L"%#.f", 1.0);
  378. expected = L"1.";
  379. SDLTest_AssertPass("Call to SDL_swprintf(\"%%#.f\", 1.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 + 1.0 / 3.0);
  384. predicted = SDL_swprintf(NULL, 0, L"%f", 1.0 + 1.0 / 3.0);
  385. expected = L"1.333333";
  386. SDLTest_AssertPass("Call to SDL_swprintf(\"%%f\", 1.0 + 1.0 / 3.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 + 1.0 / 3.0);
  391. predicted = SDL_swprintf(NULL, 0, L"%+f", 1.0 + 1.0 / 3.0);
  392. expected = L"+1.333333";
  393. SDLTest_AssertPass("Call to SDL_swprintf(\"%%+f\", 1.0 + 1.0 / 3.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"%.2f", 1.0 + 1.0 / 3.0);
  398. predicted = SDL_swprintf(NULL, 0, L"%.2f", 1.0 + 1.0 / 3.0);
  399. expected = L"1.33";
  400. SDLTest_AssertPass("Call to SDL_swprintf(\"%%.2f\", 1.0 + 1.0 / 3.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"%6.2f", 1.0 + 1.0 / 3.0);
  405. predicted = SDL_swprintf(NULL, 0, L"%6.2f", 1.0 + 1.0 / 3.0);
  406. expected = L" 1.33";
  407. SDLTest_AssertPass("Call to SDL_swprintf(\"%%6.2f\", 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"%06.2f", 1.0 + 1.0 / 3.0);
  412. predicted = SDL_swprintf(NULL, 0, L"%06.2f", 1.0 + 1.0 / 3.0);
  413. expected = L"001.33";
  414. SDLTest_AssertPass("Call to SDL_swprintf(\"%%06.2f\", 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, 5, L"%06.2f", 1.0 + 1.0 / 3.0);
  419. expected = L"001.";
  420. SDLTest_AssertPass("Call to SDL_swprintf(\"%%06.2f\", 1.0 + 1.0 / 3.0) with buffer size 5");
  421. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  422. SDLTest_AssertCheck(result == 6, "Check result value, expected: 6, got: %d", result);
  423. {
  424. static struct
  425. {
  426. float value;
  427. const wchar_t *expected_f;
  428. const wchar_t *expected_g;
  429. } f_and_g_test_cases[] = {
  430. { 100.0f, L"100.000000", L"100" },
  431. { -100.0f, L"-100.000000", L"-100" },
  432. { 100.75f, L"100.750000", L"100.75" },
  433. { -100.75f, L"-100.750000", L"-100.75" },
  434. { ((100 * 60 * 1000) / 1001) / 100.0f, L"59.939999", L"59.94" },
  435. { -((100 * 60 * 1000) / 1001) / 100.0f, L"-59.939999", L"-59.94" },
  436. { ((100 * 120 * 1000) / 1001) / 100.0f, L"119.879997", L"119.88" },
  437. { -((100 * 120 * 1000) / 1001) / 100.0f, L"-119.879997", L"-119.88" },
  438. { 9.9999999f, L"10.000000", L"10" },
  439. { -9.9999999f, L"-10.000000", L"-10" },
  440. };
  441. int i;
  442. for (i = 0; i < SDL_arraysize(f_and_g_test_cases); ++i) {
  443. float value = f_and_g_test_cases[i].value;
  444. result = SDL_swprintf(text, sizeof(text), L"%f", value);
  445. predicted = SDL_swprintf(NULL, 0, L"%f", value);
  446. expected = f_and_g_test_cases[i].expected_f;
  447. SDLTest_AssertPass("Call to SDL_swprintf(\"%%f\", %g)", value);
  448. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  449. SDLTest_AssertCheck(result == SDL_wcslen(expected), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(expected), result);
  450. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  451. result = SDL_swprintf(text, sizeof(text), L"%g", value);
  452. predicted = SDL_swprintf(NULL, 0, L"%g", value);
  453. expected = f_and_g_test_cases[i].expected_g;
  454. SDLTest_AssertPass("Call to SDL_swprintf(\"%%g\", %g)", value);
  455. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  456. SDLTest_AssertCheck(result == SDL_wcslen(expected), "Check result value, expected: %d, got: %d", (int)SDL_wcslen(expected), result);
  457. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  458. }
  459. }
  460. size = 64;
  461. result = SDL_swprintf(text, sizeof(text), L"%zu %s", size, "test");
  462. expected = L"64 test";
  463. SDLTest_AssertPass("Call to SDL_swprintf(text, sizeof(text), \"%%zu %%s\", size, \"test\")");
  464. SDLTest_AssertCheck(SDL_wcscmp(text, expected) == 0, "Check text, expected: '%S', got: '%S'", expected, text);
  465. SDLTest_AssertCheck(result == 7, "Check result value, expected: 7, got: %d", result);
  466. return TEST_COMPLETED;
  467. }
  468. #if defined(HAVE_WFORMAT) || defined(HAVE_WFORMAT_EXTRA_ARGS)
  469. #pragma GCC diagnostic pop
  470. #endif
  471. /**
  472. * Call to SDL_GetEnvironmentVariable() and SDL_SetEnvironmentVariable()
  473. */
  474. static int SDLCALL stdlib_getsetenv(void *arg)
  475. {
  476. SDL_Environment *env = SDL_GetEnvironment();
  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_GetEnvironmentVariable, 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_GetEnvironmentVariable(env, name);
  494. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%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_SetEnvironmentVariable(env, name, value1, overwrite);
  506. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s','%s', %i)", name, value1, overwrite);
  507. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  508. /* Check value */
  509. text = SDL_GetEnvironmentVariable(env, name);
  510. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%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_SetEnvironmentVariable(env, name, value2, overwrite);
  523. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s','%s', %i)", name, value2, overwrite);
  524. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  525. /* Check value */
  526. text = SDL_GetEnvironmentVariable(env, name);
  527. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%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_SetEnvironmentVariable(env, name, value1, overwrite);
  540. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s','%s', %i)", name, value1, overwrite);
  541. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  542. /* Check value */
  543. text = SDL_GetEnvironmentVariable(env, name);
  544. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%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_SetEnvironmentVariable(env, name, value1, overwrite);
  557. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s','%s', %i)", name, value1, overwrite);
  558. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  559. /* Check value */
  560. text = SDL_GetEnvironmentVariable(env, name);
  561. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '%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_SetEnvironmentVariable(env, "FOO", "1", 1);
  572. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, 'FOO','1', 1)");
  573. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  574. expected = "1";
  575. text = SDL_GetEnvironmentVariable(env, "FOO");
  576. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, 'FOO')");
  577. SDLTest_AssertCheck(text && SDL_strcmp(text, expected) == 0, "Verify returned text, expected: %s, got: %s", expected, text);
  578. result = SDL_SetEnvironmentVariable(env, "FOO", "", 1);
  579. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, 'FOO','', 1)");
  580. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  581. expected = "";
  582. text = SDL_GetEnvironmentVariable(env, "FOO");
  583. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, 'FOO')");
  584. SDLTest_AssertCheck(text && SDL_strcmp(text, expected) == 0, "Verify returned text, expected: '%s', got: '%s'", expected, text);
  585. result = SDL_UnsetEnvironmentVariable(env, "FOO");
  586. SDLTest_AssertPass("Call to SDL_UnsetEnvironmentVariable(env, 'FOO')");
  587. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  588. text = SDL_GetEnvironmentVariable(env, "FOO");
  589. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, 'FOO')");
  590. SDLTest_AssertCheck(text == NULL, "Verify returned text, expected: (null), got: %s", text);
  591. result = SDL_SetEnvironmentVariable(env, "FOO", "0", 0);
  592. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, 'FOO','0', 0)");
  593. SDLTest_AssertCheck(result == true, "Check result, expected: 1, got: %i", result);
  594. expected = "0";
  595. text = SDL_GetEnvironmentVariable(env, "FOO");
  596. SDLTest_AssertPass("Call to SDL_GetEnvironmentVariable(env, '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_SetEnvironmentVariable(env, NULL, value1, overwrite);
  601. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, NULL,'%s', %i)", value1, overwrite);
  602. SDLTest_AssertCheck(result == false, "Check result, expected: 0, got: %i", result);
  603. result = SDL_SetEnvironmentVariable(env, "", value1, overwrite);
  604. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '','%s', %i)", value1, overwrite);
  605. SDLTest_AssertCheck(result == false, "Check result, expected: 0, got: %i", result);
  606. result = SDL_SetEnvironmentVariable(env, "=", value1, overwrite);
  607. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '=','%s', %i)", value1, overwrite);
  608. SDLTest_AssertCheck(result == false, "Check result, expected: 0, got: %i", result);
  609. result = SDL_SetEnvironmentVariable(env, name, NULL, overwrite);
  610. SDLTest_AssertPass("Call to SDL_SetEnvironmentVariable(env, '%s', NULL, %i)", name, overwrite);
  611. SDLTest_AssertCheck(result == false, "Check result, expected: 0, 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. #ifndef SDL_PLATFORM_WINDOWS
  628. #define FMT_PRILLd "%lld"
  629. #define FMT_PRILLu "%llu"
  630. #else
  631. /* make sure long long is 64 bits */
  632. SDL_COMPILE_TIME_ASSERT(longlong_size64, sizeof(long long) == 8);
  633. #define FMT_PRILLd "%I64d"
  634. #define FMT_PRILLu "%I64u"
  635. #endif
  636. /**
  637. * Call to SDL_sscanf
  638. */
  639. static int SDLCALL stdlib_sscanf(void *arg)
  640. {
  641. int output;
  642. int result;
  643. int expected_output;
  644. int expected_result;
  645. short short_output, expected_short_output;
  646. long long_output, expected_long_output;
  647. long long long_long_output, expected_long_long_output;
  648. size_t size_output, expected_size_output;
  649. void *ptr_output, *expected_ptr_output;
  650. char text[128], text2[128];
  651. expected_output = output = 123;
  652. expected_result = -1;
  653. result = SDL_sscanf("", "%i", &output);
  654. SDLTest_AssertPass("Call to SDL_sscanf(\"\", \"%%i\", &output)");
  655. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  656. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  657. expected_output = output = 123;
  658. expected_result = 0;
  659. result = SDL_sscanf("a", "%i", &output);
  660. SDLTest_AssertPass("Call to SDL_sscanf(\"a\", \"%%i\", &output)");
  661. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  662. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  663. output = 123;
  664. expected_output = 2;
  665. expected_result = 1;
  666. result = SDL_sscanf("2", "%i", &output);
  667. SDLTest_AssertPass("Call to SDL_sscanf(\"2\", \"%%i\", &output)");
  668. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  669. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  670. output = 123;
  671. expected_output = 0xa;
  672. expected_result = 1;
  673. result = SDL_sscanf("aa", "%1x", &output);
  674. SDLTest_AssertPass("Call to SDL_sscanf(\"aa\", \"%%1x\", &output)");
  675. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  676. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  677. #define SIZED_TEST_CASE(type, var, format_specifier) \
  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. \
  687. var##_output = 123; \
  688. expected_##var##_output = ~(type)(((unsigned type)(~0)) >> 1); \
  689. expected_result = 1; \
  690. result = SDL_snprintf(text, sizeof(text), format_specifier, expected_##var##_output); \
  691. result = SDL_sscanf(text, format_specifier, &var##_output); \
  692. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", \"%s\", &output)", text, #format_specifier); \
  693. SDLTest_AssertCheck(expected_##var##_output == var##_output, "Check output, expected: " format_specifier ", got: " format_specifier, expected_##var##_output, var##_output); \
  694. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  695. SIZED_TEST_CASE(short, short, "%hd")
  696. SIZED_TEST_CASE(long, long, "%ld")
  697. SIZED_TEST_CASE(long long, long_long, FMT_PRILLd)
  698. size_output = 123;
  699. expected_size_output = ~((size_t)0);
  700. expected_result = 1;
  701. result = SDL_snprintf(text, sizeof(text), "%zu", expected_size_output);
  702. result = SDL_sscanf(text, "%zu", &size_output);
  703. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", \"%%zu\", &output)", text);
  704. SDLTest_AssertCheck(expected_size_output == size_output, "Check output, expected: %zu, got: %zu", expected_size_output, size_output);
  705. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  706. ptr_output = (void *)123;
  707. expected_ptr_output = (void *)0x1234567;
  708. expected_result = 1;
  709. result = SDL_snprintf(text, sizeof(text), "%p", expected_ptr_output);
  710. result = SDL_sscanf(text, "%p", &ptr_output);
  711. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", \"%%p\", &output)", text);
  712. SDLTest_AssertCheck(expected_ptr_output == ptr_output, "Check output, expected: %p, got: %p", expected_ptr_output, ptr_output);
  713. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  714. expected_result = 1;
  715. text[0] = '\0';
  716. result = SDL_sscanf("abc def", "%s", text);
  717. SDLTest_AssertPass("Call to SDL_sscanf(\"abc def\", \"%%s\", text)");
  718. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  719. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  720. expected_result = 1;
  721. text[0] = '\0';
  722. result = SDL_sscanf("abc,def", "%s", text);
  723. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%s\", text)");
  724. SDLTest_AssertCheck(SDL_strcmp(text, "abc,def") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  725. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  726. expected_result = 1;
  727. text[0] = '\0';
  728. result = SDL_sscanf("abc,def", "%[cba]", text);
  729. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[cba]\", text)");
  730. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  731. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  732. expected_result = 1;
  733. text[0] = '\0';
  734. result = SDL_sscanf("abc,def", "%[a-z]", text);
  735. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[z-a]\", text)");
  736. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  737. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  738. expected_result = 1;
  739. text[0] = '\0';
  740. result = SDL_sscanf("abc,def", "%[^,]", text);
  741. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[^,]\", text)");
  742. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  743. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  744. expected_result = 0;
  745. text[0] = '\0';
  746. result = SDL_sscanf("abc,def", "%[A-Z]", text);
  747. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[A-Z]\", text)");
  748. SDLTest_AssertCheck(SDL_strcmp(text, "") == 0, "Check output, expected: \"\", got: \"%s\"", text);
  749. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  750. expected_result = 2;
  751. text[0] = '\0';
  752. text2[0] = '\0';
  753. result = SDL_sscanf("abc,def", "%[abc],%[def]", text, text2);
  754. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[abc],%%[def]\", text)");
  755. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  756. SDLTest_AssertCheck(SDL_strcmp(text2, "def") == 0, "Check output, expected: \"def\", got: \"%s\"", text2);
  757. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  758. expected_result = 2;
  759. text[0] = '\0';
  760. text2[0] = '\0';
  761. result = SDL_sscanf("abc,def", "%[abc]%*[,]%[def]", text, text2);
  762. SDLTest_AssertPass("Call to SDL_sscanf(\"abc,def\", \"%%[abc]%%*[,]%%[def]\", text)");
  763. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  764. SDLTest_AssertCheck(SDL_strcmp(text2, "def") == 0, "Check output, expected: \"def\", got: \"%s\"", text2);
  765. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  766. expected_result = 2;
  767. text[0] = '\0';
  768. text2[0] = '\0';
  769. result = SDL_sscanf("abc def", "%[abc] %[def]", text, text2);
  770. SDLTest_AssertPass("Call to SDL_sscanf(\"abc def\", \"%%[abc] %%[def]\", text)");
  771. SDLTest_AssertCheck(SDL_strcmp(text, "abc") == 0, "Check output, expected: \"abc\", got: \"%s\"", text);
  772. SDLTest_AssertCheck(SDL_strcmp(text2, "def") == 0, "Check output, expected: \"def\", got: \"%s\"", text2);
  773. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  774. expected_result = 1;
  775. text[0] = '\0';
  776. result = SDL_sscanf("abc123XYZ", "%[a-zA-Z0-9]", text);
  777. SDLTest_AssertPass("Call to SDL_sscanf(\"abc123XYZ\", \"%%[a-zA-Z0-9]\", text)");
  778. SDLTest_AssertCheck(SDL_strcmp(text, "abc123XYZ") == 0, "Check output, expected: \"abc123XYZ\", got: \"%s\"", text);
  779. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  780. return TEST_COMPLETED;
  781. }
  782. #if defined(HAVE_WFORMAT) || defined(HAVE_WFORMAT_EXTRA_ARGS)
  783. #pragma GCC diagnostic pop
  784. #endif
  785. #ifdef _WIN64
  786. #define SIZE_FORMAT "I64u"
  787. #elif defined(SDL_PLATFORM_WIN32)
  788. #define SIZE_FORMAT "I32u"
  789. #else
  790. #define SIZE_FORMAT "zu"
  791. #endif
  792. /**
  793. * Call to SDL_aligned_alloc
  794. */
  795. static int SDLCALL stdlib_aligned_alloc(void *arg)
  796. {
  797. size_t i, alignment;
  798. void *ptr;
  799. for (i = 0; i < 2*sizeof(void *); ++i) {
  800. SDLTest_AssertPass("Call to SDL_aligned_alloc(%"SIZE_FORMAT")", i);
  801. ptr = SDL_aligned_alloc(i, 1);
  802. if (i < sizeof(void *)) {
  803. alignment = sizeof(void *);
  804. } else {
  805. alignment = i;
  806. }
  807. SDLTest_AssertCheck(ptr != NULL, "Check output, expected non-NULL, got: %p", ptr);
  808. SDLTest_AssertCheck((((size_t)ptr) % alignment) == 0, "Check output, expected aligned pointer, actual offset: %"SIZE_FORMAT, (((size_t)ptr) % alignment));
  809. SDLTest_AssertPass("Filling memory to alignment value");
  810. SDL_memset(ptr, 0xAA, alignment);
  811. SDL_aligned_free(ptr);
  812. }
  813. return TEST_COMPLETED;
  814. }
  815. typedef struct
  816. {
  817. size_t a;
  818. size_t b;
  819. size_t result;
  820. bool status;
  821. } overflow_test;
  822. static const overflow_test multiplications[] = {
  823. { 1, 1, 1, true },
  824. { 0, 0, 0, true },
  825. { SDL_SIZE_MAX, 0, 0, true },
  826. { SDL_SIZE_MAX, 1, SDL_SIZE_MAX, true },
  827. { SDL_SIZE_MAX / 2, 2, SDL_SIZE_MAX - (SDL_SIZE_MAX % 2), true },
  828. { SDL_SIZE_MAX / 23, 23, SDL_SIZE_MAX - (SDL_SIZE_MAX % 23), true },
  829. { (SDL_SIZE_MAX / 2) + 1, 2, 0, false },
  830. { (SDL_SIZE_MAX / 23) + 42, 23, 0, false },
  831. { SDL_SIZE_MAX, SDL_SIZE_MAX, 0, false },
  832. };
  833. static const overflow_test additions[] = {
  834. { 1, 1, 2, true },
  835. { 0, 0, 0, true },
  836. { SDL_SIZE_MAX, 0, SDL_SIZE_MAX, true },
  837. { SDL_SIZE_MAX - 1, 1, SDL_SIZE_MAX, true },
  838. { SDL_SIZE_MAX - 42, 23, SDL_SIZE_MAX - (42 - 23), true },
  839. { SDL_SIZE_MAX, 1, 0, false },
  840. { SDL_SIZE_MAX, 23, 0, false },
  841. { SDL_SIZE_MAX, SDL_SIZE_MAX, 0, false },
  842. };
  843. static int SDLCALL
  844. stdlib_overflow(void *arg)
  845. {
  846. size_t i;
  847. size_t useBuiltin;
  848. for (useBuiltin = 0; useBuiltin < 2; useBuiltin++) {
  849. if (useBuiltin) {
  850. SDLTest_Log("Using gcc/clang builtins if possible");
  851. } else {
  852. SDLTest_Log("Not using gcc/clang builtins");
  853. }
  854. for (i = 0; i < SDL_arraysize(multiplications); i++) {
  855. const overflow_test *t = &multiplications[i];
  856. int status;
  857. size_t result = ~t->result;
  858. if (useBuiltin) {
  859. status = SDL_size_mul_check_overflow(t->a, t->b, &result);
  860. } else {
  861. /* This disables the macro that tries to use a gcc/clang
  862. * builtin, so we test the fallback implementation instead. */
  863. status = (SDL_size_mul_check_overflow)(t->a, t->b, &result);
  864. }
  865. if (t->status) {
  866. SDLTest_AssertCheck(status,
  867. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should succeed",
  868. t->a, t->b);
  869. SDLTest_AssertCheck(result == t->result,
  870. "(%" SIZE_FORMAT " * %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  871. t->a, t->b, t->result, result);
  872. } else {
  873. SDLTest_AssertCheck(!status,
  874. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should fail",
  875. t->a, t->b);
  876. }
  877. if (t->a == t->b) {
  878. continue;
  879. }
  880. result = ~t->result;
  881. if (useBuiltin) {
  882. status = SDL_size_mul_check_overflow(t->b, t->a, &result);
  883. } else {
  884. status = (SDL_size_mul_check_overflow)(t->b, t->a, &result);
  885. }
  886. if (t->status) {
  887. SDLTest_AssertCheck(status,
  888. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should succeed",
  889. t->b, t->a);
  890. SDLTest_AssertCheck(result == t->result,
  891. "(%" SIZE_FORMAT " * %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  892. t->b, t->a, t->result, result);
  893. } else {
  894. SDLTest_AssertCheck(!status,
  895. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should fail",
  896. t->b, t->a);
  897. }
  898. }
  899. for (i = 0; i < SDL_arraysize(additions); i++) {
  900. const overflow_test *t = &additions[i];
  901. bool status;
  902. size_t result = ~t->result;
  903. if (useBuiltin) {
  904. status = SDL_size_add_check_overflow(t->a, t->b, &result);
  905. } else {
  906. status = (SDL_size_add_check_overflow)(t->a, t->b, &result);
  907. }
  908. if (t->status) {
  909. SDLTest_AssertCheck(status,
  910. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should succeed",
  911. t->a, t->b);
  912. SDLTest_AssertCheck(result == t->result,
  913. "(%" SIZE_FORMAT " + %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  914. t->a, t->b, t->result, result);
  915. } else {
  916. SDLTest_AssertCheck(!status,
  917. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should fail",
  918. t->a, t->b);
  919. }
  920. if (t->a == t->b) {
  921. continue;
  922. }
  923. result = ~t->result;
  924. if (useBuiltin) {
  925. status = SDL_size_add_check_overflow(t->b, t->a, &result);
  926. } else {
  927. status = (SDL_size_add_check_overflow)(t->b, t->a, &result);
  928. }
  929. if (t->status) {
  930. SDLTest_AssertCheck(status,
  931. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should succeed",
  932. t->b, t->a);
  933. SDLTest_AssertCheck(result == t->result,
  934. "(%" SIZE_FORMAT " + %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  935. t->b, t->a, t->result, result);
  936. } else {
  937. SDLTest_AssertCheck(!status,
  938. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should fail",
  939. t->b, t->a);
  940. }
  941. }
  942. }
  943. return TEST_COMPLETED;
  944. }
  945. static void format_for_description(char *buffer, size_t buflen, const char *text) {
  946. if (text == NULL) {
  947. SDL_strlcpy(buffer, "NULL", buflen);
  948. } else {
  949. SDL_snprintf(buffer, buflen, "\"%s\"", text);
  950. }
  951. }
  952. static int SDLCALL
  953. stdlib_iconv(void *arg)
  954. {
  955. struct {
  956. bool expect_success;
  957. const char *from_encoding;
  958. const char *text;
  959. const char *to_encoding;
  960. const char *expected;
  961. } inputs[] = {
  962. { false, "bogus-from-encoding", NULL, "bogus-to-encoding", NULL },
  963. { false, "bogus-from-encoding", "hello world", "bogus-to-encoding", NULL },
  964. { false, "bogus-from-encoding", "hello world", "ascii", NULL },
  965. { true, "utf-8", NULL, "ascii", "" },
  966. { true, "utf-8", "hello world", "ascii", "hello world" },
  967. { true, "utf-8", "\xe2\x8c\xa8\xf0\x9f\x92\xbb", "utf-16le", "\x28\x23\x3d\xd8\xbb\xdc\x00" },
  968. };
  969. SDL_iconv_t cd;
  970. size_t i;
  971. for (i = 0; i < SDL_arraysize(inputs); i++) {
  972. char to_encoding_str[32];
  973. char from_encoding_str[32];
  974. char text_str[32];
  975. size_t len_text = 0;
  976. int r;
  977. char out_buffer[6];
  978. const char *in_ptr;
  979. size_t in_pos;
  980. char *out_ptr;
  981. char *output;
  982. size_t iconv_result;
  983. size_t out_len;
  984. bool is_error;
  985. size_t out_pos;
  986. SDLTest_AssertPass("case %d", (int)i);
  987. format_for_description(to_encoding_str, SDL_arraysize(to_encoding_str), inputs[i].to_encoding);
  988. format_for_description(from_encoding_str, SDL_arraysize(from_encoding_str), inputs[i].from_encoding);
  989. format_for_description(text_str, SDL_arraysize(text_str), inputs[i].text);
  990. if (inputs[i].text) {
  991. len_text = SDL_strlen(inputs[i].text) + 1;
  992. }
  993. SDLTest_AssertPass("About to call SDL_iconv_open(%s, %s)", to_encoding_str, from_encoding_str);
  994. cd = SDL_iconv_open(inputs[i].to_encoding, inputs[i].from_encoding);
  995. if (inputs[i].expect_success) {
  996. SDLTest_AssertCheck(cd != (SDL_iconv_t)SDL_ICONV_ERROR, "result must NOT be SDL_ICONV_ERROR");
  997. } else {
  998. SDLTest_AssertCheck(cd == (SDL_iconv_t)SDL_ICONV_ERROR, "result must be SDL_ICONV_ERROR");
  999. }
  1000. in_ptr = inputs[i].text;
  1001. in_pos = 0;
  1002. out_pos = 0;
  1003. do {
  1004. size_t in_left;
  1005. size_t count_written;
  1006. size_t count_read;
  1007. in_left = len_text - in_pos;
  1008. out_ptr = out_buffer;
  1009. out_len = SDL_arraysize(out_buffer);
  1010. SDLTest_AssertPass("About to call SDL_iconv(cd, %s+%d, .., dest, ..)", text_str, (int)in_pos);
  1011. iconv_result = SDL_iconv(cd, &in_ptr, &in_left, &out_ptr, &out_len);
  1012. count_written = SDL_arraysize(out_buffer) - out_len;
  1013. count_read = in_ptr - inputs[i].text - in_pos;
  1014. in_pos += count_read;
  1015. is_error = iconv_result == SDL_ICONV_ERROR
  1016. || iconv_result == SDL_ICONV_EILSEQ
  1017. || iconv_result == SDL_ICONV_EINVAL;
  1018. if (inputs[i].expect_success) {
  1019. SDLTest_AssertCheck(!is_error, "result must NOT be an error code");
  1020. SDLTest_AssertCheck(count_written > 0 || inputs[i].expected[out_pos] == '\0', "%" SDL_PRIu64 " bytes have been written", (Uint64)count_written);
  1021. SDLTest_AssertCheck(out_pos <= SDL_strlen(inputs[i].expected), "Data written by SDL_iconv cannot be longer then reference output");
  1022. SDLTest_CompareMemory(out_buffer, count_written, inputs[i].expected + out_pos, count_written);
  1023. } else {
  1024. SDLTest_AssertCheck(is_error, "result must be an error code");
  1025. break;
  1026. }
  1027. out_pos += count_written;
  1028. if (count_written == 0) {
  1029. break;
  1030. }
  1031. if (count_read == 0) {
  1032. SDLTest_AssertCheck(false, "SDL_iconv wrote data, but read no data");
  1033. break;
  1034. }
  1035. } while (!is_error && in_pos < len_text);
  1036. SDLTest_AssertPass("About to call SDL_iconv_close(cd)");
  1037. r = SDL_iconv_close(cd);
  1038. if (inputs[i].expect_success) {
  1039. SDLTest_AssertCheck(r == 0, "result must be 0");
  1040. } else {
  1041. SDLTest_AssertCheck(r == -1, "result must be -1");
  1042. }
  1043. SDLTest_AssertPass("About to call SDL_iconv_string(%s, %s, %s, %" SDL_PRIu64 ")",
  1044. to_encoding_str, from_encoding_str, text_str, (Uint64)len_text);
  1045. output = SDL_iconv_string(inputs[i].to_encoding, inputs[i].from_encoding, inputs[i].text, len_text);
  1046. if (inputs[i].expect_success) {
  1047. SDLTest_AssertCheck(output != NULL, "result must NOT be NULL");
  1048. SDLTest_AssertCheck(SDL_strncmp(inputs[i].expected, output, SDL_strlen(inputs[i].expected)) == 0,
  1049. "converted string should be correct");
  1050. } else {
  1051. SDLTest_AssertCheck(output == NULL, "result must be NULL");
  1052. }
  1053. SDL_free(output);
  1054. }
  1055. return TEST_COMPLETED;
  1056. }
  1057. static int SDLCALL
  1058. stdlib_strpbrk(void *arg)
  1059. {
  1060. struct {
  1061. const char *input;
  1062. const char *accept;
  1063. int expected[3]; /* negative if NULL */
  1064. } test_cases[] = {
  1065. { "", "", { -1, -1, -1 } },
  1066. { "abc", "", { -1, -1, -1 } },
  1067. { "Abc", "a", { -1, -1, -1 } },
  1068. { "abc", "a", { 0, -1, -1 } },
  1069. { "abcbd", "bbbb", { 1, 3, -1 } },
  1070. { "a;b;c", ";", { 1, 3, -1 } },
  1071. { "a;b;c", ",", { -1, -1, -1 } },
  1072. { "a:bbbb;c", ";:", { 1, 6, -1 } },
  1073. { "Hello\tS DL\n", " \t\r\n", { 5, 7, 10 } },
  1074. };
  1075. int i;
  1076. for (i = 0; i < SDL_arraysize(test_cases); i++) {
  1077. int j;
  1078. const char *input = test_cases[i].input;
  1079. for (j = 0; j < SDL_arraysize(test_cases[i].expected); j++) {
  1080. char *result;
  1081. SDLTest_AssertPass("About to call SDL_strpbrk(\"%s\", \"%s\")", input, test_cases[i].accept);
  1082. result = SDL_strpbrk(input, test_cases[i].accept);
  1083. if (test_cases[i].expected[j] < 0) {
  1084. SDLTest_AssertCheck(result == NULL, "Expected NULL, got %p", result);
  1085. } else {
  1086. 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);
  1087. input = test_cases[i].input + test_cases[i].expected[j] + 1;
  1088. }
  1089. }
  1090. }
  1091. return TEST_COMPLETED;
  1092. }
  1093. static int SDLCALL stdlib_wcstol(void *arg)
  1094. {
  1095. const long long_max = (~0UL) >> 1;
  1096. const long long_min = ((~0UL) >> 1) + 1UL;
  1097. #define WCSTOL_TEST_CASE(str, base, expected_result, expected_endp_offset) do { \
  1098. const wchar_t *s = str; \
  1099. long r, expected_r = expected_result; \
  1100. wchar_t *ep, *expected_ep = (wchar_t *)s + expected_endp_offset; \
  1101. r = SDL_wcstol(s, &ep, base); \
  1102. SDLTest_AssertPass("Call to SDL_wcstol(" #str ", &endp, " #base ")"); \
  1103. SDLTest_AssertCheck(r == expected_r, "Check result value, expected: %ld, got: %ld", expected_r, r); \
  1104. SDLTest_AssertCheck(ep == expected_ep, "Check endp value, expected: %p, got: %p", expected_ep, ep); \
  1105. } while (0)
  1106. // infer decimal
  1107. WCSTOL_TEST_CASE(L"\t 123abcxyz", 0, 123, 6); // skip leading space
  1108. WCSTOL_TEST_CASE(L"+123abcxyz", 0, 123, 4);
  1109. WCSTOL_TEST_CASE(L"-123abcxyz", 0, -123, 4);
  1110. WCSTOL_TEST_CASE(L"99999999999999999999abcxyz", 0, long_max, 20);
  1111. WCSTOL_TEST_CASE(L"-99999999999999999999abcxyz", 0, long_min, 21);
  1112. // infer hexadecimal
  1113. WCSTOL_TEST_CASE(L"0x123abcxyz", 0, 0x123abc, 8);
  1114. WCSTOL_TEST_CASE(L"0X123ABCXYZ", 0, 0x123abc, 8); // uppercase X
  1115. // infer octal
  1116. WCSTOL_TEST_CASE(L"0123abcxyz", 0, 0123, 4);
  1117. // arbitrary bases
  1118. WCSTOL_TEST_CASE(L"00110011", 2, 51, 8);
  1119. WCSTOL_TEST_CASE(L"-uvwxyz", 32, -991, 3);
  1120. WCSTOL_TEST_CASE(L"ZzZzZzZzZzZzZ", 36, long_max, 13);
  1121. WCSTOL_TEST_CASE(L"-0", 10, 0, 2);
  1122. WCSTOL_TEST_CASE(L" - 1", 0, 0, 0); // invalid input
  1123. // values near the bounds of the type
  1124. if (sizeof(long) == 4) {
  1125. WCSTOL_TEST_CASE(L"2147483647", 10, 2147483647, 10);
  1126. WCSTOL_TEST_CASE(L"2147483648", 10, 2147483647, 10);
  1127. WCSTOL_TEST_CASE(L"-2147483648", 10, -2147483647L - 1, 11);
  1128. WCSTOL_TEST_CASE(L"-2147483649", 10, -2147483647L - 1, 11);
  1129. WCSTOL_TEST_CASE(L"-9999999999999999999999999999999999999999", 10, -2147483647L - 1, 41);
  1130. }
  1131. #undef WCSTOL_TEST_CASE
  1132. return TEST_COMPLETED;
  1133. }
  1134. static int SDLCALL stdlib_strtox(void *arg)
  1135. {
  1136. const unsigned long long ullong_max = ~0ULL;
  1137. #define STRTOX_TEST_CASE(func_name, type, format_spec, str, base, expected_result, expected_endp_offset) do { \
  1138. const char *s = str; \
  1139. type r, expected_r = expected_result; \
  1140. char *ep, *expected_ep = (char *)s + expected_endp_offset; \
  1141. r = func_name(s, &ep, base); \
  1142. SDLTest_AssertPass("Call to " #func_name "(" #str ", &endp, " #base ")"); \
  1143. SDLTest_AssertCheck(r == expected_r, "Check result value, expected: " format_spec ", got: " format_spec, expected_r, r); \
  1144. SDLTest_AssertCheck(ep == expected_ep, "Check endp value, expected: %p, got: %p", expected_ep, ep); \
  1145. } while (0)
  1146. // infer decimal
  1147. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "\t 123abcxyz", 0, 123, 6); // skip leading space
  1148. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "+123abcxyz", 0, 123, 4);
  1149. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "+123abcxyz", 0, 123, 4);
  1150. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "-123abcxyz", 0, -123, 4);
  1151. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "9999999999999999999999999999999999999999abcxyz", 0, ullong_max, 40);
  1152. // infer hexadecimal
  1153. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "0x123abcxyz", 0, 0x123abc, 8);
  1154. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "0X123ABCXYZ", 0, 0x123abc, 8); // uppercase X
  1155. // infer octal
  1156. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "0123abcxyz", 0, 0123, 4);
  1157. // arbitrary bases
  1158. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "00110011", 2, 51, 8);
  1159. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "-uvwxyz", 32, -991, 3);
  1160. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "ZzZzZzZzZzZzZzZzZzZzZzZzZ", 36, ullong_max, 25);
  1161. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, "-0", 10, 0, 2);
  1162. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLu, " - 1", 0, 0, 0); // invalid input
  1163. // We know that SDL_strtol, SDL_strtoul and SDL_strtoll share the same code path as SDL_strtoull under the hood,
  1164. // so the most interesting test cases are those close to the bounds of the integer type.
  1165. // For simplicity, we only run long/long long tests when they are 32-bit/64-bit, respectively.
  1166. // Suppressing warnings would be difficult otherwise.
  1167. // Since the CI runs the tests against a variety of targets, this should be fine in practice.
  1168. if (sizeof(long) == 4) {
  1169. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "2147483647", 10, 2147483647, 10);
  1170. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "2147483648", 10, 2147483647, 10);
  1171. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "-2147483648", 10, -2147483647L - 1, 11);
  1172. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "-2147483649", 10, -2147483647L - 1, 11);
  1173. STRTOX_TEST_CASE(SDL_strtol, long, "%ld", "-9999999999999999999999999999999999999999", 10, -2147483647L - 1, 41);
  1174. STRTOX_TEST_CASE(SDL_strtoul, unsigned long, "%lu", "4294967295", 10, 4294967295UL, 10);
  1175. STRTOX_TEST_CASE(SDL_strtoul, unsigned long, "%lu", "4294967296", 10, 4294967295UL, 10);
  1176. STRTOX_TEST_CASE(SDL_strtoul, unsigned long, "%lu", "-4294967295", 10, 1, 11);
  1177. }
  1178. if (sizeof(long long) == 8) {
  1179. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "9223372036854775807", 10, 9223372036854775807LL, 19);
  1180. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "9223372036854775808", 10, 9223372036854775807LL, 19);
  1181. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "-9223372036854775808", 10, -9223372036854775807LL - 1, 20);
  1182. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "-9223372036854775809", 10, -9223372036854775807LL - 1, 20);
  1183. STRTOX_TEST_CASE(SDL_strtoll, long long, FMT_PRILLd, "-9999999999999999999999999999999999999999", 10, -9223372036854775807LL - 1, 41);
  1184. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLd, "18446744073709551615", 10, 18446744073709551615ULL, 20);
  1185. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLd, "18446744073709551616", 10, 18446744073709551615ULL, 20);
  1186. STRTOX_TEST_CASE(SDL_strtoull, unsigned long long, FMT_PRILLd, "-18446744073709551615", 10, 1, 21);
  1187. }
  1188. #undef STRTOX_TEST_CASE
  1189. return TEST_COMPLETED;
  1190. }
  1191. static int SDLCALL stdlib_strtod(void *arg)
  1192. {
  1193. #define STRTOD_TEST_CASE(str, expected_result, expected_endp_offset) do { \
  1194. const char *s = str; \
  1195. double r, expected_r = expected_result; \
  1196. char *ep, *expected_ep = (char *)s + expected_endp_offset; \
  1197. r = SDL_strtod(s, &ep); \
  1198. SDLTest_AssertPass("Call to SDL_strtod(" #str ", &endp)"); \
  1199. SDLTest_AssertCheck(r == expected_r, "Check result value, expected: %f, got: %f", expected_r, r); \
  1200. SDLTest_AssertCheck(ep == expected_ep, "Check endp value, expected: %p, got: %p", expected_ep, ep); \
  1201. } while (0)
  1202. STRTOD_TEST_CASE("\t 123.75abcxyz", 123.75, 9); // skip leading space
  1203. STRTOD_TEST_CASE("+999.555", 999.555, 8);
  1204. STRTOD_TEST_CASE("-999.555", -999.555, 8);
  1205. #undef STRTOD_TEST_CASE
  1206. return TEST_COMPLETED;
  1207. }
  1208. /* ================= Test References ================== */
  1209. /* Standard C routine test cases */
  1210. static const SDLTest_TestCaseReference stdlibTest_strnlen = {
  1211. stdlib_strnlen, "stdlib_strnlen", "Call to SDL_strnlen", TEST_ENABLED
  1212. };
  1213. static const SDLTest_TestCaseReference stdlibTest_strlcpy = {
  1214. stdlib_strlcpy, "stdlib_strlcpy", "Call to SDL_strlcpy", TEST_ENABLED
  1215. };
  1216. static const SDLTest_TestCaseReference stdlibTest_strstr = {
  1217. stdlib_strstr, "stdlib_strstr", "Call to SDL_strstr", TEST_ENABLED
  1218. };
  1219. static const SDLTest_TestCaseReference stdlibTest_snprintf = {
  1220. stdlib_snprintf, "stdlib_snprintf", "Call to SDL_snprintf", TEST_ENABLED
  1221. };
  1222. static const SDLTest_TestCaseReference stdlibTest_swprintf = {
  1223. stdlib_swprintf, "stdlib_swprintf", "Call to SDL_swprintf", TEST_ENABLED
  1224. };
  1225. static const SDLTest_TestCaseReference stdlibTest_getsetenv = {
  1226. stdlib_getsetenv, "stdlib_getsetenv", "Call to SDL_GetEnvironmentVariable and SDL_SetEnvironmentVariable", TEST_ENABLED
  1227. };
  1228. static const SDLTest_TestCaseReference stdlibTest_sscanf = {
  1229. stdlib_sscanf, "stdlib_sscanf", "Call to SDL_sscanf", TEST_ENABLED
  1230. };
  1231. static const SDLTest_TestCaseReference stdlibTest_aligned_alloc = {
  1232. stdlib_aligned_alloc, "stdlib_aligned_alloc", "Call to SDL_aligned_alloc", TEST_ENABLED
  1233. };
  1234. static const SDLTest_TestCaseReference stdlibTestOverflow = {
  1235. stdlib_overflow, "stdlib_overflow", "Overflow detection", TEST_ENABLED
  1236. };
  1237. static const SDLTest_TestCaseReference stdlibTest_iconv = {
  1238. stdlib_iconv, "stdlib_iconv", "Calls to SDL_iconv", TEST_ENABLED
  1239. };
  1240. static const SDLTest_TestCaseReference stdlibTest_strpbrk = {
  1241. stdlib_strpbrk, "stdlib_strpbrk", "Calls to SDL_strpbrk", TEST_ENABLED
  1242. };
  1243. static const SDLTest_TestCaseReference stdlibTest_wcstol = {
  1244. stdlib_wcstol, "stdlib_wcstol", "Calls to SDL_wcstol", TEST_ENABLED
  1245. };
  1246. static const SDLTest_TestCaseReference stdlibTest_strtox = {
  1247. stdlib_strtox, "stdlib_strtox", "Calls to SDL_strtol, SDL_strtoul, SDL_strtoll and SDL_strtoull", TEST_ENABLED
  1248. };
  1249. static const SDLTest_TestCaseReference stdlibTest_strtod = {
  1250. stdlib_strtod, "stdlib_strtod", "Calls to SDL_strtod", TEST_ENABLED
  1251. };
  1252. /* Sequence of Standard C routine test cases */
  1253. static const SDLTest_TestCaseReference *stdlibTests[] = {
  1254. &stdlibTest_strnlen,
  1255. &stdlibTest_strlcpy,
  1256. &stdlibTest_strstr,
  1257. &stdlibTest_snprintf,
  1258. &stdlibTest_swprintf,
  1259. &stdlibTest_getsetenv,
  1260. &stdlibTest_sscanf,
  1261. &stdlibTest_aligned_alloc,
  1262. &stdlibTestOverflow,
  1263. &stdlibTest_iconv,
  1264. &stdlibTest_strpbrk,
  1265. &stdlibTest_wcstol,
  1266. &stdlibTest_strtox,
  1267. &stdlibTest_strtod,
  1268. NULL
  1269. };
  1270. /* Standard C routine test suite (global) */
  1271. SDLTest_TestSuiteReference stdlibTestSuite = {
  1272. "Stdlib",
  1273. NULL,
  1274. stdlibTests,
  1275. NULL
  1276. };