Add Address Sanitizer support to std::vector
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@208319 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -15,6 +15,7 @@
|
||||
#include <cassert>
|
||||
#include "../../../stack_allocator.h"
|
||||
#include "min_allocator.h"
|
||||
#include "asan_testing.h"
|
||||
|
||||
int main()
|
||||
{
|
||||
@@ -22,22 +23,27 @@ int main()
|
||||
std::vector<int> c;
|
||||
c.push_back(0);
|
||||
assert(c.size() == 1);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(1);
|
||||
assert(c.size() == 2);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(2);
|
||||
assert(c.size() == 3);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(3);
|
||||
assert(c.size() == 4);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(4);
|
||||
assert(c.size() == 5);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
}
|
||||
@@ -45,22 +51,27 @@ int main()
|
||||
std::vector<int, stack_allocator<int, 15> > c;
|
||||
c.push_back(0);
|
||||
assert(c.size() == 1);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(1);
|
||||
assert(c.size() == 2);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(2);
|
||||
assert(c.size() == 3);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(3);
|
||||
assert(c.size() == 4);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(4);
|
||||
assert(c.size() == 5);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
}
|
||||
@@ -69,22 +80,27 @@ int main()
|
||||
std::vector<int, min_allocator<int>> c;
|
||||
c.push_back(0);
|
||||
assert(c.size() == 1);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(1);
|
||||
assert(c.size() == 2);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(2);
|
||||
assert(c.size() == 3);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(3);
|
||||
assert(c.size() == 4);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
c.push_back(4);
|
||||
assert(c.size() == 5);
|
||||
assert(is_contiguous_container_asan_correct(c));
|
||||
for (int j = 0; j < c.size(); ++j)
|
||||
assert(c[j] == j);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user