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