summaryrefslogtreecommitdiff
path: root/asl/tests/string_view_tests.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'asl/tests/string_view_tests.cpp')
-rw-r--r--asl/tests/string_view_tests.cpp21
1 files changed, 13 insertions, 8 deletions
diff --git a/asl/tests/string_view_tests.cpp b/asl/tests/string_view_tests.cpp
index 1c12603..8f7ff28 100644
--- a/asl/tests/string_view_tests.cpp
+++ b/asl/tests/string_view_tests.cpp
@@ -1,9 +1,6 @@
#include "asl/string_view.hpp"
#include "asl/testing/testing.hpp"
-// @Todo Don't use stdlib, remake memcmp
-#include <string.h>
-
static_assert(asl::trivially_destructible<asl::string_view>);
static_assert(asl::trivially_copyable<asl::string_view>);
@@ -20,7 +17,7 @@ ASL_TEST(from_literal)
{
asl::string_view s1 = "Hello"_sv;
ASL_TEST_ASSERT(s1.size() == 5);
- ASL_TEST_EXPECT(memcmp(s1.data(), "Hello", 5) == 0);
+ ASL_TEST_EXPECT(__builtin_memcmp(s1.data(), "Hello", 5) == 0);
asl::string_view s2 = ""_sv;
ASL_TEST_EXPECT(s2.is_empty());
@@ -32,11 +29,11 @@ ASL_TEST(substr1)
asl::string_view s2 = s1.substr(0);
ASL_TEST_ASSERT(s2.size() == 4);
- ASL_TEST_EXPECT(memcmp(s2.data(), "abcd", 4) == 0);
+ ASL_TEST_EXPECT(__builtin_memcmp(s2.data(), "abcd", 4) == 0);
s2 = s1.substr(2);
ASL_TEST_ASSERT(s2.size() == 2);
- ASL_TEST_EXPECT(memcmp(s2.data(), "cd", 2) == 0);
+ ASL_TEST_EXPECT(__builtin_memcmp(s2.data(), "cd", 2) == 0);
s2 = s1.substr(4);
ASL_TEST_ASSERT(s2.size() == 0);
@@ -48,11 +45,11 @@ ASL_TEST(substr2)
asl::string_view s2 = s1.substr(0, 4);
ASL_TEST_ASSERT(s2.size() == 4);
- ASL_TEST_EXPECT(memcmp(s2.data(), "abcd", 4) == 0);
+ ASL_TEST_EXPECT(__builtin_memcmp(s2.data(), "abcd", 4) == 0);
s2 = s1.substr(1, 2);
ASL_TEST_ASSERT(s2.size() == 2);
- ASL_TEST_EXPECT(memcmp(s2.data(), "bc", 2) == 0);
+ ASL_TEST_EXPECT(__builtin_memcmp(s2.data(), "bc", 2) == 0);
s2 = s1.substr(4, 0);
ASL_TEST_ASSERT(s2.size() == 0);
@@ -60,3 +57,11 @@ ASL_TEST(substr2)
s2 = s1.substr(1, 0);
ASL_TEST_ASSERT(s2.size() == 0);
}
+
+ASL_TEST(equal)
+{
+ ASL_TEST_EXPECT("abc"_sv == "abc"_sv);
+ ASL_TEST_EXPECT(""_sv == ""_sv);
+ ASL_TEST_EXPECT("abc"_sv != "ab"_sv);
+ ASL_TEST_EXPECT("abc"_sv != "abd"_sv);
+}