Files
libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/rvalue_T.pass.cpp
Louis Dionne 4806bce5a8 [libc++] Fix XFAILs on macOS when exceptions are disabled
Some tests are marked as failing on platforms where the dylib does not
provide the required exception classes. However, when testing with
exceptions disabled, those tests shouldn't be marked as failing.

git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@353210 91177308-0d34-0410-b5e6-96231b3b80d8
2019-02-05 20:11:58 +00:00

157 lines
3.9 KiB
C++

//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// UNSUPPORTED: c++98, c++03, c++11, c++14
// XFAIL: dylib-has-no-bad_optional_access && !libcpp-no-exceptions
// <optional>
// constexpr optional(T&& v);
#include <optional>
#include <type_traits>
#include <cassert>
#include "test_macros.h"
#include "archetypes.hpp"
using std::optional;
class Z
{
public:
Z(int) {}
Z(Z&&) {TEST_THROW(6);}
};
int main(int, char**)
{
{
typedef int T;
constexpr optional<T> opt(T(5));
static_assert(static_cast<bool>(opt) == true, "");
static_assert(*opt == 5, "");
struct test_constexpr_ctor
: public optional<T>
{
constexpr test_constexpr_ctor(T&&) {}
};
}
{
typedef double T;
constexpr optional<T> opt(T(3));
static_assert(static_cast<bool>(opt) == true, "");
static_assert(*opt == 3, "");
struct test_constexpr_ctor
: public optional<T>
{
constexpr test_constexpr_ctor(T&&) {}
};
}
{
const int x = 42;
optional<const int> o(std::move(x));
assert(*o == 42);
}
{
typedef TestTypes::TestType T;
T::reset();
optional<T> opt = T{3};
assert(T::alive == 1);
assert(T::move_constructed == 1);
assert(static_cast<bool>(opt) == true);
assert(opt.value().value == 3);
}
{
typedef ExplicitTestTypes::TestType T;
static_assert(!std::is_convertible<T&&, optional<T>>::value, "");
T::reset();
optional<T> opt(T{3});
assert(T::alive == 1);
assert(T::move_constructed == 1);
assert(static_cast<bool>(opt) == true);
assert(opt.value().value == 3);
}
{
typedef TestTypes::TestType T;
T::reset();
optional<T> opt = {3};
assert(T::alive == 1);
assert(T::value_constructed == 1);
assert(T::copy_constructed == 0);
assert(T::move_constructed == 0);
assert(static_cast<bool>(opt) == true);
assert(opt.value().value == 3);
}
{
typedef ConstexprTestTypes::TestType T;
constexpr optional<T> opt = {T(3)};
static_assert(static_cast<bool>(opt) == true, "");
static_assert(opt.value().value == 3, "");
struct test_constexpr_ctor
: public optional<T>
{
constexpr test_constexpr_ctor(const T&) {}
};
}
{
typedef ConstexprTestTypes::TestType T;
constexpr optional<T> opt = {3};
static_assert(static_cast<bool>(opt) == true, "");
static_assert(opt.value().value == 3, "");
struct test_constexpr_ctor
: public optional<T>
{
constexpr test_constexpr_ctor(const T&) {}
};
}
{
typedef ExplicitConstexprTestTypes::TestType T;
static_assert(!std::is_convertible<T&&, optional<T>>::value, "");
constexpr optional<T> opt(T{3});
static_assert(static_cast<bool>(opt) == true, "");
static_assert(opt.value().value == 3, "");
struct test_constexpr_ctor
: public optional<T>
{
constexpr test_constexpr_ctor(T&&) {}
};
}
#ifndef TEST_HAS_NO_EXCEPTIONS
{
struct Z {
Z(int) {}
Z(Z&&) {throw 6;}
};
typedef Z T;
try
{
T t(3);
optional<T> opt(std::move(t));
assert(false);
}
catch (int i)
{
assert(i == 6);
}
}
#endif
return 0;
}