mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-23 18:38:30 +08:00
Protect std::ios tests under libcpp-no-exceptions
Skip tests that expect an exception be thrown. Also add some missing asserts in the original test. Differential Revision: https://reviews.llvm.org/D26512 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@286823 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -7,7 +7,6 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// XFAIL: libcpp-no-exceptions
|
|
||||||
// REQUIRES: locale.en_US.UTF-8
|
// REQUIRES: locale.en_US.UTF-8
|
||||||
// REQUIRES: locale.fr_FR.UTF-8
|
// REQUIRES: locale.fr_FR.UTF-8
|
||||||
|
|
||||||
@@ -23,6 +22,8 @@
|
|||||||
|
|
||||||
#include "platform_support.h" // locale name macros
|
#include "platform_support.h" // locale name macros
|
||||||
|
|
||||||
|
#include "test_macros.h"
|
||||||
|
|
||||||
struct testbuf
|
struct testbuf
|
||||||
: public std::streambuf
|
: public std::streambuf
|
||||||
{
|
{
|
||||||
@@ -158,6 +159,7 @@ int main()
|
|||||||
ios1.copyfmt(ios1);
|
ios1.copyfmt(ios1);
|
||||||
assert(!f1_called);
|
assert(!f1_called);
|
||||||
|
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ios1.copyfmt(ios2);
|
ios1.copyfmt(ios2);
|
||||||
@@ -166,6 +168,9 @@ int main()
|
|||||||
catch (std::ios_base::failure&)
|
catch (std::ios_base::failure&)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
ios1.copyfmt(ios2);
|
||||||
|
#endif
|
||||||
assert(ios1.rdstate() == std::ios::eofbit);
|
assert(ios1.rdstate() == std::ios::eofbit);
|
||||||
assert(ios1.rdbuf() == &sb1);
|
assert(ios1.rdbuf() == &sb1);
|
||||||
assert(ios1.flags() == (std::ios::showpoint | std::ios::uppercase));
|
assert(ios1.flags() == (std::ios::showpoint | std::ios::uppercase));
|
||||||
|
@@ -7,7 +7,6 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// XFAIL: libcpp-no-exceptions
|
|
||||||
// <ios>
|
// <ios>
|
||||||
|
|
||||||
// template <class charT, class traits> class basic_ios
|
// template <class charT, class traits> class basic_ios
|
||||||
@@ -18,6 +17,8 @@
|
|||||||
#include <streambuf>
|
#include <streambuf>
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
|
#include "test_macros.h"
|
||||||
|
|
||||||
struct testbuf
|
struct testbuf
|
||||||
: public std::streambuf
|
: public std::streambuf
|
||||||
{
|
{
|
||||||
@@ -35,16 +36,20 @@ int main()
|
|||||||
testbuf sb1;
|
testbuf sb1;
|
||||||
testbuf sb2;
|
testbuf sb2;
|
||||||
testios ios(&sb1);
|
testios ios(&sb1);
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ios.setstate(std::ios::badbit);
|
ios.setstate(std::ios::badbit);
|
||||||
ios.exceptions(std::ios::badbit);
|
ios.exceptions(std::ios::badbit);
|
||||||
|
assert(false);
|
||||||
}
|
}
|
||||||
catch (...)
|
catch (...)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
ios.set_rdbuf(&sb2);
|
ios.set_rdbuf(&sb2);
|
||||||
assert(ios.rdbuf() == &sb2);
|
assert(ios.rdbuf() == &sb2);
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ios.setstate(std::ios::badbit);
|
ios.setstate(std::ios::badbit);
|
||||||
@@ -53,6 +58,7 @@ int main()
|
|||||||
catch (...)
|
catch (...)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
ios.set_rdbuf(0);
|
ios.set_rdbuf(0);
|
||||||
assert(ios.rdbuf() == 0);
|
assert(ios.rdbuf() == 0);
|
||||||
}
|
}
|
||||||
|
@@ -7,7 +7,6 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// XFAIL: libcpp-no-exceptions
|
|
||||||
// <ios>
|
// <ios>
|
||||||
|
|
||||||
// template <class charT, class traits> class basic_ios
|
// template <class charT, class traits> class basic_ios
|
||||||
@@ -18,6 +17,8 @@
|
|||||||
#include <streambuf>
|
#include <streambuf>
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
|
#include "test_macros.h"
|
||||||
|
|
||||||
struct testbuf : public std::streambuf {};
|
struct testbuf : public std::streambuf {};
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
@@ -26,9 +27,11 @@ int main()
|
|||||||
std::ios ios(0);
|
std::ios ios(0);
|
||||||
ios.clear();
|
ios.clear();
|
||||||
assert(ios.rdstate() == std::ios::badbit);
|
assert(ios.rdstate() == std::ios::badbit);
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ios.exceptions(std::ios::badbit);
|
ios.exceptions(std::ios::badbit);
|
||||||
|
assert(false);
|
||||||
}
|
}
|
||||||
catch (...)
|
catch (...)
|
||||||
{
|
{
|
||||||
@@ -51,6 +54,7 @@ int main()
|
|||||||
{
|
{
|
||||||
assert(ios.rdstate() == (std::ios::eofbit | std::ios::badbit));
|
assert(ios.rdstate() == (std::ios::eofbit | std::ios::badbit));
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
testbuf sb;
|
testbuf sb;
|
||||||
|
@@ -7,7 +7,6 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// XFAIL: libcpp-no-exceptions
|
|
||||||
// <ios>
|
// <ios>
|
||||||
|
|
||||||
// template <class charT, class traits> class basic_ios
|
// template <class charT, class traits> class basic_ios
|
||||||
@@ -18,6 +17,8 @@
|
|||||||
#include <streambuf>
|
#include <streambuf>
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
|
#include "test_macros.h"
|
||||||
|
|
||||||
struct testbuf : public std::streambuf {};
|
struct testbuf : public std::streambuf {};
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
@@ -27,6 +28,7 @@ int main()
|
|||||||
assert(ios.exceptions() == std::ios::goodbit);
|
assert(ios.exceptions() == std::ios::goodbit);
|
||||||
ios.exceptions(std::ios::eofbit);
|
ios.exceptions(std::ios::eofbit);
|
||||||
assert(ios.exceptions() == std::ios::eofbit);
|
assert(ios.exceptions() == std::ios::eofbit);
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ios.exceptions(std::ios::badbit);
|
ios.exceptions(std::ios::badbit);
|
||||||
@@ -36,6 +38,7 @@ int main()
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
assert(ios.exceptions() == std::ios::badbit);
|
assert(ios.exceptions() == std::ios::badbit);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
testbuf sb;
|
testbuf sb;
|
||||||
|
@@ -7,7 +7,6 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// XFAIL: libcpp-no-exceptions
|
|
||||||
// <ios>
|
// <ios>
|
||||||
|
|
||||||
// template <class charT, class traits> class basic_ios
|
// template <class charT, class traits> class basic_ios
|
||||||
@@ -18,6 +17,8 @@
|
|||||||
#include <streambuf>
|
#include <streambuf>
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
|
#include "test_macros.h"
|
||||||
|
|
||||||
struct testbuf : public std::streambuf {};
|
struct testbuf : public std::streambuf {};
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
@@ -26,9 +27,11 @@ int main()
|
|||||||
std::ios ios(0);
|
std::ios ios(0);
|
||||||
ios.setstate(std::ios::goodbit);
|
ios.setstate(std::ios::goodbit);
|
||||||
assert(ios.rdstate() == std::ios::badbit);
|
assert(ios.rdstate() == std::ios::badbit);
|
||||||
|
#ifndef TEST_HAS_NO_EXCEPTIONS
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ios.exceptions(std::ios::badbit);
|
ios.exceptions(std::ios::badbit);
|
||||||
|
assert(false);
|
||||||
}
|
}
|
||||||
catch (...)
|
catch (...)
|
||||||
{
|
{
|
||||||
@@ -51,6 +54,7 @@ int main()
|
|||||||
{
|
{
|
||||||
assert(ios.rdstate() == (std::ios::eofbit | std::ios::badbit));
|
assert(ios.rdstate() == (std::ios::eofbit | std::ios::badbit));
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
testbuf sb;
|
testbuf sb;
|
||||||
|
Reference in New Issue
Block a user