mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 03:32:35 +08:00
Protect std::string tests under libcpp-no-exceptions
Skip tests that expect an exception be thrown and/or disable unreachable catch handlers. Differential Revision: https://reviews.llvm.org/D26608 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@287865 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -7,7 +7,6 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// XFAIL: libcpp-no-exceptions
|
|
||||||
// <string>
|
// <string>
|
||||||
|
|
||||||
// size_type capacity() const;
|
// size_type capacity() const;
|
||||||
@@ -18,21 +17,27 @@
|
|||||||
#include "test_allocator.h"
|
#include "test_allocator.h"
|
||||||
#include "min_allocator.h"
|
#include "min_allocator.h"
|
||||||
|
|
||||||
|
#include "test_macros.h"
|
||||||
|
|
||||||
template <class S>
|
template <class S>
|
||||||
void
|
void
|
||||||
test(S s)
|
test(S s)
|
||||||
{
|
{
|
||||||
S::allocator_type::throw_after = 0;
|
S::allocator_type::throw_after = 0;
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
try
|
try
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
while (s.size() < s.capacity())
|
while (s.size() < s.capacity())
|
||||||
s.push_back(typename S::value_type());
|
s.push_back(typename S::value_type());
|
||||||
assert(s.size() == s.capacity());
|
assert(s.size() == s.capacity());
|
||||||
}
|
}
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
catch (...)
|
catch (...)
|
||||||
{
|
{
|
||||||
assert(false);
|
assert(false);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
S::allocator_type::throw_after = INT_MAX;
|
S::allocator_type::throw_after = INT_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,6 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// XFAIL: libcpp-no-exceptions
|
|
||||||
// <string>
|
// <string>
|
||||||
|
|
||||||
// basic_string substr(size_type pos = 0, size_type n = npos) const;
|
// basic_string substr(size_type pos = 0, size_type n = npos) const;
|
||||||
@@ -24,19 +23,27 @@ template <class S>
|
|||||||
void
|
void
|
||||||
test(const S& s, typename S::size_type pos, typename S::size_type n)
|
test(const S& s, typename S::size_type pos, typename S::size_type n)
|
||||||
{
|
{
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
try
|
try
|
||||||
|
#else
|
||||||
|
if (pos <= s.size())
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
S str = s.substr(pos, n);
|
S str = s.substr(pos, n);
|
||||||
LIBCPP_ASSERT(str.__invariants());
|
LIBCPP_ASSERT(str.__invariants());
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
assert(pos <= s.size());
|
assert(pos <= s.size());
|
||||||
|
#endif
|
||||||
typename S::size_type rlen = std::min(n, s.size() - pos);
|
typename S::size_type rlen = std::min(n, s.size() - pos);
|
||||||
assert(str.size() == rlen);
|
assert(str.size() == rlen);
|
||||||
assert(S::traits_type::compare(s.data()+pos, str.data(), rlen) == 0);
|
assert(S::traits_type::compare(s.data()+pos, str.data(), rlen) == 0);
|
||||||
}
|
}
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
catch (std::out_of_range&)
|
catch (std::out_of_range&)
|
||||||
{
|
{
|
||||||
assert(pos > s.size());
|
assert(pos > s.size());
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
|
|||||||
Reference in New Issue
Block a user