1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143
// // Tests for // safe_allocation& operator=(safe_allocation&& other); // #include <libkern/c++/safe_allocation.h> #include <darwintest.h> #include "test_utils.h" #include <utility> struct T { int i; }; template <typename T> static void tests() { // Move-assign non-null to non-null { { tracked_safe_allocation<T> from(10, libkern::allocate_memory); T* memory = from.data(); { tracked_safe_allocation<T> to(20, libkern::allocate_memory); tracking_allocator::reset(); tracked_safe_allocation<T>& ref = (to = std::move(from)); CHECK(&ref == &to); CHECK(to.data() == memory); CHECK(to.size() == 10); CHECK(from.data() == nullptr); CHECK(from.size() == 0); CHECK(!tracking_allocator::did_allocate); CHECK(tracking_allocator::deallocated_size == 20 * sizeof(T)); tracking_allocator::reset(); } CHECK(tracking_allocator::deallocated_size == 10 * sizeof(T)); tracking_allocator::reset(); } CHECK(!tracking_allocator::did_deallocate); } // Move-assign null to non-null { { tracked_safe_allocation<T> from = nullptr; { tracked_safe_allocation<T> to(20, libkern::allocate_memory); tracking_allocator::reset(); tracked_safe_allocation<T>& ref = (to = std::move(from)); CHECK(&ref == &to); CHECK(to.data() == nullptr); CHECK(to.size() == 0); CHECK(from.data() == nullptr); CHECK(from.size() == 0); CHECK(!tracking_allocator::did_allocate); CHECK(tracking_allocator::deallocated_size == 20 * sizeof(T)); tracking_allocator::reset(); } CHECK(!tracking_allocator::did_deallocate); tracking_allocator::reset(); } CHECK(!tracking_allocator::did_deallocate); } // Move-assign non-null to null { { tracked_safe_allocation<T> from(10, libkern::allocate_memory); T* memory = from.data(); { tracked_safe_allocation<T> to = nullptr; tracking_allocator::reset(); tracked_safe_allocation<T>& ref = (to = std::move(from)); CHECK(&ref == &to); CHECK(to.data() == memory); CHECK(to.size() == 10); CHECK(from.data() == nullptr); CHECK(from.size() == 0); CHECK(!tracking_allocator::did_allocate); CHECK(!tracking_allocator::did_deallocate); tracking_allocator::reset(); } CHECK(tracking_allocator::deallocated_size == 10 * sizeof(T)); tracking_allocator::reset(); } CHECK(!tracking_allocator::did_deallocate); } // Move-assign null to null { { tracked_safe_allocation<T> from = nullptr; { tracked_safe_allocation<T> to = nullptr; tracking_allocator::reset(); tracked_safe_allocation<T>& ref = (to = std::move(from)); CHECK(&ref == &to); CHECK(to.data() == nullptr); CHECK(to.size() == 0); CHECK(from.data() == nullptr); CHECK(from.size() == 0); CHECK(!tracking_allocator::did_allocate); CHECK(!tracking_allocator::did_deallocate); tracking_allocator::reset(); } CHECK(!tracking_allocator::did_deallocate); tracking_allocator::reset(); } CHECK(!tracking_allocator::did_deallocate); } // Move-assign to self { { tracked_safe_allocation<T> obj(10, libkern::allocate_memory); T* memory = obj.data(); tracking_allocator::reset(); tracked_safe_allocation<T>& ref = (obj = std::move(obj)); CHECK(&ref == &obj); CHECK(obj.data() == memory); CHECK(obj.size() == 10); CHECK(!tracking_allocator::did_allocate); CHECK(!tracking_allocator::did_deallocate); tracking_allocator::reset(); } CHECK(tracking_allocator::deallocated_size == 10 * sizeof(T)); } } T_DECL(assign_move, "safe_allocation.assign.move") { tests<T>(); tests<T const>(); }