]> git.saurik.com Git - apple/xnu.git/blobdiff - tests/safe_allocation_src/swap.cpp
xnu-7195.50.7.100.1.tar.gz
[apple/xnu.git] / tests / safe_allocation_src / swap.cpp
diff --git a/tests/safe_allocation_src/swap.cpp b/tests/safe_allocation_src/swap.cpp
new file mode 100644 (file)
index 0000000..d3da0a7
--- /dev/null
@@ -0,0 +1,104 @@
+//
+// Tests for
+//  void swap(safe_allocation& a, safe_allocation& b);
+//
+
+#include <libkern/c++/safe_allocation.h>
+#include <darwintest.h>
+#include "test_utils.h"
+
+struct T {
+       int i;
+};
+
+template <typename T>
+static void
+tests()
+{
+       // Swap non-null with non-null
+       {
+               tracked_safe_allocation<T> a(10, libkern::allocate_memory);
+               tracked_safe_allocation<T> b(20, libkern::allocate_memory);
+               T* a_mem = a.data();
+               T* b_mem = b.data();
+               tracking_allocator::reset();
+
+               swap(a, b); // ADL call
+
+               CHECK(!tracking_allocator::did_allocate);
+               CHECK(!tracking_allocator::did_deallocate);
+               CHECK(a.data() == b_mem);
+               CHECK(b.data() == a_mem);
+               CHECK(a.size() == 20);
+               CHECK(b.size() == 10);
+       }
+
+       // Swap non-null with null
+       {
+               tracked_safe_allocation<T> a(10, libkern::allocate_memory);
+               tracked_safe_allocation<T> b = nullptr;
+               T* a_mem = a.data();
+               tracking_allocator::reset();
+
+               swap(a, b); // ADL call
+
+               CHECK(!tracking_allocator::did_allocate);
+               CHECK(!tracking_allocator::did_deallocate);
+               CHECK(a.data() == nullptr);
+               CHECK(b.data() == a_mem);
+               CHECK(a.size() == 0);
+               CHECK(b.size() == 10);
+       }
+
+       // Swap null with non-null
+       {
+               tracked_safe_allocation<T> a = nullptr;
+               tracked_safe_allocation<T> b(20, libkern::allocate_memory);
+               T* b_mem = b.data();
+               tracking_allocator::reset();
+
+               swap(a, b); // ADL call
+
+               CHECK(!tracking_allocator::did_allocate);
+               CHECK(!tracking_allocator::did_deallocate);
+               CHECK(a.data() == b_mem);
+               CHECK(b.data() == nullptr);
+               CHECK(a.size() == 20);
+               CHECK(b.size() == 0);
+       }
+
+       // Swap null with null
+       {
+               tracked_safe_allocation<T> a = nullptr;
+               tracked_safe_allocation<T> b = nullptr;
+               tracking_allocator::reset();
+
+               swap(a, b); // ADL call
+
+               CHECK(!tracking_allocator::did_allocate);
+               CHECK(!tracking_allocator::did_deallocate);
+               CHECK(a.data() == nullptr);
+               CHECK(b.data() == nullptr);
+               CHECK(a.size() == 0);
+               CHECK(b.size() == 0);
+       }
+
+       // Swap with self
+       {
+               tracked_safe_allocation<T> a(10, libkern::allocate_memory);
+               T* a_mem = a.data();
+               tracking_allocator::reset();
+
+               swap(a, a); // ADL call
+
+               CHECK(!tracking_allocator::did_allocate);
+               CHECK(!tracking_allocator::did_deallocate);
+               CHECK(a.data() == a_mem);
+               CHECK(a.size() == 10);
+       }
+}
+
+T_DECL(swap, "safe_allocation.swap") {
+       tests<T>();
+       tests<T const>();
+}