mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 06:37:44 +00:00
Tests: Move AK tests to Tests/AK
This commit is contained in:
parent
fd0dbd1ebf
commit
67322b0702
64 changed files with 1 additions and 2 deletions
66
Tests/AK/TestWeakPtr.cpp
Normal file
66
Tests/AK/TestWeakPtr.cpp
Normal file
|
@ -0,0 +1,66 @@
|
|||
/*
|
||||
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <LibTest/TestCase.h>
|
||||
|
||||
#include <AK/String.h>
|
||||
#include <AK/WeakPtr.h>
|
||||
#include <AK/Weakable.h>
|
||||
|
||||
#ifdef __clang__
|
||||
# pragma clang diagnostic push
|
||||
# pragma clang diagnostic ignored "-Wunused-private-field"
|
||||
#endif
|
||||
|
||||
class SimpleWeakable : public Weakable<SimpleWeakable>
|
||||
, public RefCounted<SimpleWeakable> {
|
||||
public:
|
||||
SimpleWeakable() = default;
|
||||
|
||||
private:
|
||||
int m_member { 123 };
|
||||
};
|
||||
|
||||
#ifdef __clang__
|
||||
# pragma clang diagnostic pop
|
||||
#endif
|
||||
|
||||
TEST_CASE(basic_weak)
|
||||
{
|
||||
WeakPtr<SimpleWeakable> weak1;
|
||||
WeakPtr<SimpleWeakable> weak2;
|
||||
|
||||
{
|
||||
auto simple = adopt_ref(*new SimpleWeakable);
|
||||
weak1 = simple;
|
||||
weak2 = simple;
|
||||
EXPECT_EQ(weak1.is_null(), false);
|
||||
EXPECT_EQ(weak2.is_null(), false);
|
||||
EXPECT_EQ(weak1.strong_ref().ptr(), simple.ptr());
|
||||
EXPECT_EQ(weak1.strong_ref().ptr(), weak2.strong_ref().ptr());
|
||||
}
|
||||
|
||||
EXPECT_EQ(weak1.is_null(), true);
|
||||
EXPECT_EQ(weak1.strong_ref().ptr(), nullptr);
|
||||
EXPECT_EQ(weak1.strong_ref().ptr(), weak2.strong_ref().ptr());
|
||||
}
|
||||
|
||||
TEST_CASE(weakptr_move)
|
||||
{
|
||||
WeakPtr<SimpleWeakable> weak1;
|
||||
WeakPtr<SimpleWeakable> weak2;
|
||||
|
||||
{
|
||||
auto simple = adopt_ref(*new SimpleWeakable);
|
||||
weak1 = simple;
|
||||
weak2 = move(weak1);
|
||||
EXPECT_EQ(weak1.is_null(), true);
|
||||
EXPECT_EQ(weak2.is_null(), false);
|
||||
EXPECT_EQ(weak2.strong_ref().ptr(), simple.ptr());
|
||||
}
|
||||
|
||||
EXPECT_EQ(weak2.is_null(), true);
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue