diff options
author | Eric Fiselier <eric@efcs.ca> | 2014-12-22 22:38:59 +0000 |
---|---|---|
committer | Eric Fiselier <eric@efcs.ca> | 2014-12-22 22:38:59 +0000 |
commit | 2cbc654d93bc9f1f3e6dd59166c7e1f8750738d1 (patch) | |
tree | ab539fa3fe99f12333428aa427c6c41cdf28e5e7 /libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.alg/swap.pass.cpp | |
parent | bad65c3b708accec8c6e85346dabc7967cb3d7ca (diff) | |
download | bcm5719-llvm-2cbc654d93bc9f1f3e6dd59166c7e1f8750738d1.tar.gz bcm5719-llvm-2cbc654d93bc9f1f3e6dd59166c7e1f8750738d1.zip |
[libcxx] Consolidate new/delete replacement in tests and disable it when using sanitizers.
Summary:
MSAN and ASAN also replace new/delete which leads to a link error in these tests. Currently they are unsupported but I think it would be useful if these tests could run with sanitizers.
This patch creates a support header that consolidates the new/delete replacement functionality and checking.
When we are using sanitizers new and delete are no longer replaced and the checks always return true.
Reviewers: mclow.lists, danalbert, jroelofs, EricWF
Reviewed By: EricWF
Subscribers: cfe-commits
Differential Revision: http://reviews.llvm.org/D6562
llvm-svn: 224741
Diffstat (limited to 'libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.alg/swap.pass.cpp')
-rw-r--r-- | libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.alg/swap.pass.cpp | 42 |
1 files changed, 14 insertions, 28 deletions
diff --git a/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.alg/swap.pass.cpp b/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.alg/swap.pass.cpp index b8995bffe0f..58192c928d5 100644 --- a/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.alg/swap.pass.cpp +++ b/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.alg/swap.pass.cpp @@ -14,26 +14,12 @@ // template <MoveConstructible R, MoveConstructible ... ArgTypes> // void swap(function<R(ArgTypes...)>&, function<R(ArgTypes...)>&); -// UNSUPPORTED: asan, msan #include <functional> -#include <new> #include <cstdlib> #include <cassert> -int new_called = 0; - -void* operator new(std::size_t s) throw(std::bad_alloc) -{ - ++new_called; - return std::malloc(s); -} - -void operator delete(void* p) throw() -{ - --new_called; - std::free(p); -} +#include "count_new.hpp" class A { @@ -73,65 +59,65 @@ int h(int) {return 1;} int main() { - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function<int(int)> f1 = A(1); std::function<int(int)> f2 = A(2); assert(A::count == 2); - assert(new_called == 2); + assert(globalMemCounter.checkOutstandingNewEq(2)); assert(f1.target<A>()->id() == 1); assert(f2.target<A>()->id() == 2); swap(f1, f2); assert(A::count == 2); - assert(new_called == 2); + assert(globalMemCounter.checkOutstandingNewEq(2)); assert(f1.target<A>()->id() == 2); assert(f2.target<A>()->id() == 1); } assert(A::count == 0); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function<int(int)> f1 = A(1); std::function<int(int)> f2 = g; assert(A::count == 1); - assert(new_called == 1); + assert(globalMemCounter.checkOutstandingNewEq(1)); assert(f1.target<A>()->id() == 1); assert(*f2.target<int(*)(int)>() == g); swap(f1, f2); assert(A::count == 1); - assert(new_called == 1); + assert(globalMemCounter.checkOutstandingNewEq(1)); assert(*f1.target<int(*)(int)>() == g); assert(f2.target<A>()->id() == 1); } assert(A::count == 0); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function<int(int)> f1 = g; std::function<int(int)> f2 = A(1); assert(A::count == 1); - assert(new_called == 1); + assert(globalMemCounter.checkOutstandingNewEq(1)); assert(*f1.target<int(*)(int)>() == g); assert(f2.target<A>()->id() == 1); swap(f1, f2); assert(A::count == 1); - assert(new_called == 1); + assert(globalMemCounter.checkOutstandingNewEq(1)); assert(f1.target<A>()->id() == 1); assert(*f2.target<int(*)(int)>() == g); } assert(A::count == 0); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function<int(int)> f1 = g; std::function<int(int)> f2 = h; assert(A::count == 0); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); assert(*f1.target<int(*)(int)>() == g); assert(*f2.target<int(*)(int)>() == h); swap(f1, f2); assert(A::count == 0); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); assert(*f1.target<int(*)(int)>() == h); assert(*f2.target<int(*)(int)>() == g); } assert(A::count == 0); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); } |