1*19c3b8c2SApple OSS Distributions // 2*19c3b8c2SApple OSS Distributions // Tests for 3*19c3b8c2SApple OSS Distributions // size_t size() const; 4*19c3b8c2SApple OSS Distributions // 5*19c3b8c2SApple OSS Distributions 6*19c3b8c2SApple OSS Distributions #include <libkern/c++/bounded_array.h> 7*19c3b8c2SApple OSS Distributions #include "test_policy.h" 8*19c3b8c2SApple OSS Distributions #include <darwintest.h> 9*19c3b8c2SApple OSS Distributions #include <stddef.h> 10*19c3b8c2SApple OSS Distributions 11*19c3b8c2SApple OSS Distributions struct T { int i; }; 12*19c3b8c2SApple OSS Distributions 13*19c3b8c2SApple OSS Distributions template <typename T> 14*19c3b8c2SApple OSS Distributions static void tests()15*19c3b8c2SApple OSS Distributionstests() 16*19c3b8c2SApple OSS Distributions { 17*19c3b8c2SApple OSS Distributions { 18*19c3b8c2SApple OSS Distributions test_bounded_array<T, 5> const array = {T{0}, T{1}, T{2}, T{3}, T{4}}; 19*19c3b8c2SApple OSS Distributions size_t size = array.size(); 20*19c3b8c2SApple OSS Distributions CHECK(size == 5); 21*19c3b8c2SApple OSS Distributions } 22*19c3b8c2SApple OSS Distributions { 23*19c3b8c2SApple OSS Distributions test_bounded_array<T, 0> const array = {}; 24*19c3b8c2SApple OSS Distributions size_t size = array.size(); 25*19c3b8c2SApple OSS Distributions CHECK(size == 0); 26*19c3b8c2SApple OSS Distributions } 27*19c3b8c2SApple OSS Distributions } 28*19c3b8c2SApple OSS Distributions 29*19c3b8c2SApple OSS Distributions T_DECL(size, "bounded_array.size") { 30*19c3b8c2SApple OSS Distributions tests<T>(); 31*19c3b8c2SApple OSS Distributions } 32