[Lldb-commits] [lldb] 61db1ff - [lldb] Add unit tests for NonNullSharedPtr (#172173)
via lldb-commits
lldb-commits at lists.llvm.org
Sat Dec 13 12:10:27 PST 2025
Author: Jonas Devlieghere
Date: 2025-12-13T20:10:23Z
New Revision: 61db1ff8c5946f40398841b9b068169e4562a015
URL: https://github.com/llvm/llvm-project/commit/61db1ff8c5946f40398841b9b068169e4562a015
DIFF: https://github.com/llvm/llvm-project/commit/61db1ff8c5946f40398841b9b068169e4562a015.diff
LOG: [lldb] Add unit tests for NonNullSharedPtr (#172173)
I was investigating a crash yesterday that implicated NonNullSharedPtr
which made me realize I didn't add unit tests for my new class.
Added:
lldb/unittests/Utility/NonNullSharedPtrTest.cpp
Modified:
lldb/include/lldb/Utility/NonNullSharedPtr.h
lldb/unittests/Utility/CMakeLists.txt
Removed:
################################################################################
diff --git a/lldb/include/lldb/Utility/NonNullSharedPtr.h b/lldb/include/lldb/Utility/NonNullSharedPtr.h
index e0da293b9629e..7d2d0bab6d287 100644
--- a/lldb/include/lldb/Utility/NonNullSharedPtr.h
+++ b/lldb/include/lldb/Utility/NonNullSharedPtr.h
@@ -9,6 +9,7 @@
#ifndef LLDB_UTILITY_NONNULLSHAREDPTR_H
#define LLDB_UTILITY_NONNULLSHAREDPTR_H
+#include <cassert>
#include <memory>
#include <utility>
diff --git a/lldb/unittests/Utility/CMakeLists.txt b/lldb/unittests/Utility/CMakeLists.txt
index 4cbe15bb5b073..674eefdffb59c 100644
--- a/lldb/unittests/Utility/CMakeLists.txt
+++ b/lldb/unittests/Utility/CMakeLists.txt
@@ -18,6 +18,7 @@ add_lldb_unittest(UtilityTests
ListenerTest.cpp
LogTest.cpp
NameMatchesTest.cpp
+ NonNullSharedPtrTest.cpp
PredicateTest.cpp
ProcessInfoTest.cpp
ProcessInstanceInfoTest.cpp
diff --git a/lldb/unittests/Utility/NonNullSharedPtrTest.cpp b/lldb/unittests/Utility/NonNullSharedPtrTest.cpp
new file mode 100644
index 0000000000000..dcefad36e4166
--- /dev/null
+++ b/lldb/unittests/Utility/NonNullSharedPtrTest.cpp
@@ -0,0 +1,210 @@
+//===----------------------------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "lldb/Utility/NonNullSharedPtr.h"
+#include "gtest/gtest.h"
+#include <memory>
+
+using namespace lldb_private;
+
+namespace {
+struct TestObject {
+ int value;
+ TestObject() : value(0) {}
+ explicit TestObject(int v) : value(v) {}
+};
+} // namespace
+
+TEST(NonNullSharedPtrTest, ConstructFromValidSharedPtr) {
+ auto sp = std::make_shared<TestObject>(42);
+ NonNullSharedPtr<TestObject> nps(sp);
+
+ EXPECT_EQ(nps->value, 42);
+ EXPECT_EQ(nps.get(), sp.get());
+ EXPECT_EQ(nps.use_count(), 2);
+}
+
+TEST(NonNullSharedPtrTest, ConstructFromRValueSharedPtr) {
+ auto sp = std::make_shared<TestObject>(100);
+ auto *raw_ptr = sp.get();
+ NonNullSharedPtr<TestObject> nps(std::move(sp));
+
+ EXPECT_EQ(nps->value, 100);
+ EXPECT_EQ(nps.get(), raw_ptr);
+ EXPECT_EQ(nps.use_count(), 1);
+}
+
+TEST(NonNullSharedPtrTest, CopyConstructor) {
+ auto sp = std::make_shared<TestObject>(42);
+ NonNullSharedPtr<TestObject> nps1(sp);
+ NonNullSharedPtr<TestObject> nps2(nps1);
+
+ EXPECT_EQ(nps1.get(), nps2.get());
+ EXPECT_EQ(nps2->value, 42);
+ EXPECT_EQ(nps1.use_count(), 3);
+ EXPECT_EQ(nps2.use_count(), 3);
+}
+
+TEST(NonNullSharedPtrTest, MoveConstructor) {
+ auto sp = std::make_shared<TestObject>(42);
+ auto *raw_ptr = sp.get();
+ NonNullSharedPtr<TestObject> nps1(sp);
+ NonNullSharedPtr<TestObject> nps2(std::move(nps1));
+
+ EXPECT_EQ(nps2.get(), raw_ptr);
+ EXPECT_EQ(nps2->value, 42);
+ EXPECT_EQ(nps2.use_count(), 2);
+}
+
+TEST(NonNullSharedPtrTest, CopyAssignment) {
+ auto sp1 = std::make_shared<TestObject>(42);
+ auto sp2 = std::make_shared<TestObject>(100);
+
+ NonNullSharedPtr<TestObject> nps1(sp1);
+ NonNullSharedPtr<TestObject> nps2(sp2);
+
+ nps2 = nps1;
+
+ EXPECT_EQ(nps1.get(), nps2.get());
+ EXPECT_EQ(nps2->value, 42);
+ EXPECT_EQ(nps1.use_count(), 3);
+}
+
+TEST(NonNullSharedPtrTest, MoveAssignment) {
+ auto sp1 = std::make_shared<TestObject>(42);
+ auto sp2 = std::make_shared<TestObject>(100);
+ auto *raw_ptr = sp1.get();
+
+ NonNullSharedPtr<TestObject> nps1(sp1);
+ NonNullSharedPtr<TestObject> nps2(sp2);
+
+ nps2 = std::move(nps1);
+
+ EXPECT_EQ(nps2.get(), raw_ptr);
+ EXPECT_EQ(nps2->value, 42);
+ EXPECT_EQ(nps2.use_count(), 2);
+}
+
+TEST(NonNullSharedPtrTest, DereferenceOperator) {
+ auto sp = std::make_shared<TestObject>(42);
+ NonNullSharedPtr<TestObject> nps(sp);
+
+ TestObject &obj = *nps;
+ EXPECT_EQ(obj.value, 42);
+
+ (*nps).value = 100;
+ EXPECT_EQ(nps->value, 100);
+}
+
+TEST(NonNullSharedPtrTest, ArrowOperator) {
+ auto sp = std::make_shared<TestObject>(42);
+ NonNullSharedPtr<TestObject> nps(sp);
+
+ EXPECT_EQ(nps->value, 42);
+
+ nps->value = 200;
+ EXPECT_EQ(nps->value, 200);
+}
+
+TEST(NonNullSharedPtrTest, GetMethod) {
+ auto sp = std::make_shared<TestObject>(42);
+ auto *raw_ptr = sp.get();
+ NonNullSharedPtr<TestObject> nps(sp);
+
+ EXPECT_EQ(nps.get(), raw_ptr);
+ EXPECT_NE(nps.get(), nullptr);
+}
+
+TEST(NonNullSharedPtrTest, UseCount) {
+ auto sp = std::make_shared<TestObject>(42);
+ EXPECT_EQ(sp.use_count(), 1);
+
+ NonNullSharedPtr<TestObject> nps1(sp);
+ EXPECT_EQ(sp.use_count(), 2);
+ EXPECT_EQ(nps1.use_count(), 2);
+
+ {
+ // Copy constructor.
+ NonNullSharedPtr<TestObject> nps2(nps1);
+ EXPECT_EQ(sp.use_count(), 3);
+ EXPECT_EQ(nps1.use_count(), 3);
+ EXPECT_EQ(nps2.use_count(), 3);
+ }
+
+ {
+ // Copy assignment constructor.
+ NonNullSharedPtr<TestObject> nps2 = nps1;
+ EXPECT_EQ(sp.use_count(), 3);
+ EXPECT_EQ(nps1.use_count(), 3);
+ EXPECT_EQ(nps2.use_count(), 3);
+ }
+
+ EXPECT_EQ(sp.use_count(), 2);
+ EXPECT_EQ(nps1.use_count(), 2);
+
+ sp.reset();
+ EXPECT_EQ(nps1.use_count(), 1);
+ EXPECT_TRUE(nps1);
+}
+
+TEST(NonNullSharedPtrTest, BoolOperator) {
+ auto sp = std::make_shared<TestObject>(42);
+ NonNullSharedPtr<TestObject> nps(sp);
+
+ EXPECT_TRUE(static_cast<bool>(nps));
+ EXPECT_TRUE(nps);
+}
+
+TEST(NonNullSharedPtrTest, SwapMethod) {
+ auto sp1 = std::make_shared<TestObject>(42);
+ auto sp2 = std::make_shared<TestObject>(100);
+ auto *raw_ptr1 = sp1.get();
+ auto *raw_ptr2 = sp2.get();
+
+ NonNullSharedPtr<TestObject> nps1(sp1);
+ NonNullSharedPtr<TestObject> nps2(sp2);
+
+ nps1.swap(nps2);
+
+ EXPECT_EQ(nps1.get(), raw_ptr2);
+ EXPECT_EQ(nps2.get(), raw_ptr1);
+ EXPECT_EQ(nps1->value, 100);
+ EXPECT_EQ(nps2->value, 42);
+}
+
+TEST(NonNullSharedPtrTest, ADLSwap) {
+ auto sp1 = std::make_shared<TestObject>(42);
+ auto sp2 = std::make_shared<TestObject>(100);
+ auto *raw_ptr1 = sp1.get();
+ auto *raw_ptr2 = sp2.get();
+
+ NonNullSharedPtr<TestObject> nps1(sp1);
+ NonNullSharedPtr<TestObject> nps2(sp2);
+
+ // Use ADL swap.
+ swap(nps1, nps2);
+
+ EXPECT_EQ(nps1.get(), raw_ptr2);
+ EXPECT_EQ(nps2.get(), raw_ptr1);
+ EXPECT_EQ(nps1->value, 100);
+ EXPECT_EQ(nps2->value, 42);
+}
+
+TEST(NonNullSharedPtrTest, MultipleReferences) {
+ auto sp = std::make_shared<TestObject>(42);
+ NonNullSharedPtr<TestObject> nps1(sp);
+ NonNullSharedPtr<TestObject> nps2(nps1);
+ NonNullSharedPtr<TestObject> nps3(nps2);
+
+ EXPECT_EQ(nps1.get(), nps2.get());
+ EXPECT_EQ(nps2.get(), nps3.get());
+
+ nps1->value = 999;
+ EXPECT_EQ(nps2->value, 999);
+ EXPECT_EQ(nps3->value, 999);
+}
More information about the lldb-commits
mailing list