TestStringUtils.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. /*
  2. * Copyright (c) 2020, Fei Wu <f.eiwu@yahoo.com>
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions are met:
  7. *
  8. * 1. Redistributions of source code must retain the above copyright notice, this
  9. * list of conditions and the following disclaimer.
  10. *
  11. * 2. Redistributions in binary form must reproduce the above copyright notice,
  12. * this list of conditions and the following disclaimer in the documentation
  13. * and/or other materials provided with the distribution.
  14. *
  15. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  16. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  17. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  18. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  19. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  20. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  21. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  22. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  23. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  24. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  25. */
  26. #include <AK/StringUtils.h>
  27. #include <AK/TestSuite.h>
  28. TEST_CASE(matches_null)
  29. {
  30. EXPECT(AK::StringUtils::matches(StringView(), StringView()));
  31. EXPECT(!AK::StringUtils::matches(StringView(), ""));
  32. EXPECT(!AK::StringUtils::matches(StringView(), "*"));
  33. EXPECT(!AK::StringUtils::matches(StringView(), "?"));
  34. EXPECT(!AK::StringUtils::matches(StringView(), "a"));
  35. EXPECT(!AK::StringUtils::matches("", StringView()));
  36. EXPECT(!AK::StringUtils::matches("a", StringView()));
  37. }
  38. TEST_CASE(matches_empty)
  39. {
  40. EXPECT(AK::StringUtils::matches("", ""));
  41. EXPECT(AK::StringUtils::matches("", "*"));
  42. EXPECT(!AK::StringUtils::matches("", "?"));
  43. EXPECT(!AK::StringUtils::matches("", "a"));
  44. EXPECT(!AK::StringUtils::matches("a", ""));
  45. }
  46. TEST_CASE(matches_case_sensitive)
  47. {
  48. EXPECT(AK::StringUtils::matches("a", "a", CaseSensitivity::CaseSensitive));
  49. EXPECT(!AK::StringUtils::matches("a", "A", CaseSensitivity::CaseSensitive));
  50. EXPECT(!AK::StringUtils::matches("A", "a", CaseSensitivity::CaseSensitive));
  51. }
  52. TEST_CASE(matches_case_insensitive)
  53. {
  54. EXPECT(!AK::StringUtils::matches("aa", "a"));
  55. EXPECT(AK::StringUtils::matches("aa", "*"));
  56. EXPECT(!AK::StringUtils::matches("cb", "?a"));
  57. EXPECT(AK::StringUtils::matches("adceb", "a*b"));
  58. EXPECT(!AK::StringUtils::matches("acdcb", "a*c?b"));
  59. }
  60. TEST_CASE(matches_with_positions)
  61. {
  62. Vector<AK::MaskSpan> spans;
  63. EXPECT(AK::StringUtils::matches("abbb", "a*", CaseSensitivity::CaseSensitive, &spans));
  64. EXPECT(spans == Vector<AK::MaskSpan>({ { 1, 3 } }));
  65. spans.clear();
  66. EXPECT(AK::StringUtils::matches("abbb", "?*", CaseSensitivity::CaseSensitive, &spans));
  67. EXPECT_EQ(spans, Vector<AK::MaskSpan>({ { 0, 1 }, { 1, 3 } }));
  68. spans.clear();
  69. EXPECT(AK::StringUtils::matches("acdcxb", "a*c?b", CaseSensitivity::CaseSensitive, &spans));
  70. EXPECT_EQ(spans, Vector<AK::MaskSpan>({ { 1, 2 }, { 4, 1 } }));
  71. spans.clear();
  72. EXPECT(AK::StringUtils::matches("aaaa", "A*", CaseSensitivity::CaseInsensitive, &spans));
  73. EXPECT_EQ(spans, Vector<AK::MaskSpan>({ { 1, 3 } }));
  74. }
  75. // #4607
  76. TEST_CASE(matches_trailing)
  77. {
  78. EXPECT(AK::StringUtils::matches("ab", "ab*"));
  79. EXPECT(AK::StringUtils::matches("ab", "ab****"));
  80. EXPECT(AK::StringUtils::matches("ab", "*ab****"));
  81. }
  82. TEST_CASE(convert_to_int)
  83. {
  84. auto value = AK::StringUtils::convert_to_int(StringView());
  85. EXPECT(!value.has_value());
  86. value = AK::StringUtils::convert_to_int("");
  87. EXPECT(!value.has_value());
  88. value = AK::StringUtils::convert_to_int("a");
  89. EXPECT(!value.has_value());
  90. value = AK::StringUtils::convert_to_int("+");
  91. EXPECT(!value.has_value());
  92. value = AK::StringUtils::convert_to_int("-");
  93. EXPECT(!value.has_value());
  94. auto actual = AK::StringUtils::convert_to_int("0");
  95. EXPECT_EQ(actual.has_value(), true);
  96. EXPECT_EQ(actual.value(), 0);
  97. actual = AK::StringUtils::convert_to_int("1");
  98. EXPECT_EQ(actual.has_value(), true);
  99. EXPECT_EQ(actual.value(), 1);
  100. actual = AK::StringUtils::convert_to_int("+1");
  101. EXPECT_EQ(actual.has_value(), true);
  102. EXPECT_EQ(actual.value(), 1);
  103. actual = AK::StringUtils::convert_to_int("-1");
  104. EXPECT_EQ(actual.has_value(), true);
  105. EXPECT_EQ(actual.value(), -1);
  106. actual = AK::StringUtils::convert_to_int("01");
  107. EXPECT_EQ(actual.has_value(), true);
  108. EXPECT_EQ(actual.value(), 1);
  109. actual = AK::StringUtils::convert_to_int("12345");
  110. EXPECT_EQ(actual.has_value(), true);
  111. EXPECT_EQ(actual.value(), 12345);
  112. actual = AK::StringUtils::convert_to_int("-12345");
  113. EXPECT_EQ(actual.has_value(), true);
  114. EXPECT_EQ(actual.value(), -12345);
  115. actual = AK::StringUtils::convert_to_int(" \t-12345 \n\n");
  116. EXPECT_EQ(actual.has_value(), true);
  117. EXPECT_EQ(actual.value(), -12345);
  118. auto actual_i8 = AK::StringUtils::convert_to_int<i8>("-1");
  119. EXPECT(actual_i8.has_value());
  120. EXPECT_EQ(actual_i8.value(), -1);
  121. EXPECT_EQ(sizeof(actual_i8.value()), (size_t)1);
  122. actual_i8 = AK::StringUtils::convert_to_int<i8>("128");
  123. EXPECT(!actual_i8.has_value());
  124. auto actual_i16 = AK::StringUtils::convert_to_int<i16>("-1");
  125. EXPECT(actual_i16.has_value());
  126. EXPECT_EQ(actual_i16.value(), -1);
  127. EXPECT_EQ(sizeof(actual_i16.value()), (size_t)2);
  128. actual_i16 = AK::StringUtils::convert_to_int<i16>("32768");
  129. EXPECT(!actual_i16.has_value());
  130. auto actual_i32 = AK::StringUtils::convert_to_int<i32>("-1");
  131. EXPECT(actual_i32.has_value());
  132. EXPECT_EQ(actual_i32.value(), -1);
  133. EXPECT_EQ(sizeof(actual_i32.value()), (size_t)4);
  134. actual_i32 = AK::StringUtils::convert_to_int<i32>("2147483648");
  135. EXPECT(!actual_i32.has_value());
  136. auto actual_i64 = AK::StringUtils::convert_to_int<i64>("-1");
  137. EXPECT(actual_i64.has_value());
  138. EXPECT_EQ(actual_i64.value(), -1);
  139. EXPECT_EQ(sizeof(actual_i64.value()), (size_t)8);
  140. actual_i64 = AK::StringUtils::convert_to_int<i64>("9223372036854775808");
  141. EXPECT(!actual_i64.has_value());
  142. }
  143. TEST_CASE(convert_to_uint)
  144. {
  145. auto value = AK::StringUtils::convert_to_uint(StringView());
  146. EXPECT(!value.has_value());
  147. value = AK::StringUtils::convert_to_uint("");
  148. EXPECT(!value.has_value());
  149. value = AK::StringUtils::convert_to_uint("a");
  150. EXPECT(!value.has_value());
  151. value = AK::StringUtils::convert_to_uint("+");
  152. EXPECT(!value.has_value());
  153. value = AK::StringUtils::convert_to_uint("-");
  154. EXPECT(!value.has_value());
  155. value = AK::StringUtils::convert_to_uint("+1");
  156. EXPECT(!value.has_value());
  157. value = AK::StringUtils::convert_to_uint("-1");
  158. EXPECT(!value.has_value());
  159. auto actual = AK::StringUtils::convert_to_uint("0");
  160. EXPECT_EQ(actual.has_value(), true);
  161. EXPECT_EQ(actual.value(), 0u);
  162. actual = AK::StringUtils::convert_to_uint("1");
  163. EXPECT_EQ(actual.has_value(), true);
  164. EXPECT_EQ(actual.value(), 1u);
  165. actual = AK::StringUtils::convert_to_uint("01");
  166. EXPECT_EQ(actual.has_value(), true);
  167. EXPECT_EQ(actual.value(), 1u);
  168. actual = AK::StringUtils::convert_to_uint("12345");
  169. EXPECT_EQ(actual.has_value(), true);
  170. EXPECT_EQ(actual.value(), 12345u);
  171. actual = AK::StringUtils::convert_to_uint(" \t12345 \n\n");
  172. EXPECT_EQ(actual.has_value(), true);
  173. EXPECT_EQ(actual.value(), 12345u);
  174. auto actual_u8 = AK::StringUtils::convert_to_uint<u8>("255");
  175. EXPECT(actual_u8.has_value());
  176. EXPECT_EQ(actual_u8.value(), 255u);
  177. EXPECT_EQ(sizeof(actual_u8.value()), (size_t)1);
  178. actual_u8 = AK::StringUtils::convert_to_uint<u8>("256");
  179. EXPECT(!actual_u8.has_value());
  180. auto actual_u16 = AK::StringUtils::convert_to_uint<u16>("65535");
  181. EXPECT(actual_u16.has_value());
  182. EXPECT_EQ(actual_u16.value(), 65535u);
  183. EXPECT_EQ(sizeof(actual_u16.value()), (size_t)2);
  184. actual_u16 = AK::StringUtils::convert_to_uint<u16>("65536");
  185. EXPECT(!actual_u16.has_value());
  186. auto actual_u32 = AK::StringUtils::convert_to_uint<u32>("4294967295");
  187. EXPECT(actual_u32.has_value());
  188. EXPECT_EQ(actual_u32.value(), 4294967295ul);
  189. EXPECT_EQ(sizeof(actual_u32.value()), (size_t)4);
  190. actual_u32 = AK::StringUtils::convert_to_uint<u32>("4294967296");
  191. EXPECT(!actual_u32.has_value());
  192. auto actual_u64 = AK::StringUtils::convert_to_uint<u64>("18446744073709551615");
  193. EXPECT(actual_u64.has_value());
  194. EXPECT_EQ(actual_u64.value(), 18446744073709551615ull);
  195. EXPECT_EQ(sizeof(actual_u64.value()), (size_t)8);
  196. actual_u64 = AK::StringUtils::convert_to_uint<u64>("18446744073709551616");
  197. EXPECT(!actual_u64.has_value());
  198. }
  199. TEST_CASE(ends_with)
  200. {
  201. String test_string = "ABCDEF";
  202. EXPECT(AK::StringUtils::ends_with(test_string, "DEF", CaseSensitivity::CaseSensitive));
  203. EXPECT(AK::StringUtils::ends_with(test_string, "ABCDEF", CaseSensitivity::CaseSensitive));
  204. EXPECT(!AK::StringUtils::ends_with(test_string, "ABCDE", CaseSensitivity::CaseSensitive));
  205. EXPECT(!AK::StringUtils::ends_with(test_string, "ABCDEFG", CaseSensitivity::CaseSensitive));
  206. EXPECT(AK::StringUtils::ends_with(test_string, "def", CaseSensitivity::CaseInsensitive));
  207. EXPECT(!AK::StringUtils::ends_with(test_string, "def", CaseSensitivity::CaseSensitive));
  208. }
  209. TEST_CASE(starts_with)
  210. {
  211. String test_string = "ABCDEF";
  212. EXPECT(AK::StringUtils::starts_with(test_string, "ABC", CaseSensitivity::CaseSensitive));
  213. EXPECT(AK::StringUtils::starts_with(test_string, "ABCDEF", CaseSensitivity::CaseSensitive));
  214. EXPECT(!AK::StringUtils::starts_with(test_string, "BCDEF", CaseSensitivity::CaseSensitive));
  215. EXPECT(!AK::StringUtils::starts_with(test_string, "ABCDEFG", CaseSensitivity::CaseSensitive));
  216. EXPECT(AK::StringUtils::starts_with(test_string, "abc", CaseSensitivity::CaseInsensitive));
  217. EXPECT(!AK::StringUtils::starts_with(test_string, "abc", CaseSensitivity::CaseSensitive));
  218. }
  219. TEST_CASE(contains)
  220. {
  221. String test_string = "ABCDEFABCXYZ";
  222. EXPECT(AK::StringUtils::contains(test_string, "ABC", CaseSensitivity::CaseSensitive));
  223. EXPECT(AK::StringUtils::contains(test_string, "ABC", CaseSensitivity::CaseInsensitive));
  224. EXPECT(AK::StringUtils::contains(test_string, "AbC", CaseSensitivity::CaseInsensitive));
  225. EXPECT(AK::StringUtils::contains(test_string, "BCX", CaseSensitivity::CaseSensitive));
  226. EXPECT(AK::StringUtils::contains(test_string, "BCX", CaseSensitivity::CaseInsensitive));
  227. EXPECT(AK::StringUtils::contains(test_string, "BcX", CaseSensitivity::CaseInsensitive));
  228. EXPECT(!AK::StringUtils::contains(test_string, "xyz", CaseSensitivity::CaseSensitive));
  229. EXPECT(AK::StringUtils::contains(test_string, "xyz", CaseSensitivity::CaseInsensitive));
  230. EXPECT(!AK::StringUtils::contains(test_string, "EFG", CaseSensitivity::CaseSensitive));
  231. EXPECT(!AK::StringUtils::contains(test_string, "EfG", CaseSensitivity::CaseInsensitive));
  232. EXPECT(AK::StringUtils::contains(test_string, "", CaseSensitivity::CaseSensitive));
  233. EXPECT(AK::StringUtils::contains(test_string, "", CaseSensitivity::CaseInsensitive));
  234. EXPECT(!AK::StringUtils::contains("", test_string, CaseSensitivity::CaseSensitive));
  235. EXPECT(!AK::StringUtils::contains("", test_string, CaseSensitivity::CaseInsensitive));
  236. EXPECT(!AK::StringUtils::contains(test_string, "L", CaseSensitivity::CaseSensitive));
  237. EXPECT(!AK::StringUtils::contains(test_string, "L", CaseSensitivity::CaseInsensitive));
  238. }
  239. TEST_MAIN(StringUtils)