25using namespace Kokkos::utils::callbacks;
38 using variant_t =
typename recorder_listener_t::event_variant_t;
48 using then_sndr_t = stdexec::transform_sender_result_t<
49 decltype(stdexec::then(std::declval<schd_sndr_t>(), std::declval<functor_t>())),
55 static_assert(std::same_as<Kokkos::Execution::ExecutionSpaceImpl::exec_of_t<then_sndr_t>, TEST_EXECUTION_SPACE>);
61 using policy_t =
typename then_sndr_t::closure_t::policy_t;
62 static_assert(std::same_as<typename policy_t::launch_bounds, Kokkos::LaunchBounds<1>>);
73 const view_s_t data(Kokkos::view_alloc(
exec,
"data - shared space"));
79 using chain_t =
decltype(chain);
82 static_assert(std::same_as<stdexec::__domain_of_t<stdexec::env_of_t<chain_t>>, stdexec::default_domain>);
83 static_assert(std::same_as<
84 stdexec::__detail::__completing_domain_t<stdexec::set_value_t, chain_t>,
89 static_assert(std::same_as<
90 decltype(stdexec::get_completion_scheduler<stdexec::set_value_t>(stdexec::get_env(chain))),
95 recorder_listener_t::record([chain = std::move(chain)]()
mutable { stdexec::sync_wait(std::move(chain)); }),
101 ASSERT_EQ(data(), 2);
109 const view_s_t data(Kokkos::view_alloc(
exec,
"data - shared space"));
119 using chain_t =
decltype(chain);
124 stdexec::__mset<stdexec::set_value_t(), stdexec::set_error_t(std::exception_ptr)>
128 std::same_as<stdexec::__completion_domain_of_t<stdexec::set_value_t, chain_t>, stdexec::indeterminate_domain<>>);
131 auto starts_on = stdexec::starts_on(esc.
get_scheduler(), std::move(chain));
133 using starts_on_t =
decltype(starts_on);
137 static_assert(std::same_as<
138 decltype(stdexec::get_completion_scheduler<stdexec::set_value_t>(stdexec::get_env(starts_on))),
142 static_assert(std::same_as<
143 std::invoke_result_t<stdexec::get_completion_signatures_t, starts_on_t, stdexec::env<>>,
144 stdexec::completion_signatures<stdexec::set_value_t(), stdexec::set_error_t(std::exception_ptr)>
147 ASSERT_EQ(data(), 0) <<
"Eager execution is not allowed.";
150 recorder_listener_t::record(
151 [starts_on = std::move(starts_on)]()
mutable { stdexec::sync_wait(std::move(starts_on)); }),
152 testing::ElementsAre(
157 ASSERT_EQ(data(), 2);
168 const view_s_t data(Kokkos::view_alloc(
exec,
"data - shared space"));
174 | stdexec::then(KOKKOS_LAMBDA() {
175 Kokkos::abort(
"The value channel should be used at this point.");
178 ASSERT_EQ(data(), 0) <<
"Eager execution is not allowed.";
181 recorder_listener_t::record([sndr = std::move(sndr)]()
mutable {
184 testing::ThrowsMessage<std::runtime_error>(
185 testing::HasSubstr(
"ThrowsWhenCopied: Throwing in copy constructor!")));
187 testing::ElementsAre(
192 ASSERT_EQ(data(), 1);
205 auto create_chain_in_scope = [&]() {
206 const view_s_t data(Kokkos::view_alloc(
"data - shared space",
exec));
212 auto run_test = [&]() {
213 auto chain = create_chain_in_scope();
215 using chain_t =
decltype(chain);
218 static_assert(std::same_as<stdexec::__domain_of_t<stdexec::env_of_t<chain_t>>, stdexec::default_domain>);
219 static_assert(std::same_as<
220 stdexec::__detail::__completing_domain_t<stdexec::set_value_t, chain_t>,
225 static_assert(std::same_as<
226 decltype(stdexec::get_completion_scheduler<stdexec::set_value_t>(stdexec::get_env(chain))),
230 stdexec::sync_wait(std::move(chain));
234 recorder_listener_t::record(run_test),
256 static_assert(std::same_as<
257 stdexec::__demangle_t<sndr_then_t>,
265 static_assert(stdexec::__detail::__has_nothrow_transform_sender<
267 stdexec::set_value_t,
272 using sndr_then_maythrow_on_move_t =
275 static_assert(!stdexec::__detail::__has_nothrow_transform_sender<
277 stdexec::set_value_t,
278 sndr_then_maythrow_on_move_t&&,
constexpr std::string dispatch_label(const Exec &, Label &&label)
Get the dispatch label from Exec and label.
#define MATCHER_FOR_BEGIN_PFOR(_exec_, _label_)
#define MATCHER_FOR_BEGIN_FENCE(_exec_, _label_)
typename recorder_listener_t::event_variant_t variant_t
RecorderListener< EventDiscardMatcher< TEST_EXECUTION_SPACE >, BeginFenceEvent, BeginParallelForEvent, AllocateDataEvent, DeallocateDataEvent > recorder_listener_t
Concept for a sender whose completion scheduler is Kokkos::Execution::ExecutionSpaceImpl::Scheduler.
Concept that constrains the type of a sender that dispatches a functor for execution.
#define THEN_INCREMENT(_data_)
Add a then using Tests::Utils::Functors::Increment that may throw. // NOLINTNEXTLINE(cppcoreguideline...
auto AAllocateDataEvent(Matchers &&... matchers)
auto ADeallocateDataEvent(Matchers &&... matchers)
auto ContainsInOrder(Matchers &&... matchers)
consteval bool test_sndr_no_throw_transformable()
consteval bool test_sndr_traits()
typename stdexec::__basic_sender< Args... >::type basic_sender_t
See https://github.com/NVIDIA/stdexec/pull/1873#discussion_r2834863237.
Matcher to filter out events that are just noise for tests.
auto get_scheduler() const noexcept -> ExecutionSpaceImpl::Scheduler< Exec >
decltype(std::declval< const context_t >().get_scheduler()) scheduler_t
decltype(stdexec::schedule(std::declval< scheduler_t >())) schedule_sender_t
Kokkos::View< value_t, Kokkos::SharedSpace > view_s_t
Kokkos::Execution::ExecutionSpaceContext< Exec > context_t
This helper struct throws when copy constructed.