#include "../test.h" #include "rxcpp/operators/rx-timestamp.hpp" using namespace std::chrono; SCENARIO("should not emit timestamped items if the source never emits any items", "[timestamp][operators]"){ GIVEN("a source"){ typedef rxsc::detail::test_type::clock_type::time_point time_point; auto sc = rxsc::make_test(); auto w = sc.create_worker(); const rxsc::test::messages on; auto xs = sc.make_hot_observable({ on.next(150, 1) }); WHEN("timestamp operator is invoked"){ auto res = w.start( [xs]() { return xs | rxo::timestamp(); } ); THEN("the output is empty"){ auto required = std::vector>::recorded_type>(); auto actual = res.get_observer().messages(); REQUIRE(required == actual); } THEN("there was 1 subscription/unsubscription to the source"){ auto required = rxu::to_vector({ on.subscribe(200, 1000) }); auto actual = xs.subscriptions(); REQUIRE(required == actual); } } } } SCENARIO("should not emit timestamped items if the source observable is empty", "[timestamp][operators]"){ GIVEN("a source"){ typedef rxsc::detail::test_type::clock_type::time_point time_point; auto sc = rxsc::make_test(); auto so = rx::synchronize_in_one_worker(sc); auto w = sc.create_worker(); const rxsc::test::messages on; const rxsc::test::messages> on_timestamp; auto xs = sc.make_hot_observable({ on.next(150, 1), on.completed(250) }); WHEN("timestamp operator is invoked"){ auto res = w.start( [so, xs]() { return xs.timestamp(); } ); THEN("the output only contains complete message"){ auto required = rxu::to_vector({ on_timestamp.completed(250) }); auto actual = res.get_observer().messages(); REQUIRE(required == actual); } THEN("there was 1 subscription/unsubscription to the source"){ auto required = rxu::to_vector({ on.subscribe(200, 250) }); auto actual = xs.subscriptions(); REQUIRE(required == actual); } } } } SCENARIO("should emit timestamped items for every item in the source observable", "[timestamp][operators]"){ GIVEN("a source"){ typedef rxsc::detail::test_type::clock_type clock_type; typedef clock_type::time_point time_point; auto sc = rxsc::make_test(); auto so = rx::synchronize_in_one_worker(sc); auto w = sc.create_worker(); const rxsc::test::messages on; const rxsc::test::messages> on_timestamp; auto xs = sc.make_hot_observable({ on.next(150, 1), on.next(210, 2), on.next(240, 3), on.completed(250) }); WHEN("timestamp operator is invoked"){ auto res = w.start( [so, xs]() { return xs.timestamp(so); } ); THEN("the output contains the emitted items while subscribed"){ auto required = rxu::to_vector({ on_timestamp.next(210, std::make_pair(2, clock_type::time_point(milliseconds(210)))), on_timestamp.next(240, std::make_pair(3, clock_type::time_point(milliseconds(240)))), on_timestamp.completed(250) }); auto actual = res.get_observer().messages(); REQUIRE(required == actual); } THEN("there was 1 subscription/unsubscription to the source"){ auto required = rxu::to_vector({ on.subscribe(200, 250) }); auto actual = xs.subscriptions(); REQUIRE(required == actual); } } } } SCENARIO("should emit timestamped items and an error if there is an error", "[timestamp][operators]"){ GIVEN("a source"){ typedef rxsc::detail::test_type::clock_type clock_type; typedef clock_type::time_point time_point; auto sc = rxsc::make_test(); auto so = rx::synchronize_in_one_worker(sc); auto w = sc.create_worker(); const rxsc::test::messages on; const rxsc::test::messages> on_timestamp; std::runtime_error ex("on_error from source"); auto xs = sc.make_hot_observable({ on.next(150, 1), on.next(210, 2), on.next(240, 3), on.error(250, ex) }); WHEN("timestamp operator is invoked"){ auto res = w.start( [so, xs]() { return xs.timestamp(so); } ); THEN("the output contains emitted items and an error"){ auto required = rxu::to_vector({ on_timestamp.next(210, std::make_pair(2, clock_type::time_point(milliseconds(210)))), on_timestamp.next(240, std::make_pair(3, clock_type::time_point(milliseconds(240)))), on_timestamp.error(250, ex) }); auto actual = res.get_observer().messages(); REQUIRE(required == actual); } THEN("there was 1 subscription/unsubscription to the source"){ auto required = rxu::to_vector({ on.subscribe(200, 250) }); auto actual = xs.subscriptions(); REQUIRE(required == actual); } } } }