[X86] matchPMADDWD/matchPMADDWD_2 - update to use m_ExtractElt matchers. NFC.
[llvm-project.git] / libcxx / test / std / containers / sequences / vector / vector.capacity / reserve.pass.cpp
blobb8548ad72d4376fa45aba2386ca79c59f255704b
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 // <vector>
11 // void reserve(size_type n);
13 #include <vector>
14 #include <cassert>
15 #include <stdexcept>
16 #include "test_macros.h"
17 #include "test_allocator.h"
18 #include "min_allocator.h"
19 #include "asan_testing.h"
21 TEST_CONSTEXPR_CXX20 bool tests() {
23 std::vector<int> v;
24 v.reserve(10);
25 assert(v.capacity() >= 10);
26 assert(is_contiguous_container_asan_correct(v));
29 std::vector<int> v(100);
30 assert(v.capacity() == 100);
31 v.reserve(50);
32 assert(v.size() == 100);
33 assert(v.capacity() == 100);
34 v.reserve(150);
35 assert(v.size() == 100);
36 assert(v.capacity() == 150);
37 assert(is_contiguous_container_asan_correct(v));
40 // Add 1 for implementations that dynamically allocate a container proxy.
41 std::vector<int, limited_allocator<int, 250 + 1> > v(100);
42 assert(v.capacity() == 100);
43 v.reserve(50);
44 assert(v.size() == 100);
45 assert(v.capacity() == 100);
46 v.reserve(150);
47 assert(v.size() == 100);
48 assert(v.capacity() == 150);
49 assert(is_contiguous_container_asan_correct(v));
51 #ifndef TEST_HAS_NO_EXCEPTIONS
52 if (!TEST_IS_CONSTANT_EVALUATED) {
53 std::vector<int> v;
54 std::size_t sz = v.max_size() + 1;
56 try {
57 v.reserve(sz);
58 assert(false);
59 } catch (const std::length_error&) {
60 assert(v.size() == 0);
61 assert(v.capacity() == 0);
64 if (!TEST_IS_CONSTANT_EVALUATED) {
65 std::vector<int> v(10, 42);
66 int* previous_data = v.data();
67 std::size_t previous_capacity = v.capacity();
68 std::size_t sz = v.max_size() + 1;
70 try {
71 v.reserve(sz);
72 assert(false);
73 } catch (std::length_error&) {
74 assert(v.size() == 10);
75 assert(v.capacity() == previous_capacity);
76 assert(v.data() == previous_data);
78 for (int i = 0; i < 10; ++i) {
79 assert(v[i] == 42);
83 #endif
84 #if TEST_STD_VER >= 11
86 std::vector<int, min_allocator<int>> v;
87 v.reserve(10);
88 assert(v.capacity() >= 10);
89 assert(is_contiguous_container_asan_correct(v));
92 std::vector<int, min_allocator<int>> v(100);
93 assert(v.capacity() == 100);
94 v.reserve(50);
95 assert(v.size() == 100);
96 assert(v.capacity() == 100);
97 v.reserve(150);
98 assert(v.size() == 100);
99 assert(v.capacity() == 150);
100 assert(is_contiguous_container_asan_correct(v));
103 std::vector<int, safe_allocator<int>> v;
104 v.reserve(10);
105 assert(v.capacity() >= 10);
106 assert(is_contiguous_container_asan_correct(v));
109 std::vector<int, safe_allocator<int>> v(100);
110 assert(v.capacity() == 100);
111 v.reserve(50);
112 assert(v.size() == 100);
113 assert(v.capacity() == 100);
114 v.reserve(150);
115 assert(v.size() == 100);
116 assert(v.capacity() == 150);
117 assert(is_contiguous_container_asan_correct(v));
119 #endif
120 #ifndef TEST_HAS_NO_EXCEPTIONS
121 if (!TEST_IS_CONSTANT_EVALUATED) {
122 std::vector<int, limited_allocator<int, 100> > v;
123 v.reserve(50);
124 assert(v.capacity() == 50);
125 assert(is_contiguous_container_asan_correct(v));
126 try {
127 v.reserve(101);
128 assert(false);
129 } catch (const std::length_error&) {
130 // no-op
132 assert(v.capacity() == 50);
133 assert(is_contiguous_container_asan_correct(v));
135 #endif
137 return true;
140 int main(int, char**)
142 tests();
144 #if TEST_STD_VER > 17
145 static_assert(tests());
146 #endif
148 return 0;