ladybird/Tests/AK/TestByteBuffer.cpp
Luke Wilde d9d556fbab AK: Allow Vector<ByteBuffer>::contains_slow to accept (Readonly)Bytes
This is done by providing Traits<ByteBuffer>::equals functions for
(Readonly)Bytes, as the base GenericTraits<T>::equals is unable to
convert the ByteBuffer to (Readonly)Bytes to then use Span::operator==

This allows us to check if a Vector<ByteBuffer> contains a
(Readonly)Bytes without having to making a copy of it into a ByteBuffer
first. The initial use of this is in LibWeb with CORS-preflight, where
we check the split contents of the Access-Control headers with
Fetch::Infrastructure::Request::method() and static StringViews
such as "*"sv.bytes().
2023-02-10 22:18:19 +00:00

72 lines
2.1 KiB
C++
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
* Copyright (c) 2020, the SerenityOS developers.
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibTest/TestCase.h>
#include <AK/ByteBuffer.h>
#include <AK/Vector.h>
TEST_CASE(equality_operator)
{
ByteBuffer a = ByteBuffer::copy("Hello, world", 7).release_value();
ByteBuffer b = ByteBuffer::copy("Hello, friend", 7).release_value();
// `a` and `b` are both "Hello, ".
ByteBuffer c = ByteBuffer::copy("asdf", 4).release_value();
ByteBuffer d;
EXPECT_EQ(a == a, true);
EXPECT_EQ(a == b, true);
EXPECT_EQ(a == c, false);
EXPECT_EQ(a == d, false);
EXPECT_EQ(b == a, true);
EXPECT_EQ(b == b, true);
EXPECT_EQ(b == c, false);
EXPECT_EQ(b == d, false);
EXPECT_EQ(c == a, false);
EXPECT_EQ(c == b, false);
EXPECT_EQ(c == c, true);
EXPECT_EQ(c == d, false);
EXPECT_EQ(d == a, false);
EXPECT_EQ(d == b, false);
EXPECT_EQ(d == c, false);
EXPECT_EQ(d == d, true);
}
TEST_CASE(byte_buffer_vector_contains_slow_bytes)
{
Vector<ByteBuffer> vector;
ByteBuffer a = ByteBuffer::copy("Hello, friend", 13).release_value();
vector.append(a);
ReadonlyBytes b = "Hello, friend"sv.bytes();
Bytes c = a.bytes();
EXPECT_EQ(vector.contains_slow(b), true);
EXPECT_EQ(vector.contains_slow(c), true);
}
BENCHMARK_CASE(append)
{
ByteBuffer bb;
for (size_t i = 0; i < 1000000; ++i) {
bb.append(static_cast<u8>(i));
}
}
/*
* FIXME: These `negative_*` tests should cause precisely one compilation error
* each, and always for the specified reason. Currently we do not have a harness
* for that, so in order to run the test you need to set the #define to 1, compile
* it, and check the error messages manually.
*/
#define COMPILE_NEGATIVE_TESTS 0
#if COMPILE_NEGATIVE_TESTS
TEST_CASE(negative_operator_lt)
{
ByteBuffer a = ByteBuffer::copy("Hello, world", 10).release_value();
ByteBuffer b = ByteBuffer::copy("Hello, friend", 10).release_value();
[[maybe_unused]] auto res = a < b;
// error: error: use of deleted function bool AK::ByteBuffer::operator<(const AK::ByteBuffer&) const
}
#endif /* COMPILE_NEGATIVE_TESTS */