1*bb611c8fSApple OSS Distributions // 2*bb611c8fSApple OSS Distributions // Tests for 3*bb611c8fSApple OSS Distributions // bounded_array(); 4*bb611c8fSApple OSS Distributions // 5*bb611c8fSApple OSS Distributions 6*bb611c8fSApple OSS Distributions #include <libkern/c++/bounded_array.h> 7*bb611c8fSApple OSS Distributions #include <darwintest.h> 8*bb611c8fSApple OSS Distributions #include <darwintest_utils.h> 9*bb611c8fSApple OSS Distributions #include "test_policy.h" 10*bb611c8fSApple OSS Distributions 11*bb611c8fSApple OSS Distributions struct T { 12*bb611c8fSApple OSS Distributions T() : i(4) 13*bb611c8fSApple OSS Distributions { 14*bb611c8fSApple OSS Distributions } 15*bb611c8fSApple OSS Distributions int i; 16*bb611c8fSApple OSS Distributions friend bool 17*bb611c8fSApple OSS Distributions operator==(T const& a, T const& b) 18*bb611c8fSApple OSS Distributions { 19*bb611c8fSApple OSS Distributions return a.i == b.i; 20*bb611c8fSApple OSS Distributions } 21*bb611c8fSApple OSS Distributions }; 22*bb611c8fSApple OSS Distributions 23*bb611c8fSApple OSS Distributions template <typename T> 24*bb611c8fSApple OSS Distributions static void 25*bb611c8fSApple OSS Distributions tests() 26*bb611c8fSApple OSS Distributions { 27*bb611c8fSApple OSS Distributions { 28*bb611c8fSApple OSS Distributions test_bounded_array<T, 10> array; 29*bb611c8fSApple OSS Distributions CHECK(array.size() == 10); 30*bb611c8fSApple OSS Distributions T* end = array.data() + array.size(); 31*bb611c8fSApple OSS Distributions for (auto it = array.data(); it != end; ++it) { 32*bb611c8fSApple OSS Distributions CHECK(*it == T()); 33*bb611c8fSApple OSS Distributions } 34*bb611c8fSApple OSS Distributions } 35*bb611c8fSApple OSS Distributions { 36*bb611c8fSApple OSS Distributions test_bounded_array<T, 10> array{}; 37*bb611c8fSApple OSS Distributions CHECK(array.size() == 10); 38*bb611c8fSApple OSS Distributions T* end = array.data() + array.size(); 39*bb611c8fSApple OSS Distributions for (auto it = array.data(); it != end; ++it) { 40*bb611c8fSApple OSS Distributions CHECK(*it == T()); 41*bb611c8fSApple OSS Distributions } 42*bb611c8fSApple OSS Distributions } 43*bb611c8fSApple OSS Distributions { 44*bb611c8fSApple OSS Distributions test_bounded_array<T, 10> array = {}; 45*bb611c8fSApple OSS Distributions CHECK(array.size() == 10); 46*bb611c8fSApple OSS Distributions T* end = array.data() + array.size(); 47*bb611c8fSApple OSS Distributions for (auto it = array.data(); it != end; ++it) { 48*bb611c8fSApple OSS Distributions CHECK(*it == T()); 49*bb611c8fSApple OSS Distributions } 50*bb611c8fSApple OSS Distributions } 51*bb611c8fSApple OSS Distributions { 52*bb611c8fSApple OSS Distributions test_bounded_array<T, 10> array = test_bounded_array<T, 10>(); 53*bb611c8fSApple OSS Distributions CHECK(array.size() == 10); 54*bb611c8fSApple OSS Distributions T* end = array.data() + array.size(); 55*bb611c8fSApple OSS Distributions for (auto it = array.data(); it != end; ++it) { 56*bb611c8fSApple OSS Distributions CHECK(*it == T()); 57*bb611c8fSApple OSS Distributions } 58*bb611c8fSApple OSS Distributions } 59*bb611c8fSApple OSS Distributions 60*bb611c8fSApple OSS Distributions // Check with a 0-sized array 61*bb611c8fSApple OSS Distributions { 62*bb611c8fSApple OSS Distributions test_bounded_array<T, 0> array; 63*bb611c8fSApple OSS Distributions CHECK(array.size() == 0); 64*bb611c8fSApple OSS Distributions } 65*bb611c8fSApple OSS Distributions } 66*bb611c8fSApple OSS Distributions 67*bb611c8fSApple OSS Distributions T_DECL(ctor_default, "bounded_array.ctor.default") { 68*bb611c8fSApple OSS Distributions tests<T>(); 69*bb611c8fSApple OSS Distributions } 70