X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/016d020461cd4d21ea5a617d8f9099d47d7c880c..e4e4b7da7f6a6d04b659f0aa9c1de8733939096f:/src/plugins/chaos_monkey.cpp diff --git a/src/plugins/chaos_monkey.cpp b/src/plugins/chaos_monkey.cpp index 32c9ba7edd..45f4df6eac 100644 --- a/src/plugins/chaos_monkey.cpp +++ b/src/plugins/chaos_monkey.cpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2022-2022. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2022-2023. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -10,7 +10,7 @@ #include #include -#include "src/surf/surf_interface.hpp" // SIMGRID_REGISTER_PLUGIN +#include "src/simgrid/module.hpp" // SIMGRID_REGISTER_PLUGIN namespace sg4 = simgrid::s4u; static simgrid::config::Flag cfg_tell{"cmonkey/tell", "Request the Chaos Monkey to display all timestamps", @@ -18,60 +18,60 @@ static simgrid::config::Flag cfg_tell{"cmonkey/tell", "Request the Chaos M static simgrid::config::Flag cfg_time{"cmonkey/time", "When should the chaos monkey kill a resource", -1.}; static simgrid::config::Flag cfg_link{"cmonkey/link", "Which link should be killed (number)", -1}; static simgrid::config::Flag cfg_host{"cmonkey/host", "Which host should be killed (number)", -1}; -static void sg_chaos_monkey_plugin_init(); -// Makes sure that this plugin can be activated from the command line with ``--cfg=plugin:chaos_monkey`` -SIMGRID_REGISTER_PLUGIN(cmonkey, "Chaos monkey", &sg_chaos_monkey_plugin_init) XBT_LOG_NEW_DEFAULT_SUBCATEGORY(cmonkey, kernel, "Chaos Monkey plugin"); -static void sg_chaos_monkey_plugin_init() +static void sg_chaos_monkey_plugin_run() { - XBT_INFO("Initializing the chaos monkey"); + auto engine = sg4::Engine::get_instance(); + auto hosts = engine->get_all_hosts(); + auto links = engine->get_all_links(); - // delay the initialization until after the parameter are parsed - sg4::Engine::on_platform_created_cb([]() { - auto engine = sg4::Engine::get_instance(); - auto hosts = engine->get_all_hosts(); - auto links = engine->get_all_links(); + sg4::Engine::on_deadlock_cb([]() { exit(2); }); - sg4::Engine::on_deadlock_cb([]() { exit(2); }); + if (cfg_tell) { + XBT_INFO("HOST_COUNT=%zu", hosts.size()); + XBT_INFO("LINK_COUNT=%zu", links.size()); + sg4::Engine::on_time_advance_cb([engine](double /* delta*/) { XBT_INFO("TIMESTAMP=%lf", engine->get_clock()); }); + } - if (cfg_tell) { - XBT_INFO("HOST_COUNT=%zu", hosts.size()); - XBT_INFO("LINK_COUNT=%zu", links.size()); - sg4::Engine::on_time_advance_cb([engine](double /* delta*/) { XBT_INFO("TIMESTAMP=%lf", engine->get_clock()); }); + if (cfg_time >= 0) { + int host = cfg_host; + int link = cfg_link; + xbt_assert(host >= 0 || link >= 0, + "If a kill time is given, you must also specify a resource to kill (either a link or an host)"); + xbt_assert(host < 0 || link < 0, "Cannot specify both a link and an host to kill"); + if (host >= 0) { + auto* h = hosts[host]; + simgrid::kernel::timer::Timer::set(cfg_time, [h]() { + XBT_INFO("Kill host %s", h->get_cname()); + h->turn_off(); + }); + simgrid::kernel::timer::Timer::set(cfg_time + 30, [h]() { + XBT_INFO("Restart host %s", h->get_cname()); + h->turn_on(); + }); } - - if (cfg_time >= 0) { - int host = cfg_host; - int link = cfg_link; - xbt_assert(host >= 0 || link >= 0, - "If a kill time is given, you must also specify a resource to kill (either a link or an host)"); - xbt_assert(host < 0 || link < 0, "Cannot specify both a link and an host to kill"); - if (host >= 0) { - auto* h = hosts[host]; - simgrid::kernel::timer::Timer::set(cfg_time, [h]() { - XBT_INFO("Kill host %s", h->get_cname()); - h->turn_off(); - }); - simgrid::kernel::timer::Timer::set(cfg_time + 30, [h]() { - XBT_INFO("Restart host %s", h->get_cname()); - h->turn_on(); - }); - } - if (link >= 0) { - auto* l = links[link]; - simgrid::kernel::timer::Timer::set(cfg_time, [l]() { - XBT_INFO("Kill link %s", l->get_cname()); - l->turn_off(); - }); - simgrid::kernel::timer::Timer::set(cfg_time + 30, [l]() { - XBT_INFO("Restart host %s", l->get_cname()); - l->turn_on(); - }); - } + if (link >= 0) { + auto* l = links[link]; + simgrid::kernel::timer::Timer::set(cfg_time, [l]() { + XBT_INFO("Kill link %s", l->get_cname()); + l->turn_off(); + }); + simgrid::kernel::timer::Timer::set(cfg_time + 30, [l]() { + XBT_INFO("Restart host %s", l->get_cname()); + l->turn_on(); + }); } + } - sg4::Engine::on_simulation_end_cb([]() { XBT_INFO("Chaos Monkey done!"); }); - }); + sg4::Engine::on_simulation_end_cb([]() { XBT_INFO("Chaos Monkey done!"); }); } + +// Makes sure that this plugin can be activated from the command line with ``--cfg=plugin:chaos_monkey`` +SIMGRID_REGISTER_PLUGIN(cmonkey, "Chaos monkey", []() { + XBT_INFO("Initializing the chaos monkey"); + + // delay the initialization until after the parameter are parsed + sg4::Engine::on_simulation_start_cb(sg_chaos_monkey_plugin_run); +})