test_supervisor.h 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. // SPDX-License-Identifier: GPL-3.0-or-later
  2. // SPDX-FileCopyrightText: 2019-2024 Ivan Baidakou
  3. #pragma once
  4. #include "rotor/supervisor.h"
  5. #include "model/messages.h"
  6. #include "model/diff/apply_controller.h"
  7. #include "model/diff/cluster_visitor.h"
  8. #include "model/diff/local/io_failure.h"
  9. #include "model/misc/sequencer.h"
  10. #include "utils/log.h"
  11. #include "syncspirit-test-export.h"
  12. namespace syncspirit::test {
  13. namespace r = rotor;
  14. namespace outcome = boost::outcome_v2;
  15. struct supervisor_config_t : r::supervisor_config_t {
  16. using parent_t = r::supervisor_config_t;
  17. using parent_t::parent_t;
  18. bool auto_finish = true;
  19. bool auto_ack_blocks = true;
  20. };
  21. template <typename Supervisor> struct supervisor_config_builder_t : r::supervisor_config_builder_t<Supervisor> {
  22. /** \brief final builder class */
  23. using builder_t = typename Supervisor::template config_builder_t<Supervisor>;
  24. /** \brief parent config builder */
  25. using parent_t = r::supervisor_config_builder_t<Supervisor>;
  26. using parent_t::parent_t;
  27. /** \brief defines actor's startup policy */
  28. builder_t &&auto_finish(bool value) && noexcept {
  29. parent_t::config.auto_finish = value;
  30. return std::move(*static_cast<typename parent_t::builder_t *>(this));
  31. }
  32. /** \brief defines actor's startup policy */
  33. builder_t &&auto_ack_blocks(bool value) && noexcept {
  34. parent_t::config.auto_ack_blocks = value;
  35. return std::move(*static_cast<typename parent_t::builder_t *>(this));
  36. }
  37. };
  38. struct SYNCSPIRIT_TEST_API supervisor_t : r::supervisor_t,
  39. private model::diff::cluster_visitor_t,
  40. private model::diff::apply_controller_t {
  41. using config_t = supervisor_config_t;
  42. template <typename Actor> using config_builder_t = supervisor_config_builder_t<Actor>;
  43. using timers_t = std::list<r::timer_handler_base_t *>;
  44. using parent_t = r::supervisor_t;
  45. using io_errors_t = model::diff::local::io_errors_t;
  46. using configure_callback_t = std::function<void(r::plugin::plugin_base_t &)>;
  47. supervisor_t(config_t &cfg);
  48. void configure(r::plugin::plugin_base_t &plugin) noexcept override;
  49. void start() noexcept override;
  50. void shutdown() noexcept override;
  51. void enqueue(r::message_ptr_t message) noexcept override;
  52. void on_model_update(model::message::model_update_t &) noexcept;
  53. void on_model_sink(model::message::model_update_t &) noexcept;
  54. void do_start_timer(const r::pt::time_duration &interval, r::timer_handler_base_t &handler) noexcept override;
  55. void do_invoke_timer(r::request_id_t timer_id) noexcept;
  56. void do_cancel_timer(r::request_id_t timer_id) noexcept override;
  57. io_errors_t consume_errors() noexcept;
  58. outcome::result<void> operator()(const model::diff::local::io_failure_t &, void *) noexcept override;
  59. outcome::result<void> operator()(const model::diff::modify::finish_file_t &, void *) noexcept override;
  60. outcome::result<void> operator()(const model::diff::modify::append_block_t &, void *) noexcept override;
  61. outcome::result<void> operator()(const model::diff::modify::clone_block_t &, void *) noexcept override;
  62. utils::logger_t log;
  63. model::cluster_ptr_t cluster;
  64. model::sequencer_ptr_t sequencer;
  65. configure_callback_t configure_callback;
  66. model::diff::cluster_diff_ptr_t delayed_ack_holder;
  67. model::diff::cluster_diff_t *delayed_ack_current;
  68. timers_t timers;
  69. bool auto_finish;
  70. bool auto_ack_blocks;
  71. io_errors_t io_errors;
  72. r::address_ptr_t sink;
  73. };
  74. }; // namespace syncspirit::test