[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