Index: libcxx/trunk/test/std/strings/basic.string/string.capacity/capacity.pass.cpp =================================================================== --- libcxx/trunk/test/std/strings/basic.string/string.capacity/capacity.pass.cpp +++ libcxx/trunk/test/std/strings/basic.string/string.capacity/capacity.pass.cpp @@ -7,7 +7,6 @@ // //===----------------------------------------------------------------------===// -// XFAIL: libcpp-no-exceptions // // size_type capacity() const; @@ -18,21 +17,27 @@ #include "test_allocator.h" #include "min_allocator.h" +#include "test_macros.h" + template void test(S s) { S::allocator_type::throw_after = 0; +#ifndef TEST_HAS_NO_EXCEPTIONS try +#endif { while (s.size() < s.capacity()) s.push_back(typename S::value_type()); assert(s.size() == s.capacity()); } +#ifndef TEST_HAS_NO_EXCEPTIONS catch (...) { assert(false); } +#endif S::allocator_type::throw_after = INT_MAX; } Index: libcxx/trunk/test/std/strings/basic.string/string.ops/string_substr/substr.pass.cpp =================================================================== --- libcxx/trunk/test/std/strings/basic.string/string.ops/string_substr/substr.pass.cpp +++ libcxx/trunk/test/std/strings/basic.string/string.ops/string_substr/substr.pass.cpp @@ -7,7 +7,6 @@ // //===----------------------------------------------------------------------===// -// XFAIL: libcpp-no-exceptions // // basic_string substr(size_type pos = 0, size_type n = npos) const; @@ -24,7 +23,7 @@ void test(const S& s, typename S::size_type pos, typename S::size_type n) { - try + if (pos <= s.size()) { S str = s.substr(pos, n); LIBCPP_ASSERT(str.__invariants()); @@ -33,10 +32,20 @@ assert(str.size() == rlen); assert(S::traits_type::compare(s.data()+pos, str.data(), rlen) == 0); } - catch (std::out_of_range&) +#ifndef TEST_HAS_NO_EXCEPTIONS + else { - assert(pos > s.size()); + try + { + S str = s.substr(pos, n); + assert(false); + } + catch (std::out_of_range&) + { + assert(pos > s.size()); + } } +#endif } int main()