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