dtss_tests.cpp 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. /**
  2. * @file examples.cpp
  3. * @author The PARADEVS Development Team
  4. * See the AUTHORS or Authors.txt file
  5. */
  6. /*
  7. * PARADEVS - the multimodeling and simulation environment
  8. * This file is a part of the PARADEVS environment
  9. *
  10. * Copyright (C) 2013 ULCO http://www.univ-litoral.fr
  11. *
  12. * This program is free software: you can redistribute it and/or modify
  13. * it under the terms of the GNU General Public License as published by
  14. * the Free Software Foundation, either version 3 of the License, or
  15. * (at your option) any later version.
  16. *
  17. * This program is distributed in the hope that it will be useful,
  18. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  19. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  20. * GNU General Public License for more details.
  21. *
  22. * You should have received a copy of the GNU General Public License
  23. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  24. */
  25. #include <tests/dtss_tests.hpp>
  26. #include <common/RootCoordinator.hpp>
  27. #include <common/Trace.hpp>
  28. #include <dtss/Coordinator.hpp>
  29. #include <dtss/GraphManager.hpp>
  30. #include <dtss/Simulator.hpp>
  31. #define CATCH_CONFIG_MAIN
  32. #include "catch.hpp"
  33. namespace paradevs { namespace dtss {
  34. void A::transition(const common::Bag < MyTime >& /* x */, MyTime::type t)
  35. {
  36. common::Trace < MyTime >::trace()
  37. << common::TraceElement < MyTime >(get_name(), t,
  38. common::DELTA_INT);
  39. common::Trace < MyTime >::trace().flush();
  40. }
  41. MyTime::type A::start(MyTime::type t)
  42. {
  43. common::Trace < MyTime >::trace()
  44. << common::TraceElement < MyTime >(get_name(), t,
  45. common::START);
  46. common::Trace < MyTime >::trace().flush();
  47. return 0;
  48. }
  49. common::Bag < MyTime > A::lambda(MyTime::type t) const
  50. {
  51. common::Bag < MyTime > msgs;
  52. msgs.push_back(common::ExternalEvent < MyTime >("out", 0.));
  53. common::Trace < MyTime >::trace()
  54. << common::TraceElement < MyTime >(get_name(), t,
  55. common::LAMBDA)
  56. << "messages = " << msgs.to_string();
  57. common::Trace < MyTime >::trace().flush();
  58. return msgs;
  59. }
  60. void B::transition(const common::Bag < MyTime >& x, MyTime::type t)
  61. {
  62. common::Trace < MyTime >::trace()
  63. << common::TraceElement < MyTime >(get_name(), t,
  64. common::DELTA_INT)
  65. << "x = " << x.to_string();
  66. common::Trace < MyTime >::trace().flush();
  67. }
  68. MyTime::type B::start(MyTime::type t)
  69. {
  70. common::Trace < MyTime >::trace()
  71. << common::TraceElement < MyTime >(get_name(), t,
  72. common::START);
  73. common::Trace < MyTime >::trace().flush();
  74. return 0;
  75. }
  76. common::Bag < MyTime > B::lambda(MyTime::type t) const
  77. {
  78. common::Bag < MyTime > msgs;
  79. msgs.push_back(common::ExternalEvent < MyTime >("out", 0.));
  80. common::Trace < MyTime >::trace()
  81. << common::TraceElement < MyTime >(get_name(), t,
  82. common::LAMBDA)
  83. << "messages = " << msgs.to_string();
  84. common::Trace < MyTime >::trace().flush();
  85. return msgs;
  86. }
  87. struct Policy
  88. {
  89. const common::Bag < MyTime >& bag() const
  90. { return _bag; }
  91. virtual void operator()(MyTime::type /* t */,
  92. const common::ExternalEvent < MyTime >& event,
  93. MyTime::type /* tl */,
  94. MyTime::type /* tn */)
  95. {
  96. _bag.clear();
  97. _bag.push_back(event);
  98. }
  99. private:
  100. common::Bag < MyTime > _bag;
  101. };
  102. class OnlyOneGraphManager : public dtss::GraphManager < MyTime >
  103. {
  104. public:
  105. OnlyOneGraphManager(common::Coordinator < MyTime >* coordinator) :
  106. dtss::GraphManager < MyTime >(coordinator), a("a", 1)
  107. {
  108. add_child(&a);
  109. }
  110. virtual ~OnlyOneGraphManager()
  111. { }
  112. private:
  113. dtss::Simulator < MyTime, A > a;
  114. };
  115. class TwoGraphManager : public dtss::GraphManager < MyTime >
  116. {
  117. public:
  118. TwoGraphManager(common::Coordinator < MyTime >* coordinator) :
  119. dtss::GraphManager < MyTime >(coordinator), a("a", 1), b("b", 1)
  120. {
  121. add_child(&a);
  122. add_child(&b);
  123. add_link(&a, "out", &b, "in");
  124. }
  125. virtual ~TwoGraphManager()
  126. { }
  127. private:
  128. dtss::Simulator < MyTime, A > a;
  129. dtss::Simulator < MyTime, B > b;
  130. };
  131. } } // namespace paradevs dtss
  132. TEST_CASE("dtss/only_one", "run")
  133. {
  134. paradevs::common::RootCoordinator <
  135. paradevs::dtss::MyTime, paradevs::dtss::Coordinator <
  136. paradevs::dtss::MyTime, paradevs::dtss::Policy,
  137. paradevs::dtss::OnlyOneGraphManager >
  138. > rc(0, 10, "root",
  139. paradevs::dtss::Parameters < paradevs::dtss::MyTime >(1));
  140. paradevs::common::Trace < paradevs::dtss::MyTime >::trace().clear();
  141. rc.run();
  142. REQUIRE(paradevs::common::Trace <
  143. paradevs::dtss::MyTime >::trace().elements().
  144. filter_model_name("a").
  145. filter_type(paradevs::common::START).size() == 1);
  146. for (double t = 0; t <= 10; ++t) {
  147. REQUIRE(paradevs::common::Trace <
  148. paradevs::dtss::MyTime >::trace().elements().
  149. filter_model_name("a").filter_time(t).
  150. filter_type(paradevs::common::DELTA_INT).size() == 1);
  151. REQUIRE(paradevs::common::Trace <
  152. paradevs::dtss::MyTime >::trace().elements().
  153. filter_model_name("a").filter_time(t).
  154. filter_type(paradevs::common::LAMBDA).size() == 1);
  155. }
  156. }
  157. TEST_CASE("dtss/two", "run")
  158. {
  159. paradevs::common::RootCoordinator <
  160. paradevs::dtss::MyTime, paradevs::dtss::Coordinator <
  161. paradevs::dtss::MyTime, paradevs::dtss::Policy,
  162. paradevs::dtss::TwoGraphManager >
  163. > rc(0, 10, "root",
  164. paradevs::dtss::Parameters < paradevs::dtss::MyTime >(1));
  165. paradevs::common::Trace < paradevs::dtss::MyTime >::trace().clear();
  166. rc.run();
  167. REQUIRE(paradevs::common::Trace <
  168. paradevs::dtss::MyTime >::trace().elements().
  169. filter_model_name("a").
  170. filter_type(paradevs::common::START).size() == 1);
  171. for (unsigned int t = 0; t <= 10; ++t) {
  172. REQUIRE(paradevs::common::Trace <
  173. paradevs::dtss::MyTime >::trace().elements().
  174. filter_model_name("a").filter_time(t).
  175. filter_type(paradevs::common::DELTA_INT).size() == 1);
  176. REQUIRE(paradevs::common::Trace <
  177. paradevs::dtss::MyTime >::trace().elements().
  178. filter_model_name("a").filter_time(t).
  179. filter_type(paradevs::common::LAMBDA).size() == 1);
  180. }
  181. REQUIRE(paradevs::common::Trace <
  182. paradevs::dtss::MyTime >::trace().elements().
  183. filter_model_name("b").
  184. filter_type(paradevs::common::START).size() == 1);
  185. for (unsigned int t = 0; t <= 10; ++t) {
  186. REQUIRE(paradevs::common::Trace <
  187. paradevs::dtss::MyTime >::trace().elements().
  188. filter_model_name("b").filter_time(t).
  189. filter_type(paradevs::common::DELTA_INT).size() == 1);
  190. REQUIRE(paradevs::common::Trace <
  191. paradevs::dtss::MyTime >::trace().elements().
  192. filter_model_name("b").filter_time(t).
  193. filter_type(paradevs::common::LAMBDA).size() == 1);
  194. }
  195. }