From 29b75d6986caa3f9c12667272d4c65f3c7610e24 Mon Sep 17 00:00:00 2001 From: Marshall Clow Date: Thu, 25 May 2017 00:22:33 +0000 Subject: Add some constexpr tests for optional's move/copy ctor llvm-svn: 303824 --- .../optional.object/optional.object.ctor/copy.pass.cpp | 13 +++++++++++++ .../optional.object/optional.object.ctor/move.pass.cpp | 14 ++++++++++++++ 2 files changed, 27 insertions(+) (limited to 'libcxx/test/std/utilities/optional') diff --git a/libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/copy.pass.cpp b/libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/copy.pass.cpp index 76c1fb82b86..6b4283a2854 100644 --- a/libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/copy.pass.cpp +++ b/libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/copy.pass.cpp @@ -32,6 +32,16 @@ void test(InitArgs&&... args) assert(*lhs == *rhs); } +template +constexpr bool constexpr_test(InitArgs&&... args) +{ + static_assert( std::is_trivially_copy_constructible_v, ""); // requirement + const optional rhs(std::forward(args)...); + optional lhs = rhs; + return (lhs.has_value() == rhs.has_value()) && + (lhs.has_value() ? *lhs == *rhs : true); +} + void test_throwing_ctor() { #ifndef TEST_HAS_NO_EXCEPTIONS struct Z { @@ -108,6 +118,9 @@ int main() { test(); test(3); + static_assert(constexpr_test(), "" ); + static_assert(constexpr_test(3), "" ); + { const optional o(42); optional o2(o); diff --git a/libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/move.pass.cpp b/libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/move.pass.cpp index 09aaa0561b5..82acdd9d775 100644 --- a/libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/move.pass.cpp +++ b/libcxx/test/std/utilities/optional/optional.object/optional.object.ctor/move.pass.cpp @@ -41,6 +41,17 @@ void test(InitArgs&&... args) assert(*lhs == *orig); } +template +constexpr bool constexpr_test(InitArgs&&... args) +{ + static_assert( std::is_trivially_copy_constructible_v, ""); // requirement + const optional orig(std::forward(args)...); + optional rhs(orig); + optional lhs = std::move(rhs); + return (lhs.has_value() == orig.has_value()) && + (lhs.has_value() ? *lhs == *orig : true); +} + void test_throwing_ctor() { #ifndef TEST_HAS_NO_EXCEPTIONS struct Z { @@ -144,6 +155,9 @@ int main() { test(); test(3); + static_assert(constexpr_test(), "" ); + static_assert(constexpr_test(3), "" ); + { optional o(42); optional o2(std::move(o)); -- cgit v1.2.3