testMessageScheduler.py 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. # Copyright 2014 Modelling, Simulation and Design Lab (MSDL) at
  2. # McGill University and the University of Antwerp (http://msdl.cs.mcgill.ca/)
  3. #
  4. # Licensed under the Apache License, Version 2.0 (the "License");
  5. # you may not use this file except in compliance with the License.
  6. # You may obtain a copy of the License at
  7. #
  8. # http://www.apache.org/licenses/LICENSE-2.0
  9. #
  10. # Unless required by applicable law or agreed to in writing, software
  11. # distributed under the License is distributed on an "AS IS" BASIS,
  12. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. # See the License for the specific language governing permissions and
  14. # limitations under the License.
  15. from testutils import *
  16. from pypdevs.messageScheduler import MessageScheduler
  17. from copy import deepcopy
  18. class TestMessageScheduler(unittest.TestCase):
  19. def setUp(self):
  20. self.scheduler = MessageScheduler()
  21. def tearDown(self):
  22. pass
  23. def test_mscheduler_schedule(self):
  24. self.assertTrue(len(self.scheduler.heap) == 0)
  25. self.assertTrue(len(self.scheduler.processed) == 0)
  26. self.assertTrue(self.scheduler.invalids == set({}))
  27. # Only [0] and [3] are important, so don't even bother
  28. # creating the rest
  29. msg = NetworkMessage((1, 1), {}, 12345, False, 0)
  30. self.scheduler.schedule(msg)
  31. self.assertTrue(len(self.scheduler.heap) == 1)
  32. self.assertTrue(len(self.scheduler.processed) == 0)
  33. self.assertTrue(self.scheduler.invalids == set({}))
  34. msg = deepcopy(msg)
  35. msg.uuid = 444
  36. self.scheduler.schedule(msg)
  37. self.assertTrue(len(self.scheduler.heap) == 2)
  38. self.assertTrue(len(self.scheduler.processed) == 0)
  39. self.assertTrue(self.scheduler.invalids == set({}))
  40. msg = deepcopy(msg)
  41. msg.uuid = 456
  42. self.scheduler.schedule(msg)
  43. self.assertTrue(len(self.scheduler.heap) == 3)
  44. self.assertTrue(len(self.scheduler.processed) == 0)
  45. self.assertTrue(self.scheduler.invalids == set({}))
  46. def test_mschedule_invalids(self):
  47. self.assertTrue(len(self.scheduler.heap) == 0)
  48. self.assertTrue(len(self.scheduler.processed) == 0)
  49. self.assertTrue(self.scheduler.invalids == set({}))
  50. # Only [0] and [3] are important, so don't even bother
  51. # creating the rest
  52. msg = NetworkMessage((1, 1), {}, 12345, False, 0)
  53. self.scheduler.schedule(msg)
  54. self.assertTrue(len(self.scheduler.heap) == 1)
  55. self.assertTrue(len(self.scheduler.processed) == 0)
  56. self.assertTrue(self.scheduler.invalids == set({}))
  57. msg = deepcopy(msg)
  58. msg.uuid = 1111
  59. self.scheduler.invalids = set({1111})
  60. self.scheduler.schedule(msg)
  61. self.assertTrue(len(self.scheduler.heap) == 1)
  62. self.assertTrue(len(self.scheduler.processed) == 0)
  63. self.assertTrue(self.scheduler.invalids == set({}))
  64. msg = deepcopy(msg)
  65. msg.uuid = 1111
  66. self.scheduler.schedule(msg)
  67. self.assertTrue(len(self.scheduler.heap) == 2)
  68. self.assertTrue(len(self.scheduler.processed) == 0)
  69. self.assertTrue(self.scheduler.invalids == set({}))
  70. msg = deepcopy(msg)
  71. msg.uuid = 234
  72. self.scheduler.invalids.add(234)
  73. self.scheduler.schedule(msg)
  74. self.assertTrue(len(self.scheduler.heap) == 2)
  75. self.assertTrue(len(self.scheduler.processed) == 0)
  76. self.assertTrue(self.scheduler.invalids == set({}))
  77. def test_mscheduler_read_first(self):
  78. msg1 = NetworkMessage((3, 1), {}, 1, False, 0)
  79. msg2 = NetworkMessage((4, 1), {}, 2, False, 0)
  80. msg3 = NetworkMessage((5, 1), {}, 3, False, 0)
  81. self.scheduler.heap = [msg1, msg2, msg3]
  82. self.scheduler.processed = []
  83. self.assertTrue(self.scheduler.heap == [msg1, msg2, msg3])
  84. self.assertTrue(self.scheduler.processed == [])
  85. self.assertTrue(self.scheduler.invalids == set({}))
  86. first = self.scheduler.readFirst()
  87. self.assertTrue(first == msg1)
  88. self.assertTrue(self.scheduler.heap == [msg1, msg2, msg3])
  89. self.assertTrue(self.scheduler.processed == [])
  90. self.assertTrue(self.scheduler.invalids == set({}))
  91. first = self.scheduler.readFirst()
  92. self.assertTrue(first == msg1)
  93. self.assertTrue(self.scheduler.heap == [msg1, msg2, msg3])
  94. self.assertTrue(self.scheduler.processed == [])
  95. self.assertTrue(self.scheduler.invalids == set({}))
  96. self.scheduler.invalids = set({1})
  97. first = self.scheduler.readFirst()
  98. self.assertTrue(first == msg2)
  99. self.assertTrue(self.scheduler.heap == [msg2, msg3])
  100. self.assertTrue(self.scheduler.processed == [])
  101. self.assertTrue(self.scheduler.invalids == set({}))
  102. def test_mscheduler_removeFirst(self):
  103. msg1 = NetworkMessage((3, 1), {}, 1, False, 0)
  104. msg2 = NetworkMessage((4, 1), {}, 2, False, 0)
  105. msg3 = NetworkMessage((5, 1), {}, 3, False, 0)
  106. self.scheduler.heap = [msg1, msg2, msg3]
  107. self.scheduler.processed = []
  108. self.assertTrue(self.scheduler.heap == [msg1, msg2, msg3])
  109. self.assertTrue(self.scheduler.processed == [])
  110. self.assertTrue(self.scheduler.invalids == set({}))
  111. self.scheduler.removeFirst()
  112. self.assertTrue(self.scheduler.heap == [msg2, msg3])
  113. self.assertTrue(self.scheduler.processed == [msg1])
  114. self.assertTrue(self.scheduler.invalids == set({}))
  115. self.scheduler.invalids = set({2})
  116. self.scheduler.removeFirst()
  117. self.assertTrue(self.scheduler.heap == [])
  118. self.assertTrue(self.scheduler.processed == [msg1, msg3])
  119. self.assertTrue(self.scheduler.invalids == set({}))
  120. def test_mscheduler_revert(self):
  121. msg1 = NetworkMessage((3, 1), {}, 1, False, 0)
  122. msg2 = NetworkMessage((4, 1), {}, 2, False, 0)
  123. msg3 = NetworkMessage((5, 1), {}, 3, False, 0)
  124. self.scheduler.heap = [msg3]
  125. self.scheduler.processed = [msg1, msg2]
  126. self.scheduler.revert((4, 1))
  127. self.assertTrue(self.scheduler.heap == [msg2, msg3])
  128. self.assertTrue(self.scheduler.processed == [msg1])
  129. self.assertTrue(self.scheduler.invalids == set({}))
  130. self.scheduler.revert((2, 1))
  131. self.assertTrue(self.scheduler.heap == [msg1, msg3, msg2])
  132. self.assertTrue(self.scheduler.processed == [])
  133. self.assertTrue(self.scheduler.invalids == set({}))
  134. self.scheduler.heap = []
  135. self.scheduler.processed = [msg1, msg2, msg3]
  136. self.scheduler.revert((2, 1))
  137. self.assertTrue(self.scheduler.heap == [msg1, msg2, msg3])
  138. self.assertTrue(self.scheduler.processed == [])
  139. self.assertTrue(self.scheduler.invalids == set({}))
  140. def test_mscheduler_cleanup(self):
  141. msg1 = NetworkMessage((3, 1), {}, 1, False, 0)
  142. msg2 = NetworkMessage((4, 1), {}, 2, False, 0)
  143. msg3 = NetworkMessage((5, 1), {}, 3, False, 0)
  144. self.scheduler.heap = [msg3]
  145. self.scheduler.processed = [msg1, msg2]
  146. self.scheduler.cleanup((4, 1))
  147. self.assertTrue(self.scheduler.heap == [msg3])
  148. self.assertTrue(self.scheduler.processed == [msg2])
  149. self.assertTrue(self.scheduler.invalids == set({}))
  150. self.scheduler.cleanup((5, 1))
  151. self.assertTrue(self.scheduler.heap == [msg3])
  152. self.assertTrue(self.scheduler.processed == [])
  153. self.assertTrue(self.scheduler.invalids == set({}))
  154. self.scheduler.processed = [msg1, msg2]
  155. self.scheduler.invalids = set({2})
  156. self.scheduler.cleanup((4, 1))
  157. self.assertTrue(self.scheduler.heap == [msg3])
  158. self.assertTrue(self.scheduler.processed == [msg2])
  159. self.assertTrue(self.scheduler.invalids == set({2}))