/* * Copyright (c) Facebook, Inc. and its affiliates. * * Licensed under the Apache License Version 2.0 with LLVM Exceptions * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * https://llvm.org/LICENSE.txt * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace unifex; using namespace std::chrono; TEST(Delay, Smoke) { timed_single_thread_context context; auto startTime = steady_clock::now(); sync_wait( stop_when( for_each( delay(range_stream{0, 100}, context.get_scheduler(), 100ms), [startTime](int value) { auto ms = duration_cast(steady_clock::now() - startTime); std::printf("[%i ms] %i\n", (int)ms.count(), value); }), then( schedule_at(context.get_scheduler(), startTime + 500ms), [] { std::printf("cancelling\n"); }))); } TEST(Delay, Pipeable) { timed_single_thread_context context; auto startTime = steady_clock::now(); range_stream{0, 100} | delay(context.get_scheduler(), 100ms) | for_each( [startTime](int value) { auto ms = duration_cast(steady_clock::now() - startTime); std::printf("[%i ms] %i\n", (int)ms.count(), value); }) | stop_when( schedule_at(context.get_scheduler(), startTime + 500ms) | then([] { std::printf("cancelling\n"); })) | sync_wait(); }