test-strstr.c 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. /* Test and measure strstr functions.
  2. Copyright (C) 2010-2019 Free Software Foundation, Inc.
  3. This file is part of the GNU C Library.
  4. Written by Ulrich Drepper <drepper@redhat.com>, 2010.
  5. The GNU C Library is free software; you can redistribute it and/or
  6. modify it under the terms of the GNU Lesser General Public
  7. License as published by the Free Software Foundation; either
  8. version 2.1 of the License, or (at your option) any later version.
  9. The GNU C Library is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. Lesser General Public License for more details.
  13. You should have received a copy of the GNU Lesser General Public
  14. License along with the GNU C Library; if not, see
  15. <http://www.gnu.org/licenses/>. */
  16. #define TEST_MAIN
  17. #define TEST_NAME "strstr"
  18. #include "test-string.h"
  19. #define STRSTR simple_strstr
  20. #define libc_hidden_builtin_def(arg) /* nothing */
  21. #define __strnlen strnlen
  22. #include "strstr.c"
  23. static char *
  24. stupid_strstr (const char *s1, const char *s2)
  25. {
  26. ssize_t s1len = strlen (s1);
  27. ssize_t s2len = strlen (s2);
  28. if (s2len > s1len)
  29. return NULL;
  30. for (ssize_t i = 0; i <= s1len - s2len; ++i)
  31. {
  32. size_t j;
  33. for (j = 0; j < s2len; ++j)
  34. if (s1[i + j] != s2[j])
  35. break;
  36. if (j == s2len)
  37. return (char *) s1 + i;
  38. }
  39. return NULL;
  40. }
  41. typedef char *(*proto_t) (const char *, const char *);
  42. IMPL (stupid_strstr, 0)
  43. IMPL (simple_strstr, 0)
  44. IMPL (strstr, 1)
  45. static int
  46. check_result (impl_t *impl, const char *s1, const char *s2,
  47. char *exp_result)
  48. {
  49. char *result = CALL (impl, s1, s2);
  50. if (result != exp_result)
  51. {
  52. error (0, 0, "Wrong result in function %s %s %s", impl->name,
  53. result, exp_result);
  54. ret = 1;
  55. return -1;
  56. }
  57. return 0;
  58. }
  59. static void
  60. do_one_test (impl_t *impl, const char *s1, const char *s2, char *exp_result)
  61. {
  62. if (check_result (impl, s1, s2, exp_result) < 0)
  63. return;
  64. }
  65. static void
  66. do_test (size_t align1, size_t align2, size_t len1, size_t len2,
  67. int fail)
  68. {
  69. char *s1 = (char *) (buf1 + align1);
  70. char *s2 = (char *) (buf2 + align2);
  71. static const char d[] = "1234567890abcdef";
  72. #define dl (sizeof (d) - 1)
  73. char *ss2 = s2;
  74. for (size_t l = len2; l > 0; l = l > dl ? l - dl : 0)
  75. {
  76. size_t t = l > dl ? dl : l;
  77. ss2 = mempcpy (ss2, d, t);
  78. }
  79. s2[len2] = '\0';
  80. if (fail)
  81. {
  82. char *ss1 = s1;
  83. for (size_t l = len1; l > 0; l = l > dl ? l - dl : 0)
  84. {
  85. size_t t = l > dl ? dl : l;
  86. memcpy (ss1, d, t);
  87. ++ss1[len2 > 7 ? 7 : len2 - 1];
  88. ss1 += t;
  89. }
  90. }
  91. else
  92. {
  93. memset (s1, '0', len1);
  94. memcpy (s1 + len1 - len2, s2, len2);
  95. }
  96. s1[len1] = '\0';
  97. FOR_EACH_IMPL (impl, 0)
  98. do_one_test (impl, s1, s2, fail ? NULL : s1 + len1 - len2);
  99. }
  100. static void
  101. check1 (void)
  102. {
  103. const char s1[] =
  104. "F_BD_CE_BD_EF_BF_BD_EF_BF_BD_EF_BF_BD_EF_BF_BD_C3_88_20_EF_BF_BD_EF_BF_BD_EF_BF_BD_C3_A7_20_EF_BF_BD";
  105. const char s2[] = "_EF_BF_BD_EF_BF_BD_EF_BF_BD_EF_BF_BD_EF_BF_BD";
  106. char *exp_result;
  107. exp_result = stupid_strstr (s1, s2);
  108. FOR_EACH_IMPL (impl, 0)
  109. check_result (impl, s1, s2, exp_result);
  110. }
  111. static void
  112. check2 (void)
  113. {
  114. const char s1[] = ", enable_static, \0, enable_shared, ";
  115. char *exp_result;
  116. char *s2 = (void *) buf1 + page_size - 18;
  117. strcpy (s2, s1);
  118. exp_result = stupid_strstr (s1, s1 + 18);
  119. FOR_EACH_IMPL (impl, 0)
  120. {
  121. check_result (impl, s1, s1 + 18, exp_result);
  122. check_result (impl, s2, s1 + 18, exp_result);
  123. }
  124. }
  125. #define N 1024
  126. static void
  127. pr23637 (void)
  128. {
  129. char *h = (char*) buf1;
  130. char *n = (char*) buf2;
  131. for (int i = 0; i < N; i++)
  132. {
  133. n[i] = 'x';
  134. h[i] = ' ';
  135. h[i + N] = 'x';
  136. }
  137. n[N] = '\0';
  138. h[N * 2] = '\0';
  139. /* Ensure we don't match at the first 'x'. */
  140. h[0] = 'x';
  141. char *exp_result = stupid_strstr (h, n);
  142. FOR_EACH_IMPL (impl, 0)
  143. check_result (impl, h, n, exp_result);
  144. }
  145. static int
  146. test_main (void)
  147. {
  148. test_init ();
  149. check1 ();
  150. check2 ();
  151. pr23637 ();
  152. printf ("%23s", "");
  153. FOR_EACH_IMPL (impl, 0)
  154. printf ("\t%s", impl->name);
  155. putchar ('\n');
  156. for (size_t klen = 2; klen < 32; ++klen)
  157. for (size_t hlen = 2 * klen; hlen < 16 * klen; hlen += klen)
  158. {
  159. do_test (0, 0, hlen, klen, 0);
  160. do_test (0, 0, hlen, klen, 1);
  161. do_test (0, 3, hlen, klen, 0);
  162. do_test (0, 3, hlen, klen, 1);
  163. do_test (0, 9, hlen, klen, 0);
  164. do_test (0, 9, hlen, klen, 1);
  165. do_test (0, 15, hlen, klen, 0);
  166. do_test (0, 15, hlen, klen, 1);
  167. do_test (3, 0, hlen, klen, 0);
  168. do_test (3, 0, hlen, klen, 1);
  169. do_test (3, 3, hlen, klen, 0);
  170. do_test (3, 3, hlen, klen, 1);
  171. do_test (3, 9, hlen, klen, 0);
  172. do_test (3, 9, hlen, klen, 1);
  173. do_test (3, 15, hlen, klen, 0);
  174. do_test (3, 15, hlen, klen, 1);
  175. do_test (9, 0, hlen, klen, 0);
  176. do_test (9, 0, hlen, klen, 1);
  177. do_test (9, 3, hlen, klen, 0);
  178. do_test (9, 3, hlen, klen, 1);
  179. do_test (9, 9, hlen, klen, 0);
  180. do_test (9, 9, hlen, klen, 1);
  181. do_test (9, 15, hlen, klen, 0);
  182. do_test (9, 15, hlen, klen, 1);
  183. do_test (15, 0, hlen, klen, 0);
  184. do_test (15, 0, hlen, klen, 1);
  185. do_test (15, 3, hlen, klen, 0);
  186. do_test (15, 3, hlen, klen, 1);
  187. do_test (15, 9, hlen, klen, 0);
  188. do_test (15, 9, hlen, klen, 1);
  189. do_test (15, 15, hlen, klen, 0);
  190. do_test (15, 15, hlen, klen, 1);
  191. do_test (15, 15, hlen + klen * 4, klen * 4, 0);
  192. do_test (15, 15, hlen + klen * 4, klen * 4, 1);
  193. }
  194. do_test (0, 0, page_size - 1, 16, 0);
  195. do_test (0, 0, page_size - 1, 16, 1);
  196. return ret;
  197. }
  198. #include <support/test-driver.c>