testautomation_stdlib.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574
  1. /**
  2. * Standard C library routine test suite
  3. */
  4. #include <stdio.h>
  5. #include "SDL.h"
  6. #include "SDL_test.h"
  7. /* Test case functions */
  8. /**
  9. * @brief Call to SDL_strlcpy
  10. */
  11. #undef SDL_strlcpy
  12. int
  13. stdlib_strlcpy(void *arg)
  14. {
  15. size_t result;
  16. char text[1024];
  17. const char *expected;
  18. result = SDL_strlcpy(text, "foo", sizeof(text));
  19. expected = "foo";
  20. SDLTest_AssertPass("Call to SDL_strlcpy(\"foo\")");
  21. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  22. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), (int) result);
  23. result = SDL_strlcpy(text, "foo", 2);
  24. expected = "f";
  25. SDLTest_AssertPass("Call to SDL_strlcpy(\"foo\") with buffer size 2");
  26. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  27. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", (int) result);
  28. return TEST_COMPLETED;
  29. }
  30. /**
  31. * @brief Call to SDL_snprintf
  32. */
  33. #undef SDL_snprintf
  34. int
  35. stdlib_snprintf(void *arg)
  36. {
  37. int result;
  38. int predicted;
  39. char text[1024];
  40. const char *expected;
  41. size_t size;
  42. result = SDL_snprintf(text, sizeof(text), "%s", "foo");
  43. expected = "foo";
  44. SDLTest_AssertPass("Call to SDL_snprintf(\"%%s\", \"foo\")");
  45. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  46. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  47. result = SDL_snprintf(text, 2, "%s", "foo");
  48. expected = "f";
  49. SDLTest_AssertPass("Call to SDL_snprintf(\"%%s\", \"foo\") with buffer size 2");
  50. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  51. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", result);
  52. result = SDL_snprintf(NULL, 0, "%s", "foo");
  53. SDLTest_AssertPass("Call to SDL_snprintf(NULL, 0, \"%%s\", \"foo\")");
  54. SDLTest_AssertCheck(result == 3, "Check result value, expected: 3, got: %d", result);
  55. result = SDL_snprintf(text, 2, "%s\n", "foo");
  56. expected = "f";
  57. SDLTest_AssertPass("Call to SDL_snprintf(\"%%s\\n\", \"foo\") with buffer size 2");
  58. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  59. SDLTest_AssertCheck(result == 4, "Check result value, expected: 4, got: %d", result);
  60. result = SDL_snprintf(text, sizeof(text), "%f", 0.0);
  61. predicted = SDL_snprintf(NULL, 0, "%f", 0.0);
  62. expected = "0.000000";
  63. SDLTest_AssertPass("Call to SDL_snprintf(\"%%f\", 0.0)");
  64. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  65. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  66. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  67. result = SDL_snprintf(text, sizeof(text), "%f", 1.0);
  68. predicted = SDL_snprintf(NULL, 0, "%f", 1.0);
  69. expected = "1.000000";
  70. SDLTest_AssertPass("Call to SDL_snprintf(\"%%f\", 1.0)");
  71. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  72. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  73. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  74. result = SDL_snprintf(text, sizeof(text), "%.f", 1.0);
  75. predicted = SDL_snprintf(NULL, 0, "%.f", 1.0);
  76. expected = "1";
  77. SDLTest_AssertPass("Call to SDL_snprintf(\"%%.f\", 1.0)");
  78. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  79. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  80. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  81. result = SDL_snprintf(text, sizeof(text), "%#.f", 1.0);
  82. predicted = SDL_snprintf(NULL, 0, "%#.f", 1.0);
  83. expected = "1.";
  84. SDLTest_AssertPass("Call to SDL_snprintf(\"%%#.f\", 1.0)");
  85. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  86. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  87. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  88. result = SDL_snprintf(text, sizeof(text), "%f", 1.0 + 1.0 / 3.0);
  89. predicted = SDL_snprintf(NULL, 0, "%f", 1.0 + 1.0 / 3.0);
  90. expected = "1.333333";
  91. SDLTest_AssertPass("Call to SDL_snprintf(\"%%f\", 1.0 + 1.0 / 3.0)");
  92. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  93. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  94. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  95. result = SDL_snprintf(text, sizeof(text), "%+f", 1.0 + 1.0 / 3.0);
  96. predicted = SDL_snprintf(NULL, 0, "%+f", 1.0 + 1.0 / 3.0);
  97. expected = "+1.333333";
  98. SDLTest_AssertPass("Call to SDL_snprintf(\"%%+f\", 1.0 + 1.0 / 3.0)");
  99. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  100. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  101. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  102. result = SDL_snprintf(text, sizeof(text), "%.2f", 1.0 + 1.0 / 3.0);
  103. predicted = SDL_snprintf(NULL, 0, "%.2f", 1.0 + 1.0 / 3.0);
  104. expected = "1.33";
  105. SDLTest_AssertPass("Call to SDL_snprintf(\"%%.2f\", 1.0 + 1.0 / 3.0)");
  106. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: %s, got: %s", expected, text);
  107. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  108. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  109. result = SDL_snprintf(text, sizeof(text), "%6.2f", 1.0 + 1.0 / 3.0);
  110. predicted = SDL_snprintf(NULL, 0, "%6.2f", 1.0 + 1.0 / 3.0);
  111. expected = " 1.33";
  112. SDLTest_AssertPass("Call to SDL_snprintf(\"%%6.2f\", 1.0 + 1.0 / 3.0)");
  113. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  114. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  115. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  116. result = SDL_snprintf(text, sizeof(text), "%06.2f", 1.0 + 1.0 / 3.0);
  117. predicted = SDL_snprintf(NULL, 0, "%06.2f", 1.0 + 1.0 / 3.0);
  118. expected = "001.33";
  119. SDLTest_AssertPass("Call to SDL_snprintf(\"%%06.2f\", 1.0 + 1.0 / 3.0)");
  120. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  121. SDLTest_AssertCheck(result == SDL_strlen(text), "Check result value, expected: %d, got: %d", (int) SDL_strlen(text), result);
  122. SDLTest_AssertCheck(predicted == result, "Check predicted value, expected: %d, got: %d", result, predicted);
  123. result = SDL_snprintf(text, 5, "%06.2f", 1.0 + 1.0 / 3.0);
  124. expected = "001.";
  125. SDLTest_AssertPass("Call to SDL_snprintf(\"%%06.2f\", 1.0 + 1.0 / 3.0) with buffer size 5");
  126. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  127. SDLTest_AssertCheck(result == 6, "Check result value, expected: 6, got: %d", result);
  128. size = 64;
  129. result = SDL_snprintf(text, sizeof(text), "%zu %s", size, "test");
  130. expected = "64 test";
  131. SDLTest_AssertPass("Call to SDL_snprintf(text, sizeof(text), \"%%zu %%s\", size, \"test\")");
  132. SDLTest_AssertCheck(SDL_strcmp(text, expected) == 0, "Check text, expected: '%s', got: '%s'", expected, text);
  133. SDLTest_AssertCheck(result == 7, "Check result value, expected: 7, got: %d", result);
  134. return TEST_COMPLETED;
  135. }
  136. /**
  137. * @brief Call to SDL_getenv and SDL_setenv
  138. */
  139. int
  140. stdlib_getsetenv(void *arg)
  141. {
  142. const int nameLen = 16;
  143. char name[17];
  144. int counter;
  145. int result;
  146. char * value1;
  147. char * value2;
  148. char * expected;
  149. int overwrite;
  150. char * text;
  151. /* Create a random name. This tests SDL_getenv, since we need to */
  152. /* make sure the variable is not set yet (it shouldn't). */
  153. do {
  154. for(counter = 0; counter < nameLen; counter++) {
  155. name[counter] = (char)SDLTest_RandomIntegerInRange(65, 90);
  156. }
  157. name[nameLen] = '\0';
  158. text = SDL_getenv(name);
  159. SDLTest_AssertPass("Call to SDL_getenv('%s')", name);
  160. if (text != NULL) {
  161. SDLTest_Log("Expected: NULL, Got: '%s' (%i)", text, (int) SDL_strlen(text));
  162. }
  163. } while (text != NULL);
  164. /* Create random values to set */
  165. value1 = SDLTest_RandomAsciiStringOfSize(10);
  166. value2 = SDLTest_RandomAsciiStringOfSize(10);
  167. /* Set value 1 without overwrite */
  168. overwrite = 0;
  169. expected = value1;
  170. result = SDL_setenv(name, value1, overwrite);
  171. SDLTest_AssertPass("Call to SDL_setenv('%s','%s', %i)", name, value1, overwrite);
  172. SDLTest_AssertCheck(result == 0, "Check result, expected: 0, got: %i", result);
  173. /* Check value */
  174. text = SDL_getenv(name);
  175. SDLTest_AssertPass("Call to SDL_getenv('%s')", name);
  176. SDLTest_AssertCheck(text != NULL, "Verify returned text is not NULL");
  177. if (text != NULL) {
  178. SDLTest_AssertCheck(
  179. SDL_strcmp(text, expected) == 0,
  180. "Verify returned text, expected: %s, got: %s",
  181. expected,
  182. text);
  183. }
  184. /* Set value 2 with overwrite */
  185. overwrite = 1;
  186. expected = value2;
  187. result = SDL_setenv(name, value2, overwrite);
  188. SDLTest_AssertPass("Call to SDL_setenv('%s','%s', %i)", name, value2, overwrite);
  189. SDLTest_AssertCheck(result == 0, "Check result, expected: 0, got: %i", result);
  190. /* Check value */
  191. text = SDL_getenv(name);
  192. SDLTest_AssertPass("Call to SDL_getenv('%s')", name);
  193. SDLTest_AssertCheck(text != NULL, "Verify returned text is not NULL");
  194. if (text != NULL) {
  195. SDLTest_AssertCheck(
  196. SDL_strcmp(text, expected) == 0,
  197. "Verify returned text, expected: %s, got: %s",
  198. expected,
  199. text);
  200. }
  201. /* Set value 1 without overwrite */
  202. overwrite = 0;
  203. expected = value2;
  204. result = SDL_setenv(name, value1, overwrite);
  205. SDLTest_AssertPass("Call to SDL_setenv('%s','%s', %i)", name, value1, overwrite);
  206. SDLTest_AssertCheck(result == 0, "Check result, expected: 0, got: %i", result);
  207. /* Check value */
  208. text = SDL_getenv(name);
  209. SDLTest_AssertPass("Call to SDL_getenv('%s')", name);
  210. SDLTest_AssertCheck(text != NULL, "Verify returned text is not NULL");
  211. if (text != NULL) {
  212. SDLTest_AssertCheck(
  213. SDL_strcmp(text, expected) == 0,
  214. "Verify returned text, expected: %s, got: %s",
  215. expected,
  216. text);
  217. }
  218. /* Set value 1 without overwrite */
  219. overwrite = 1;
  220. expected = value1;
  221. result = SDL_setenv(name, value1, overwrite);
  222. SDLTest_AssertPass("Call to SDL_setenv('%s','%s', %i)", name, value1, overwrite);
  223. SDLTest_AssertCheck(result == 0, "Check result, expected: 0, got: %i", result);
  224. /* Check value */
  225. text = SDL_getenv(name);
  226. SDLTest_AssertPass("Call to SDL_getenv('%s')", name);
  227. SDLTest_AssertCheck(text != NULL, "Verify returned text is not NULL");
  228. if (text != NULL) {
  229. SDLTest_AssertCheck(
  230. SDL_strcmp(text, expected) == 0,
  231. "Verify returned text, expected: %s, got: %s",
  232. expected,
  233. text);
  234. }
  235. /* Negative cases */
  236. for (overwrite=0; overwrite <= 1; overwrite++) {
  237. result = SDL_setenv(NULL, value1, overwrite);
  238. SDLTest_AssertPass("Call to SDL_setenv(NULL,'%s', %i)", value1, overwrite);
  239. SDLTest_AssertCheck(result == -1, "Check result, expected: -1, got: %i", result);
  240. result = SDL_setenv("", value1, overwrite);
  241. SDLTest_AssertPass("Call to SDL_setenv('','%s', %i)", value1, overwrite);
  242. SDLTest_AssertCheck(result == -1, "Check result, expected: -1, got: %i", result);
  243. result = SDL_setenv("=", value1, overwrite);
  244. SDLTest_AssertPass("Call to SDL_setenv('=','%s', %i)", value1, overwrite);
  245. SDLTest_AssertCheck(result == -1, "Check result, expected: -1, got: %i", result);
  246. result = SDL_setenv(name, NULL, overwrite);
  247. SDLTest_AssertPass("Call to SDL_setenv('%s', NULL, %i)", name, overwrite);
  248. SDLTest_AssertCheck(result == -1, "Check result, expected: -1, got: %i", result);
  249. }
  250. /* Clean up */
  251. SDL_free(value1);
  252. SDL_free(value2);
  253. return TEST_COMPLETED;
  254. }
  255. /**
  256. * @brief Call to SDL_sscanf
  257. */
  258. #undef SDL_sscanf
  259. int
  260. stdlib_sscanf(void *arg)
  261. {
  262. int output;
  263. int result;
  264. int expected_output;
  265. int expected_result;
  266. short short_output, expected_short_output;
  267. long long_output, expected_long_output;
  268. long long long_long_output, expected_long_long_output;
  269. size_t size_output, expected_size_output;
  270. char text[128];
  271. expected_output = output = 123;
  272. expected_result = -1;
  273. result = SDL_sscanf("", "%i", &output);
  274. SDLTest_AssertPass("Call to SDL_sscanf(\"\", \"%%i\", &output)");
  275. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  276. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  277. expected_output = output = 123;
  278. expected_result = 0;
  279. result = SDL_sscanf("a", "%i", &output);
  280. SDLTest_AssertPass("Call to SDL_sscanf(\"a\", \"%%i\", &output)");
  281. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  282. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  283. output = 123;
  284. expected_output = 2;
  285. expected_result = 1;
  286. result = SDL_sscanf("2", "%i", &output);
  287. SDLTest_AssertPass("Call to SDL_sscanf(\"2\", \"%%i\", &output)");
  288. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  289. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  290. output = 123;
  291. expected_output = 0xa;
  292. expected_result = 1;
  293. result = SDL_sscanf("aa", "%1x", &output);
  294. SDLTest_AssertPass("Call to SDL_sscanf(\"aa\", \"%%1x\", &output)");
  295. SDLTest_AssertCheck(expected_output == output, "Check output, expected: %i, got: %i", expected_output, output);
  296. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  297. #define SIZED_TEST_CASE(type, var, format_specifier) \
  298. var##_output = 123; \
  299. expected_##var##_output = (type)(((unsigned type)(~0)) >> 1); \
  300. expected_result = 1; \
  301. result = SDL_snprintf(text, sizeof(text), format_specifier, expected_##var##_output); \
  302. result = SDL_sscanf(text, format_specifier, &var##_output); \
  303. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", \"%s\", &output)", text, #format_specifier); \
  304. SDLTest_AssertCheck(expected_##var##_output == var##_output, "Check output, expected: " format_specifier ", got: " format_specifier, expected_##var##_output, var##_output); \
  305. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result); \
  306. \
  307. var##_output = 123; \
  308. expected_##var##_output = ~(type)(((unsigned type)(~0)) >> 1); \
  309. expected_result = 1; \
  310. result = SDL_snprintf(text, sizeof(text), format_specifier, expected_##var##_output); \
  311. result = SDL_sscanf(text, format_specifier, &var##_output); \
  312. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", \"%s\", &output)", text, #format_specifier); \
  313. SDLTest_AssertCheck(expected_##var##_output == var##_output, "Check output, expected: " format_specifier ", got: " format_specifier, expected_##var##_output, var##_output); \
  314. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result); \
  315. SIZED_TEST_CASE(short, short, "%hd")
  316. SIZED_TEST_CASE(long, long, "%ld")
  317. SIZED_TEST_CASE(long long, long_long, "%lld")
  318. size_output = 123;
  319. expected_size_output = (size_t)~0;
  320. expected_result = 1;
  321. result = SDL_snprintf(text, sizeof(text), "%zu", expected_size_output);
  322. result = SDL_sscanf(text, "%zu", &size_output);
  323. SDLTest_AssertPass("Call to SDL_sscanf(\"%s\", \"%%zu\", &output)", text);
  324. SDLTest_AssertCheck(expected_size_output == size_output, "Check output, expected: %zu, got: %zu", expected_size_output, size_output);
  325. SDLTest_AssertCheck(expected_result == result, "Check return value, expected: %i, got: %i", expected_result, result);
  326. return TEST_COMPLETED;
  327. }
  328. #if defined(_WIN64)
  329. # define SIZE_FORMAT "I64u"
  330. #elif defined(__WIN32__)
  331. # define SIZE_FORMAT "I32u"
  332. #else
  333. # define SIZE_FORMAT "zu"
  334. #endif
  335. typedef struct
  336. {
  337. size_t a;
  338. size_t b;
  339. size_t result;
  340. int status;
  341. } overflow_test;
  342. static const overflow_test multiplications[] =
  343. {
  344. { 1, 1, 1, 0 },
  345. { 0, 0, 0, 0 },
  346. { SDL_SIZE_MAX, 0, 0, 0 },
  347. { SDL_SIZE_MAX, 1, SDL_SIZE_MAX, 0 },
  348. { SDL_SIZE_MAX / 2, 2, SDL_SIZE_MAX - (SDL_SIZE_MAX % 2), 0 },
  349. { SDL_SIZE_MAX / 23, 23, SDL_SIZE_MAX - (SDL_SIZE_MAX % 23), 0 },
  350. { (SDL_SIZE_MAX / 2) + 1, 2, 0, -1 },
  351. { (SDL_SIZE_MAX / 23) + 42, 23, 0, -1 },
  352. { SDL_SIZE_MAX, SDL_SIZE_MAX, 0, -1 },
  353. };
  354. static const overflow_test additions[] =
  355. {
  356. { 1, 1, 2, 0 },
  357. { 0, 0, 0, 0 },
  358. { SDL_SIZE_MAX, 0, SDL_SIZE_MAX, 0 },
  359. { SDL_SIZE_MAX - 1, 1, SDL_SIZE_MAX, 0 },
  360. { SDL_SIZE_MAX - 42, 23, SDL_SIZE_MAX - (42 - 23), 0 },
  361. { SDL_SIZE_MAX, 1, 0, -1 },
  362. { SDL_SIZE_MAX, 23, 0, -1 },
  363. { SDL_SIZE_MAX, SDL_SIZE_MAX, 0, -1 },
  364. };
  365. static int
  366. stdlib_overflow(void *arg)
  367. {
  368. size_t i;
  369. size_t useBuiltin;
  370. for (useBuiltin = 0; useBuiltin < 2; useBuiltin++) {
  371. if (useBuiltin) {
  372. SDLTest_Log("Using gcc/clang builtins if possible");
  373. } else {
  374. SDLTest_Log("Not using gcc/clang builtins");
  375. }
  376. for (i = 0; i < SDL_arraysize(multiplications); i++) {
  377. const overflow_test *t = &multiplications[i];
  378. int status;
  379. size_t result = ~t->result;
  380. if (useBuiltin) {
  381. status = SDL_size_mul_overflow(t->a, t->b, &result);
  382. } else {
  383. /* This disables the macro that tries to use a gcc/clang
  384. * builtin, so we test the fallback implementation instead. */
  385. status = (SDL_size_mul_overflow)(t->a, t->b, &result);
  386. }
  387. if (t->status == 0) {
  388. SDLTest_AssertCheck(status == 0,
  389. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should succeed",
  390. t->a, t->b);
  391. SDLTest_AssertCheck(result == t->result,
  392. "(%" SIZE_FORMAT " * %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  393. t->a, t->b, t->result, result);
  394. } else {
  395. SDLTest_AssertCheck(status == -1,
  396. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should fail",
  397. t->a, t->b);
  398. }
  399. if (t->a == t->b) {
  400. continue;
  401. }
  402. result = ~t->result;
  403. if (useBuiltin) {
  404. status = SDL_size_mul_overflow(t->b, t->a, &result);
  405. } else {
  406. status = (SDL_size_mul_overflow)(t->b, t->a, &result);
  407. }
  408. if (t->status == 0) {
  409. SDLTest_AssertCheck(status == 0,
  410. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should succeed",
  411. t->b, t->a);
  412. SDLTest_AssertCheck(result == t->result,
  413. "(%" SIZE_FORMAT " * %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  414. t->b, t->a, t->result, result);
  415. } else {
  416. SDLTest_AssertCheck(status == -1,
  417. "(%" SIZE_FORMAT " * %" SIZE_FORMAT ") should fail",
  418. t->b, t->a);
  419. }
  420. }
  421. for (i = 0; i < SDL_arraysize(additions); i++) {
  422. const overflow_test *t = &additions[i];
  423. int status;
  424. size_t result = ~t->result;
  425. if (useBuiltin) {
  426. status = SDL_size_add_overflow(t->a, t->b, &result);
  427. } else {
  428. status = (SDL_size_add_overflow)(t->a, t->b, &result);
  429. }
  430. if (t->status == 0) {
  431. SDLTest_AssertCheck(status == 0,
  432. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should succeed",
  433. t->a, t->b);
  434. SDLTest_AssertCheck(result == t->result,
  435. "(%" SIZE_FORMAT " + %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  436. t->a, t->b, t->result, result);
  437. } else {
  438. SDLTest_AssertCheck(status == -1,
  439. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should fail",
  440. t->a, t->b);
  441. }
  442. if (t->a == t->b) {
  443. continue;
  444. }
  445. result = ~t->result;
  446. if (useBuiltin) {
  447. status = SDL_size_add_overflow(t->b, t->a, &result);
  448. } else {
  449. status = (SDL_size_add_overflow)(t->b, t->a, &result);
  450. }
  451. if (t->status == 0) {
  452. SDLTest_AssertCheck(status == 0,
  453. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should succeed",
  454. t->b, t->a);
  455. SDLTest_AssertCheck(result == t->result,
  456. "(%" SIZE_FORMAT " + %" SIZE_FORMAT "): expected %" SIZE_FORMAT ", got %" SIZE_FORMAT,
  457. t->b, t->a, t->result, result);
  458. } else {
  459. SDLTest_AssertCheck(status == -1,
  460. "(%" SIZE_FORMAT " + %" SIZE_FORMAT ") should fail",
  461. t->b, t->a);
  462. }
  463. }
  464. }
  465. return TEST_COMPLETED;
  466. }
  467. /* ================= Test References ================== */
  468. /* Standard C routine test cases */
  469. static const SDLTest_TestCaseReference stdlibTest1 =
  470. { (SDLTest_TestCaseFp)stdlib_strlcpy, "stdlib_strlcpy", "Call to SDL_strlcpy", TEST_ENABLED };
  471. static const SDLTest_TestCaseReference stdlibTest2 =
  472. { (SDLTest_TestCaseFp)stdlib_snprintf, "stdlib_snprintf", "Call to SDL_snprintf", TEST_ENABLED };
  473. static const SDLTest_TestCaseReference stdlibTest3 =
  474. { (SDLTest_TestCaseFp)stdlib_getsetenv, "stdlib_getsetenv", "Call to SDL_getenv and SDL_setenv", TEST_ENABLED };
  475. static const SDLTest_TestCaseReference stdlibTest4 =
  476. { (SDLTest_TestCaseFp)stdlib_sscanf, "stdlib_sscanf", "Call to SDL_sscanf", TEST_ENABLED };
  477. static const SDLTest_TestCaseReference stdlibTestOverflow =
  478. { stdlib_overflow, "stdlib_overflow", "Overflow detection", TEST_ENABLED };
  479. /* Sequence of Standard C routine test cases */
  480. static const SDLTest_TestCaseReference *stdlibTests[] = {
  481. &stdlibTest1,
  482. &stdlibTest2,
  483. &stdlibTest3,
  484. &stdlibTest4,
  485. &stdlibTestOverflow,
  486. NULL
  487. };
  488. /* Standard C routine test suite (global) */
  489. SDLTest_TestSuiteReference stdlibTestSuite = {
  490. "Stdlib",
  491. NULL,
  492. stdlibTests,
  493. NULL
  494. };