summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/outcome/test/tests/constexpr.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/boost/libs/outcome/test/tests/constexpr.cpp')
-rw-r--r--src/boost/libs/outcome/test/tests/constexpr.cpp118
1 files changed, 118 insertions, 0 deletions
diff --git a/src/boost/libs/outcome/test/tests/constexpr.cpp b/src/boost/libs/outcome/test/tests/constexpr.cpp
new file mode 100644
index 000000000..b8030e943
--- /dev/null
+++ b/src/boost/libs/outcome/test/tests/constexpr.cpp
@@ -0,0 +1,118 @@
+/* Unit testing for outcomes
+(C) 2013-2022 Niall Douglas <http://www.nedproductions.biz/> (9 commits)
+
+
+Boost Software License - Version 1.0 - August 17th, 2003
+
+Permission is hereby granted, free of charge, to any person or organization
+obtaining a copy of the software and accompanying documentation covered by
+this license (the "Software") to use, reproduce, display, distribute,
+execute, and transmit the Software, and to prepare derivative works of the
+Software, and to permit third-parties to whom the Software is furnished to
+do so, all subject to the following:
+
+The copyright notices in the Software and this entire statement, including
+the above license grant, this restriction and the following disclaimer,
+must be included in all copies of the Software, in whole or in part, and
+all derivative works of the Software, unless such copies or derivative
+works are solely in the form of machine-executable object code generated by
+a source language processor.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
+SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
+FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
+ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+DEALINGS IN THE SOFTWARE.
+*/
+
+#include <boost/outcome.hpp>
+#include <boost/test/unit_test.hpp>
+#include <boost/test/unit_test_monitor.hpp>
+
+#if __cplusplus >= 201700 || _HAS_CXX17
+// Match LiteralType, even on C++ 17 and later
+template <class T> struct is_literal_type
+{
+ static constexpr bool value = //
+ std::is_void<T>::value //
+ || std::is_scalar<T>::value //
+ || std::is_reference<T>::value //
+ // leave out is_array for simplicity
+ || (std::is_class<T>::value && std::is_trivially_destructible<T>::value
+ // how does one detect if a type has at least one constexpr constructor without Reflection???
+ ) // leave out union for simplicity
+ ;
+};
+#else
+template <class T> using is_literal_type = std::is_literal_type<T>;
+#endif
+
+BOOST_OUTCOME_AUTO_TEST_CASE(works_outcome_constexpr, "Tests that outcome works as intended in a constexpr evaluation context")
+{
+ using namespace BOOST_OUTCOME_V2_NAMESPACE;
+
+ static_assert(is_literal_type<result<int, void, void>>::value, "result<int, void, void> is not a literal type!");
+ static_assert(is_literal_type<outcome<int, void, void>>::value, "outcome<int, void, void> is not a literal type!");
+
+ // Unfortunately result<T> can never be a literal type as error_code can never be literal
+ //
+ // It can however be trivially destructible as error_code is trivially destructible. That
+ // makes possible lots of compiler optimisations
+ static_assert(std::is_trivially_destructible<result<int>>::value, "result<int> is not trivially destructible!");
+ static_assert(std::is_trivially_destructible<result<void>>::value, "result<void> is not trivially destructible!");
+
+ // outcome<T> default has no trivial operations, but if configured it can become so
+ static_assert(std::is_trivially_destructible<outcome<int, boost::system::error_code, void>>::value,
+ "outcome<int, boost::system::error_code, void> is not trivially destructible!");
+
+ {
+ // Test compatible results can be constructed from one another
+ constexpr result<int, long> g(in_place_type<int>, 5);
+ constexpr result<long, int> g2(g);
+ static_assert(g.has_value(), "");
+ static_assert(!g.has_error(), "");
+ static_assert(g.assume_value() == 5, ""); // value() with UDT E won't compile
+ static_assert(g2.has_value(), "");
+ static_assert(!g2.has_error(), "");
+ static_assert(g2.assume_value() == 5, ""); // value() with UDT E won't compile
+ constexpr result<void, int> g3(in_place_type<void>);
+ constexpr result<long, int> g4(g3);
+ constexpr result<int, void> g5(in_place_type<void>);
+ constexpr result<long, int> g6(g5);
+ (void) g4;
+ (void) g6;
+
+ // Test void
+ constexpr result<void, int> h(in_place_type<void>);
+ static_assert(h.has_value(), "");
+ constexpr result<int, void> h2(in_place_type<void>);
+ static_assert(!h2.has_value(), "");
+ static_assert(h2.has_error(), "");
+
+ // Test const
+ constexpr result<const int, void> i(5);
+ constexpr result<const int, void> i2(i);
+ (void) i2;
+ }
+ {
+ // Test compatible outcomes can be constructed from one another
+ constexpr outcome<int, long, char *> g(in_place_type<int>, 5);
+ constexpr outcome<long, int, const char *> g2(g);
+ static_assert(g.has_value(), "");
+ static_assert(!g.has_error(), "");
+ static_assert(!g.has_exception(), "");
+ static_assert(g.assume_value() == 5, ""); // value() with UDT E won't compile
+ static_assert(g2.has_value(), "");
+ static_assert(!g2.has_error(), "");
+ static_assert(!g2.has_exception(), "");
+ static_assert(g2.assume_value() == 5, ""); // value() with UDT E won't compile
+ constexpr outcome<void, int, char *> g3(in_place_type<void>);
+ constexpr outcome<long, int, const char *> g4(g3);
+ constexpr outcome<int, void, char *> g5(in_place_type<void>);
+ constexpr outcome<long, int, const char *> g6(g5);
+ (void) g4;
+ (void) g6;
+ }
+}