1*19c3b8c2SApple OSS Distributions //
2*19c3b8c2SApple OSS Distributions // Tests for
3*19c3b8c2SApple OSS Distributions // iterator begin();
4*19c3b8c2SApple OSS Distributions // const_iterator begin() const;
5*19c3b8c2SApple OSS Distributions //
6*19c3b8c2SApple OSS Distributions // iterator end();
7*19c3b8c2SApple OSS Distributions // const_iterator end() const;
8*19c3b8c2SApple OSS Distributions //
9*19c3b8c2SApple OSS Distributions
10*19c3b8c2SApple OSS Distributions #include <libkern/c++/bounded_array.h>
11*19c3b8c2SApple OSS Distributions #include "test_policy.h"
12*19c3b8c2SApple OSS Distributions #include <darwintest.h>
13*19c3b8c2SApple OSS Distributions #include <type_traits>
14*19c3b8c2SApple OSS Distributions
15*19c3b8c2SApple OSS Distributions struct T { int i; };
16*19c3b8c2SApple OSS Distributions
17*19c3b8c2SApple OSS Distributions template <typename T>
18*19c3b8c2SApple OSS Distributions static void
tests()19*19c3b8c2SApple OSS Distributions tests()
20*19c3b8c2SApple OSS Distributions {
21*19c3b8c2SApple OSS Distributions // Check begin()/end() for a non-empty array
22*19c3b8c2SApple OSS Distributions {
23*19c3b8c2SApple OSS Distributions test_bounded_array<T, 5> array = {T{0}, T{1}, T{2}, T{3}, T{4}};
24*19c3b8c2SApple OSS Distributions test_bounded_ptr<T> begin = array.begin();
25*19c3b8c2SApple OSS Distributions test_bounded_ptr<T> end = array.end();
26*19c3b8c2SApple OSS Distributions CHECK(begin.discard_bounds() == array.data());
27*19c3b8c2SApple OSS Distributions CHECK(end.unsafe_discard_bounds() == array.data() + 5);
28*19c3b8c2SApple OSS Distributions }
29*19c3b8c2SApple OSS Distributions {
30*19c3b8c2SApple OSS Distributions test_bounded_array<T, 5> const array = {T{0}, T{1}, T{2}, T{3}, T{4}};
31*19c3b8c2SApple OSS Distributions test_bounded_ptr<T const> begin = array.begin();
32*19c3b8c2SApple OSS Distributions test_bounded_ptr<T const> end = array.end();
33*19c3b8c2SApple OSS Distributions CHECK(begin.discard_bounds() == array.data());
34*19c3b8c2SApple OSS Distributions CHECK(end.unsafe_discard_bounds() == array.data() + 5);
35*19c3b8c2SApple OSS Distributions }
36*19c3b8c2SApple OSS Distributions
37*19c3b8c2SApple OSS Distributions // Check begin()/end() for an empty array
38*19c3b8c2SApple OSS Distributions {
39*19c3b8c2SApple OSS Distributions test_bounded_array<T, 0> array = {};
40*19c3b8c2SApple OSS Distributions test_bounded_ptr<T> begin = array.begin();
41*19c3b8c2SApple OSS Distributions test_bounded_ptr<T> end = array.end();
42*19c3b8c2SApple OSS Distributions CHECK(begin.unsafe_discard_bounds() == array.data());
43*19c3b8c2SApple OSS Distributions CHECK(end.unsafe_discard_bounds() == array.data());
44*19c3b8c2SApple OSS Distributions }
45*19c3b8c2SApple OSS Distributions {
46*19c3b8c2SApple OSS Distributions test_bounded_array<T, 0> const array = {};
47*19c3b8c2SApple OSS Distributions test_bounded_ptr<T const> begin = array.begin();
48*19c3b8c2SApple OSS Distributions test_bounded_ptr<T const> end = array.end();
49*19c3b8c2SApple OSS Distributions CHECK(begin.unsafe_discard_bounds() == array.data());
50*19c3b8c2SApple OSS Distributions CHECK(end.unsafe_discard_bounds() == array.data());
51*19c3b8c2SApple OSS Distributions }
52*19c3b8c2SApple OSS Distributions
53*19c3b8c2SApple OSS Distributions // Check associated types
54*19c3b8c2SApple OSS Distributions {
55*19c3b8c2SApple OSS Distributions using A = test_bounded_array<T, 10>;
56*19c3b8c2SApple OSS Distributions static_assert(std::is_same_v<typename A::iterator, test_bounded_ptr<T> >);
57*19c3b8c2SApple OSS Distributions static_assert(std::is_same_v<typename A::const_iterator, test_bounded_ptr<T const> >);
58*19c3b8c2SApple OSS Distributions }
59*19c3b8c2SApple OSS Distributions }
60*19c3b8c2SApple OSS Distributions
61*19c3b8c2SApple OSS Distributions T_DECL(begin_end, "bounded_array.begin_end") {
62*19c3b8c2SApple OSS Distributions tests<T>();
63*19c3b8c2SApple OSS Distributions }
64