test-strcasestr.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. /* Test and measure strcasestr functions.
  2. Copyright (C) 2010-2026 Free Software Foundation, Inc.
  3. This file is part of the GNU C Library.
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Lesser General Public
  6. License as published by the Free Software Foundation; either
  7. version 2.1 of the License, or (at your option) any later version.
  8. The GNU C Library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public
  13. License along with the GNU C Library; if not, see
  14. <https://www.gnu.org/licenses/>. */
  15. #define TEST_MAIN
  16. #define TEST_NAME "strcasestr"
  17. #include "test-string.h"
  18. #define STRCASESTR c_strcasestr
  19. #define NO_ALIAS
  20. #define __strncasecmp strncasecmp
  21. #define __strnlen strnlen
  22. #include "strcasestr.c"
  23. /* Naive implementation to verify results. */
  24. static char *
  25. simple_strcasestr (const char *s1, const char *s2)
  26. {
  27. ssize_t s1len = strlen (s1);
  28. ssize_t s2len = strlen (s2);
  29. if (s2len > s1len)
  30. return NULL;
  31. for (ssize_t i = 0; i <= s1len - s2len; ++i)
  32. {
  33. size_t j;
  34. for (j = 0; j < s2len; ++j)
  35. if (tolower (s1[i + j]) != tolower (s2[j]))
  36. break;
  37. if (j == s2len)
  38. return (char *) s1 + i;
  39. }
  40. return NULL;
  41. }
  42. typedef char *(*proto_t) (const char *, const char *);
  43. IMPL (c_strcasestr, 0)
  44. IMPL (strcasestr, 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 == NULL) ? "(null)" : result,
  54. (exp_result == NULL) ? "(null)" : exp_result);
  55. ret = 1;
  56. return -1;
  57. }
  58. return 0;
  59. }
  60. static void
  61. do_one_test (impl_t *impl, const char *s1, const char *s2, char *exp_result)
  62. {
  63. if (check_result (impl, s1, s2, exp_result) < 0)
  64. return;
  65. }
  66. static void
  67. do_test (size_t align1, size_t align2, size_t len1, size_t len2,
  68. int fail)
  69. {
  70. char *s1 = (char *) (buf1 + align1);
  71. char *s2 = (char *) (buf2 + align2);
  72. static const char d[] = "1234567890abcxyz";
  73. #define dl (sizeof (d) - 1)
  74. char *ss2 = s2;
  75. for (size_t l = len2; l > 0; l = l > dl ? l - dl : 0)
  76. {
  77. size_t t = l > dl ? dl : l;
  78. ss2 = mempcpy (ss2, d, t);
  79. }
  80. s2[len2] = '\0';
  81. if (fail)
  82. {
  83. char *ss1 = s1;
  84. for (size_t l = len1; l > 0; l = l > dl ? l - dl : 0)
  85. {
  86. size_t t = l > dl ? dl : l;
  87. memcpy (ss1, d, t);
  88. ++ss1[len2 > 7 ? 7 : len2 - 1];
  89. ss1 += t;
  90. }
  91. }
  92. else
  93. {
  94. memset (s1, '0', len1);
  95. for (size_t i = 0; i < len2; ++i)
  96. s1[len1 - len2 + i] = toupper (s2[i]);
  97. }
  98. s1[len1] = '\0';
  99. FOR_EACH_IMPL (impl, 0)
  100. do_one_test (impl, s1, s2, fail ? NULL : s1 + len1 - len2);
  101. }
  102. static void
  103. check1 (void)
  104. {
  105. const char s1[] = "AOKB";
  106. const char s2[] = "OK";
  107. char *exp_result;
  108. exp_result = simple_strcasestr (s1, s2);
  109. FOR_EACH_IMPL (impl, 0)
  110. check_result (impl, s1, s2, exp_result);
  111. }
  112. static int
  113. test_main (void)
  114. {
  115. test_init ();
  116. check1 ();
  117. printf ("%23s", "");
  118. FOR_EACH_IMPL (impl, 0)
  119. printf ("\t%s", impl->name);
  120. putchar ('\n');
  121. for (size_t klen = 2; klen < 32; ++klen)
  122. for (size_t hlen = 2 * klen; hlen < 16 * klen; hlen += klen)
  123. {
  124. do_test (0, 0, hlen, klen, 0);
  125. do_test (0, 0, hlen, klen, 1);
  126. do_test (0, 3, hlen, klen, 0);
  127. do_test (0, 3, hlen, klen, 1);
  128. do_test (0, 9, hlen, klen, 0);
  129. do_test (0, 9, hlen, klen, 1);
  130. do_test (0, 15, hlen, klen, 0);
  131. do_test (0, 15, hlen, klen, 1);
  132. do_test (3, 0, hlen, klen, 0);
  133. do_test (3, 0, hlen, klen, 1);
  134. do_test (3, 3, hlen, klen, 0);
  135. do_test (3, 3, hlen, klen, 1);
  136. do_test (3, 9, hlen, klen, 0);
  137. do_test (3, 9, hlen, klen, 1);
  138. do_test (3, 15, hlen, klen, 0);
  139. do_test (3, 15, hlen, klen, 1);
  140. do_test (9, 0, hlen, klen, 0);
  141. do_test (9, 0, hlen, klen, 1);
  142. do_test (9, 3, hlen, klen, 0);
  143. do_test (9, 3, hlen, klen, 1);
  144. do_test (9, 9, hlen, klen, 0);
  145. do_test (9, 9, hlen, klen, 1);
  146. do_test (9, 15, hlen, klen, 0);
  147. do_test (9, 15, hlen, klen, 1);
  148. do_test (15, 0, hlen, klen, 0);
  149. do_test (15, 0, hlen, klen, 1);
  150. do_test (15, 3, hlen, klen, 0);
  151. do_test (15, 3, hlen, klen, 1);
  152. do_test (15, 9, hlen, klen, 0);
  153. do_test (15, 9, hlen, klen, 1);
  154. do_test (15, 15, hlen, klen, 0);
  155. do_test (15, 15, hlen, klen, 1);
  156. }
  157. do_test (0, 0, page_size - 1, 16, 0);
  158. do_test (0, 0, page_size - 1, 16, 1);
  159. return ret;
  160. }
  161. #include <support/test-driver.c>