blob: 91facb00436689254889a48bd089604f4beda762 [file] [log] [blame]
Karl Wiberge2a83ee2015-10-26 19:51:29 +01001/*
2 * Copyright 2015 The WebRTC Project Authors. All rights reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#include <algorithm>
12#include <string>
13#include <vector>
14
15#include "webrtc/base/array_view.h"
16#include "webrtc/base/buffer.h"
17#include "webrtc/base/checks.h"
18#include "webrtc/base/gunit.h"
19
20namespace rtc {
21
22namespace {
kwibergbd431722016-09-05 04:20:54 -070023
Karl Wiberge2a83ee2015-10-26 19:51:29 +010024template <typename T>
25void Call(ArrayView<T>) {}
kwibergbd431722016-09-05 04:20:54 -070026
Karl Wiberge2a83ee2015-10-26 19:51:29 +010027} // namespace
28
29TEST(ArrayViewTest, TestConstructFromPtrAndArray) {
30 char arr[] = "Arrr!";
31 const char carr[] = "Carrr!";
32 Call<const char>(arr);
33 Call<const char>(carr);
34 Call<char>(arr);
35 // Call<char>(carr); // Compile error, because can't drop const.
36 // Call<int>(arr); // Compile error, because incompatible types.
37 ArrayView<int*> x;
38 EXPECT_EQ(0u, x.size());
39 EXPECT_EQ(nullptr, x.data());
40 ArrayView<char> y = arr;
41 EXPECT_EQ(6u, y.size());
42 EXPECT_EQ(arr, y.data());
43 ArrayView<const char> z(arr + 1, 3);
44 EXPECT_EQ(3u, z.size());
45 EXPECT_EQ(arr + 1, z.data());
46 ArrayView<const char> w(arr, 2);
47 EXPECT_EQ(2u, w.size());
48 EXPECT_EQ(arr, w.data());
49 ArrayView<char> q(arr, 0);
50 EXPECT_EQ(0u, q.size());
51 EXPECT_EQ(nullptr, q.data());
52#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
53 // DCHECK error (nullptr with nonzero size).
54 EXPECT_DEATH(ArrayView<int>(static_cast<int*>(nullptr), 5), "");
55#endif
56 // These are compile errors, because incompatible types.
57 // ArrayView<int> m = arr;
58 // ArrayView<float> n(arr + 2, 2);
59}
60
61TEST(ArrayViewTest, TestCopyConstructor) {
62 char arr[] = "Arrr!";
63 ArrayView<char> x = arr;
64 EXPECT_EQ(6u, x.size());
65 EXPECT_EQ(arr, x.data());
66 ArrayView<char> y = x; // Copy non-const -> non-const.
67 EXPECT_EQ(6u, y.size());
68 EXPECT_EQ(arr, y.data());
69 ArrayView<const char> z = x; // Copy non-const -> const.
70 EXPECT_EQ(6u, z.size());
71 EXPECT_EQ(arr, z.data());
72 ArrayView<const char> w = z; // Copy const -> const.
73 EXPECT_EQ(6u, w.size());
74 EXPECT_EQ(arr, w.data());
75 // ArrayView<char> v = z; // Compile error, because can't drop const.
76}
77
78TEST(ArrayViewTest, TestCopyAssignment) {
79 char arr[] = "Arrr!";
80 ArrayView<char> x(arr);
81 EXPECT_EQ(6u, x.size());
82 EXPECT_EQ(arr, x.data());
83 ArrayView<char> y;
84 y = x; // Copy non-const -> non-const.
85 EXPECT_EQ(6u, y.size());
86 EXPECT_EQ(arr, y.data());
87 ArrayView<const char> z;
88 z = x; // Copy non-const -> const.
89 EXPECT_EQ(6u, z.size());
90 EXPECT_EQ(arr, z.data());
91 ArrayView<const char> w;
92 w = z; // Copy const -> const.
93 EXPECT_EQ(6u, w.size());
94 EXPECT_EQ(arr, w.data());
95 // ArrayView<char> v;
96 // v = z; // Compile error, because can't drop const.
97}
98
99TEST(ArrayViewTest, TestStdVector) {
100 std::vector<int> v;
101 v.push_back(3);
102 v.push_back(11);
103 Call<const int>(v);
104 Call<int>(v);
105 // Call<unsigned int>(v); // Compile error, because incompatible types.
106 ArrayView<int> x = v;
107 EXPECT_EQ(2u, x.size());
108 EXPECT_EQ(v.data(), x.data());
109 ArrayView<const int> y;
110 y = v;
111 EXPECT_EQ(2u, y.size());
112 EXPECT_EQ(v.data(), y.data());
113 // ArrayView<double> d = v; // Compile error, because incompatible types.
114 const std::vector<int> cv;
115 Call<const int>(cv);
116 // Call<int>(cv); // Compile error, because can't drop const.
117 ArrayView<const int> z = cv;
118 EXPECT_EQ(0u, z.size());
119 EXPECT_EQ(nullptr, z.data());
120 // ArrayView<int> w = cv; // Compile error, because can't drop const.
121}
122
123TEST(ArrayViewTest, TestRtcBuffer) {
124 rtc::Buffer b = "so buffer";
125 Call<const uint8_t>(b);
126 Call<uint8_t>(b);
127 // Call<int8_t>(b); // Compile error, because incompatible types.
128 ArrayView<uint8_t> x = b;
129 EXPECT_EQ(10u, x.size());
130 EXPECT_EQ(b.data(), x.data());
131 ArrayView<const uint8_t> y;
132 y = b;
133 EXPECT_EQ(10u, y.size());
134 EXPECT_EQ(b.data(), y.data());
135 // ArrayView<char> d = b; // Compile error, because incompatible types.
136 const rtc::Buffer cb = "very const";
137 Call<const uint8_t>(cb);
138 // Call<uint8_t>(cb); // Compile error, because can't drop const.
139 ArrayView<const uint8_t> z = cb;
140 EXPECT_EQ(11u, z.size());
141 EXPECT_EQ(cb.data(), z.data());
142 // ArrayView<uint8_t> w = cb; // Compile error, because can't drop const.
143}
144
145TEST(ArrayViewTest, TestSwap) {
146 const char arr[] = "Arrr!";
147 const char aye[] = "Aye, Cap'n!";
148 ArrayView<const char> x(arr);
149 EXPECT_EQ(6u, x.size());
150 EXPECT_EQ(arr, x.data());
151 ArrayView<const char> y(aye);
152 EXPECT_EQ(12u, y.size());
153 EXPECT_EQ(aye, y.data());
154 using std::swap;
155 swap(x, y);
156 EXPECT_EQ(12u, x.size());
157 EXPECT_EQ(aye, x.data());
158 EXPECT_EQ(6u, y.size());
159 EXPECT_EQ(arr, y.data());
160 // ArrayView<char> z;
161 // swap(x, z); // Compile error, because can't drop const.
162}
163
164TEST(ArrayViewTest, TestIndexing) {
165 char arr[] = "abcdefg";
166 ArrayView<char> x(arr);
167 const ArrayView<char> y(arr);
168 ArrayView<const char> z(arr);
169 EXPECT_EQ(8u, x.size());
170 EXPECT_EQ(8u, y.size());
171 EXPECT_EQ(8u, z.size());
172 EXPECT_EQ('b', x[1]);
173 EXPECT_EQ('c', y[2]);
174 EXPECT_EQ('d', z[3]);
175 x[3] = 'X';
176 y[2] = 'Y';
177 // z[1] = 'Z'; // Compile error, because z's element type is const char.
178 EXPECT_EQ('b', x[1]);
179 EXPECT_EQ('Y', y[2]);
180 EXPECT_EQ('X', z[3]);
181#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
182 EXPECT_DEATH(z[8], ""); // DCHECK error (index out of bounds).
183#endif
184}
185
186TEST(ArrayViewTest, TestIterationEmpty) {
187 ArrayView<std::vector<std::vector<std::vector<std::string>>>> av;
188 EXPECT_FALSE(av.begin());
189 EXPECT_FALSE(av.cbegin());
190 EXPECT_FALSE(av.end());
191 EXPECT_FALSE(av.cend());
192 for (auto& e : av) {
193 EXPECT_TRUE(false);
194 EXPECT_EQ(42u, e.size()); // Dummy use of e to prevent unused var warning.
195 }
196}
197
198TEST(ArrayViewTest, TestIteration) {
199 char arr[] = "Arrr!";
200 ArrayView<char> av(arr);
201 EXPECT_EQ('A', *av.begin());
202 EXPECT_EQ('A', *av.cbegin());
203 EXPECT_EQ('\0', *(av.end() - 1));
204 EXPECT_EQ('\0', *(av.cend() - 1));
205 char i = 0;
206 for (auto& e : av) {
207 EXPECT_EQ(arr + i, &e);
208 e = 's' + i;
209 ++i;
210 }
211 i = 0;
212 for (auto& e : ArrayView<const char>(av)) {
213 EXPECT_EQ(arr + i, &e);
214 // e = 'q' + i; // Compile error, because e is a const char&.
215 ++i;
216 }
217}
218
kwiberg288886b2015-11-06 01:21:35 -0800219TEST(ArrayViewTest, TestEmpty) {
220 EXPECT_TRUE(ArrayView<int>().empty());
221 const int a[] = {1, 2, 3};
222 EXPECT_FALSE(ArrayView<const int>(a).empty());
223}
224
225TEST(ArrayViewTest, TestCompare) {
226 int a[] = {1, 2, 3};
227 int b[] = {1, 2, 3};
228 EXPECT_EQ(ArrayView<int>(a), ArrayView<int>(a));
229 EXPECT_EQ(ArrayView<int>(), ArrayView<int>());
230 EXPECT_NE(ArrayView<int>(a), ArrayView<int>(b));
231 EXPECT_NE(ArrayView<int>(a), ArrayView<int>());
232 EXPECT_NE(ArrayView<int>(a), ArrayView<int>(a, 2));
233}
234
Karl Wiberge2a83ee2015-10-26 19:51:29 +0100235} // namespace rtc