From 2cbc654d93bc9f1f3e6dd59166c7e1f8750738d1 Mon Sep 17 00:00:00 2001 From: Eric Fiselier Date: Mon, 22 Dec 2014 22:38:59 +0000 Subject: [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 --- .../func.wrap.func/func.wrap.func.con/F.pass.cpp | 32 ++++++---------------- 1 file changed, 8 insertions(+), 24 deletions(-) (limited to 'libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F.pass.cpp') diff --git a/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F.pass.cpp b/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F.pass.cpp index 3a43be73f7a..f506af0e001 100644 --- a/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F.pass.cpp +++ b/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F.pass.cpp @@ -13,26 +13,10 @@ // function(nullptr_t); -// UNSUPPORTED: asan, msan - #include -#include -#include #include -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 { @@ -67,34 +51,34 @@ int g(int) {return 0;} int main() { - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function f = A(); assert(A::count == 1); - assert(new_called == 1); + assert(globalMemCounter.checkOutstandingNewEq(1)); assert(f.target()); assert(f.target() == 0); } assert(A::count == 0); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function f = g; - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); assert(f.target()); assert(f.target() == 0); } - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); { std::function f = (int (*)(int))0; assert(!f); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); assert(f.target() == 0); assert(f.target() == 0); } { std::function f = &A::foo; assert(f); - assert(new_called == 0); + assert(globalMemCounter.checkOutstandingNewEq(0)); assert(f.target() != 0); } } -- cgit v1.2.3