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