From 9c81cffc32a5e88ac9f81fe3d08c2a670efa79d2 Mon Sep 17 00:00:00 2001 From: Felix Morgner Date: Thu, 2 Jan 2020 12:48:57 +0100 Subject: new_type: implement multiplication --- test/src/arithmetic_suite.cpp | 49 ++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 48 insertions(+), 1 deletion(-) (limited to 'test') diff --git a/test/src/arithmetic_suite.cpp b/test/src/arithmetic_suite.cpp index b7713e0..e77c1dd 100644 --- a/test/src/arithmetic_suite.cpp +++ b/test/src/arithmetic_suite.cpp @@ -111,7 +111,7 @@ inline namespace subtraction_tests auto subtraction_of_two_instances_of_a_new__type_deriving_arithmetic_produces_an_instance_of_the_same_new__type() -> void { using type_alias = nt::new_type; - ASSERT((std::is_same_v() + std::declval())>)); + ASSERT((std::is_same_v() - std::declval())>)); } auto subtraction_of_two_instances_of_a_new__type_deriving_arithmetic_produces_the_correct_value_with_respect_to_the_base_type() -> void @@ -124,6 +124,45 @@ inline namespace subtraction_tests } // namespace subtraction_tests +inline namespace multiplication_tests +{ + + auto a_new__type_not_deriving_arithmetic_is_not_multipliable_with_instances_of_itself() -> void + { + using type_alias = nt::new_type; + ASSERT(!(nt::impl::is_multipliable_v)); + } + + auto a_new__type_deriving_arithmetic_is_multipliable_with_instances_of_itself() -> void + { + using type_alias = nt::new_type; + ASSERT(nt::impl::is_multipliable_v); + } + + template + auto a_new__type_deriving_arithmetic_is_multipliable_with_instances_of_itself_if_the_base_type_is_multipliable() -> void + { + static_assert(nt::impl::is_multipliable_v, "Sanity Check"); + using type_alias = nt::new_type; + ASSERT_EQUAL(nt::impl::is_multipliable_v, nt::impl::is_multipliable_v); + } + + auto multiplication_of_two_instances_of_a_new__type_deriving_arithmetic_produces_an_instance_of_the_same_new__type() -> void + { + using type_alias = nt::new_type; + ASSERT((std::is_same_v() * std::declval())>)); + } + + auto multiplication_of_two_instances_of_a_new__type_deriving_arithmetic_produces_the_correct_value_with_respect_to_the_base_type() -> void + { + using type_alias = nt::new_type; + auto lhs = type_alias{24}; + auto rhs = type_alias{18}; + ASSERT_EQUAL(24 * 18, (lhs * rhs).decay()); + } + +} // namespace multiplication_tests + auto arithmetic_suite() -> std::pair { return { @@ -143,6 +182,14 @@ auto arithmetic_suite() -> std::pair KAWAII(a_new__type_deriving_arithmetic_is_subtractable_with_instances_of_itself_if_the_base_type_is_subtractable), KAWAII(subtraction_of_two_instances_of_a_new__type_deriving_arithmetic_produces_an_instance_of_the_same_new__type), KAWAII(subtraction_of_two_instances_of_a_new__type_deriving_arithmetic_produces_the_correct_value_with_respect_to_the_base_type), + + /// Multiplication Tests + KAWAII(a_new__type_not_deriving_arithmetic_is_not_multipliable_with_instances_of_itself), + KAWAII(a_new__type_deriving_arithmetic_is_multipliable_with_instances_of_itself), + KAWAII(a_new__type_deriving_arithmetic_is_multipliable_with_instances_of_itself_if_the_base_type_is_multipliable), + KAWAII(a_new__type_deriving_arithmetic_is_multipliable_with_instances_of_itself_if_the_base_type_is_multipliable), + KAWAII(multiplication_of_two_instances_of_a_new__type_deriving_arithmetic_produces_an_instance_of_the_same_new__type), + KAWAII(multiplication_of_two_instances_of_a_new__type_deriving_arithmetic_produces_the_correct_value_with_respect_to_the_base_type), }, "Arithmetic Operators Tests"}; } \ No newline at end of file -- cgit v1.2.3