From b73f692919f697877c4622f6f39270110d666db9 Mon Sep 17 00:00:00 2001 From: Hans Goudey Date: Mon, 30 Aug 2021 17:49:38 -0500 Subject: Add a slightly more complicated test --- source/blender/functions/tests/FN_field_test.cc | 34 +++++++++++++++++++++++++ 1 file changed, 34 insertions(+) (limited to 'source/blender/functions') diff --git a/source/blender/functions/tests/FN_field_test.cc b/source/blender/functions/tests/FN_field_test.cc index ba4bfde4eaa..8882f1a5eb6 100644 --- a/source/blender/functions/tests/FN_field_test.cc +++ b/source/blender/functions/tests/FN_field_test.cc @@ -186,4 +186,38 @@ TEST(field, FunctionTwoOutputs) EXPECT_EQ(result_2[8], 26); } +TEST(field, TwoFunctionsTwoOutputs) +{ + /* Also use two separate input fields, why not. */ + Field index_field{CPPType::get(), std::make_shared()}; + + std::shared_ptr fn = std::make_shared(FieldFunction( + std::make_unique("SI_SI_SO_SO"), {index_field, index_field})); + + Field result_field_1{CPPType::get(), fn, 0}; + Field intermediate_field{CPPType::get(), fn, 1}; + + std::unique_ptr add_10_fn = std::make_unique>( + "add_10", [](int a) { return a + 10; }); + Field result_field_2{ + CPPType::get(), + std::make_shared(FieldFunction(std::move(add_10_fn), {intermediate_field})), + 0}; + + Array result_1(10); + Array result_2(10); + GMutableSpan result_generic_1(result_1.as_mutable_span()); + GMutableSpan result_generic_2(result_2.as_mutable_span()); + evaluate_fields( + {result_field_1, result_field_2}, {2, 4, 6, 8}, {result_generic_1, result_generic_2}); + EXPECT_EQ(result_1[2], 4); + EXPECT_EQ(result_1[4], 8); + EXPECT_EQ(result_1[6], 12); + EXPECT_EQ(result_1[8], 16); + EXPECT_EQ(result_2[2], 24); + EXPECT_EQ(result_2[4], 28); + EXPECT_EQ(result_2[6], 32); + EXPECT_EQ(result_2[8], 36); +} + } // namespace blender::fn::tests -- cgit v1.2.3