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