isar 1.24.1__tar.gz → 1.24.2__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of isar might be problematic. Click here for more details.

Files changed (204) hide show
  1. {isar-1.24.1 → isar-1.24.2}/PKG-INFO +1 -1
  2. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/schedule/scheduling_controller.py +2 -8
  3. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/state_machine.py +21 -6
  4. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/idle.py +3 -0
  5. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/monitor.py +11 -7
  6. {isar-1.24.1 → isar-1.24.2}/src/isar.egg-info/PKG-INFO +1 -1
  7. {isar-1.24.1 → isar-1.24.2}/tests/isar/apis/scheduler/test_scheduler_router.py +1 -8
  8. {isar-1.24.1 → isar-1.24.2}/.dockerignore +0 -0
  9. {isar-1.24.1 → isar-1.24.2}/.github/ISSUE_TEMPLATE/bug_report.md +0 -0
  10. {isar-1.24.1 → isar-1.24.2}/.github/ISSUE_TEMPLATE/feature.md +0 -0
  11. {isar-1.24.1 → isar-1.24.2}/.github/ISSUE_TEMPLATE/improvement.md +0 -0
  12. {isar-1.24.1 → isar-1.24.2}/.github/release.yml +0 -0
  13. {isar-1.24.1 → isar-1.24.2}/.github/workflows/compile_requirements.yml +0 -0
  14. {isar-1.24.1 → isar-1.24.2}/.github/workflows/project_automations.yml +0 -0
  15. {isar-1.24.1 → isar-1.24.2}/.github/workflows/publish_isar_base_image.yml +0 -0
  16. {isar-1.24.1 → isar-1.24.2}/.github/workflows/pythonpackage.yml +0 -0
  17. {isar-1.24.1 → isar-1.24.2}/.github/workflows/pythonpublish.yml +0 -0
  18. {isar-1.24.1 → isar-1.24.2}/.github/workflows/stale.yml +0 -0
  19. {isar-1.24.1 → isar-1.24.2}/.gitignore +0 -0
  20. {isar-1.24.1 → isar-1.24.2}/.pre-commit-config.yaml +0 -0
  21. {isar-1.24.1 → isar-1.24.2}/Dockerfile +0 -0
  22. {isar-1.24.1 → isar-1.24.2}/LICENSE +0 -0
  23. {isar-1.24.1 → isar-1.24.2}/README.md +0 -0
  24. {isar-1.24.1 → isar-1.24.2}/SECURITY.md +0 -0
  25. {isar-1.24.1 → isar-1.24.2}/docker-compose-turtlebot.yml +0 -0
  26. {isar-1.24.1 → isar-1.24.2}/docker-compose.yml +0 -0
  27. {isar-1.24.1 → isar-1.24.2}/docs/Makefile +0 -0
  28. {isar-1.24.1 → isar-1.24.2}/docs/make.bat +0 -0
  29. {isar-1.24.1 → isar-1.24.2}/docs/rst_processing.py +0 -0
  30. {isar-1.24.1 → isar-1.24.2}/docs/source/conf.py +0 -0
  31. {isar-1.24.1 → isar-1.24.2}/docs/source/index.rst +0 -0
  32. {isar-1.24.1 → isar-1.24.2}/docs/source/readme_link.md +0 -0
  33. {isar-1.24.1 → isar-1.24.2}/docs/state_machine_diagram.png +0 -0
  34. {isar-1.24.1 → isar-1.24.2}/main.py +0 -0
  35. {isar-1.24.1 → isar-1.24.2}/pyproject.toml +0 -0
  36. {isar-1.24.1 → isar-1.24.2}/radixconfig.yml +0 -0
  37. {isar-1.24.1 → isar-1.24.2}/requirements.txt +0 -0
  38. {isar-1.24.1 → isar-1.24.2}/setup.cfg +0 -0
  39. {isar-1.24.1 → isar-1.24.2}/src/isar/__init__.py +0 -0
  40. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/__init__.py +0 -0
  41. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/api.py +0 -0
  42. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/models/__init__.py +0 -0
  43. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/models/models.py +0 -0
  44. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/models/start_mission_definition.py +0 -0
  45. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/schedule/__init__.py +0 -0
  46. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/security/__init__.py +0 -0
  47. {isar-1.24.1 → isar-1.24.2}/src/isar/apis/security/authentication.py +0 -0
  48. {isar-1.24.1 → isar-1.24.2}/src/isar/config/__init__.py +0 -0
  49. {isar-1.24.1 → isar-1.24.2}/src/isar/config/certs/ca-cert.pem +0 -0
  50. {isar-1.24.1 → isar-1.24.2}/src/isar/config/configuration_error.py +0 -0
  51. {isar-1.24.1 → isar-1.24.2}/src/isar/config/keyvault/__init__.py +0 -0
  52. {isar-1.24.1 → isar-1.24.2}/src/isar/config/keyvault/keyvault_error.py +0 -0
  53. {isar-1.24.1 → isar-1.24.2}/src/isar/config/keyvault/keyvault_service.py +0 -0
  54. {isar-1.24.1 → isar-1.24.2}/src/isar/config/log.py +0 -0
  55. {isar-1.24.1 → isar-1.24.2}/src/isar/config/logging.conf +0 -0
  56. {isar-1.24.1 → isar-1.24.2}/src/isar/config/maps/JSP1_intermediate_deck.json +0 -0
  57. {isar-1.24.1 → isar-1.24.2}/src/isar/config/maps/JSP1_weather_deck.json +0 -0
  58. {isar-1.24.1 → isar-1.24.2}/src/isar/config/maps/default_map.json +0 -0
  59. {isar-1.24.1 → isar-1.24.2}/src/isar/config/maps/klab_b.json +0 -0
  60. {isar-1.24.1 → isar-1.24.2}/src/isar/config/maps/klab_compressor.json +0 -0
  61. {isar-1.24.1 → isar-1.24.2}/src/isar/config/maps/klab_turtlebot.json +0 -0
  62. {isar-1.24.1 → isar-1.24.2}/src/isar/config/maps/turtleworld.json +0 -0
  63. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_mission_definition/__init__.py +0 -0
  64. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_mission_definition/default_exr.json +0 -0
  65. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_mission_definition/default_mission.json +0 -0
  66. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_mission_definition/default_turtlebot.json +0 -0
  67. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_missions/__init__.py +0 -0
  68. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_missions/default.json +0 -0
  69. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_missions/default_turtlebot.json +0 -0
  70. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_poses/__init__.py +0 -0
  71. {isar-1.24.1 → isar-1.24.2}/src/isar/config/predefined_poses/predefined_poses.py +0 -0
  72. {isar-1.24.1 → isar-1.24.2}/src/isar/config/settings.env +0 -0
  73. {isar-1.24.1 → isar-1.24.2}/src/isar/config/settings.py +0 -0
  74. {isar-1.24.1 → isar-1.24.2}/src/isar/mission_planner/__init__.py +0 -0
  75. {isar-1.24.1 → isar-1.24.2}/src/isar/mission_planner/local_planner.py +0 -0
  76. {isar-1.24.1 → isar-1.24.2}/src/isar/mission_planner/mission_planner_interface.py +0 -0
  77. {isar-1.24.1 → isar-1.24.2}/src/isar/mission_planner/sequential_task_selector.py +0 -0
  78. {isar-1.24.1 → isar-1.24.2}/src/isar/mission_planner/task_selector_interface.py +0 -0
  79. {isar-1.24.1 → isar-1.24.2}/src/isar/models/__init__.py +0 -0
  80. {isar-1.24.1 → isar-1.24.2}/src/isar/models/communication/__init__.py +0 -0
  81. {isar-1.24.1 → isar-1.24.2}/src/isar/models/communication/message.py +0 -0
  82. {isar-1.24.1 → isar-1.24.2}/src/isar/models/communication/queues/__init__.py +0 -0
  83. {isar-1.24.1 → isar-1.24.2}/src/isar/models/communication/queues/queue_io.py +0 -0
  84. {isar-1.24.1 → isar-1.24.2}/src/isar/models/communication/queues/queue_timeout_error.py +0 -0
  85. {isar-1.24.1 → isar-1.24.2}/src/isar/models/communication/queues/queues.py +0 -0
  86. {isar-1.24.1 → isar-1.24.2}/src/isar/models/communication/queues/status_queue.py +0 -0
  87. {isar-1.24.1 → isar-1.24.2}/src/isar/models/mission_metadata/__init__.py +0 -0
  88. {isar-1.24.1 → isar-1.24.2}/src/isar/modules.py +0 -0
  89. {isar-1.24.1 → isar-1.24.2}/src/isar/script.py +0 -0
  90. {isar-1.24.1 → isar-1.24.2}/src/isar/services/__init__.py +0 -0
  91. {isar-1.24.1 → isar-1.24.2}/src/isar/services/auth/__init__.py +0 -0
  92. {isar-1.24.1 → isar-1.24.2}/src/isar/services/auth/azure_credentials.py +0 -0
  93. {isar-1.24.1 → isar-1.24.2}/src/isar/services/readers/__init__.py +0 -0
  94. {isar-1.24.1 → isar-1.24.2}/src/isar/services/readers/base_reader.py +0 -0
  95. {isar-1.24.1 → isar-1.24.2}/src/isar/services/service_connections/__init__.py +0 -0
  96. {isar-1.24.1 → isar-1.24.2}/src/isar/services/service_connections/mqtt/__init__.py +0 -0
  97. {isar-1.24.1 → isar-1.24.2}/src/isar/services/service_connections/mqtt/mqtt_client.py +0 -0
  98. {isar-1.24.1 → isar-1.24.2}/src/isar/services/service_connections/mqtt/robot_heartbeat_publisher.py +0 -0
  99. {isar-1.24.1 → isar-1.24.2}/src/isar/services/service_connections/mqtt/robot_info_publisher.py +0 -0
  100. {isar-1.24.1 → isar-1.24.2}/src/isar/services/service_connections/request_handler.py +0 -0
  101. {isar-1.24.1 → isar-1.24.2}/src/isar/services/service_connections/stid/__init__.py +0 -0
  102. {isar-1.24.1 → isar-1.24.2}/src/isar/services/utilities/__init__.py +0 -0
  103. {isar-1.24.1 → isar-1.24.2}/src/isar/services/utilities/queue_utilities.py +0 -0
  104. {isar-1.24.1 → isar-1.24.2}/src/isar/services/utilities/scheduling_utilities.py +0 -0
  105. {isar-1.24.1 → isar-1.24.2}/src/isar/services/utilities/threaded_request.py +0 -0
  106. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/__init__.py +0 -0
  107. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/__init__.py +0 -0
  108. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/initialize.py +0 -0
  109. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/initiate.py +0 -0
  110. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/off.py +0 -0
  111. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/offline.py +0 -0
  112. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/paused.py +0 -0
  113. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states/stop.py +0 -0
  114. {isar-1.24.1 → isar-1.24.2}/src/isar/state_machine/states_enum.py +0 -0
  115. {isar-1.24.1 → isar-1.24.2}/src/isar/storage/__init__.py +0 -0
  116. {isar-1.24.1 → isar-1.24.2}/src/isar/storage/blob_storage.py +0 -0
  117. {isar-1.24.1 → isar-1.24.2}/src/isar/storage/local_storage.py +0 -0
  118. {isar-1.24.1 → isar-1.24.2}/src/isar/storage/slimm_storage.py +0 -0
  119. {isar-1.24.1 → isar-1.24.2}/src/isar/storage/storage_interface.py +0 -0
  120. {isar-1.24.1 → isar-1.24.2}/src/isar/storage/uploader.py +0 -0
  121. {isar-1.24.1 → isar-1.24.2}/src/isar/storage/utilities.py +0 -0
  122. {isar-1.24.1 → isar-1.24.2}/src/isar.egg-info/SOURCES.txt +0 -0
  123. {isar-1.24.1 → isar-1.24.2}/src/isar.egg-info/dependency_links.txt +0 -0
  124. {isar-1.24.1 → isar-1.24.2}/src/isar.egg-info/entry_points.txt +0 -0
  125. {isar-1.24.1 → isar-1.24.2}/src/isar.egg-info/requires.txt +0 -0
  126. {isar-1.24.1 → isar-1.24.2}/src/isar.egg-info/top_level.txt +0 -0
  127. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/__init__.py +0 -0
  128. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/__init__.py +0 -0
  129. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/exceptions/__init__.py +0 -0
  130. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/exceptions/robot_exceptions.py +0 -0
  131. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/initialize/__init__.py +0 -0
  132. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/initialize/initialize_params.py +0 -0
  133. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/inspection/__init__.py +0 -0
  134. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/inspection/inspection.py +0 -0
  135. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/mission/__init__.py +0 -0
  136. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/mission/mission.py +0 -0
  137. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/mission/status.py +0 -0
  138. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/mission/task.py +0 -0
  139. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/robots/__init__.py +0 -0
  140. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/models/robots/robot_model.py +0 -0
  141. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/robot_interface.py +0 -0
  142. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/telemetry/__init__.py +0 -0
  143. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/telemetry/media_connection_type.py +0 -0
  144. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/telemetry/mqtt_client.py +0 -0
  145. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/telemetry/payloads.py +0 -0
  146. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/test_robot_interface.py +0 -0
  147. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/utilities/__init__.py +0 -0
  148. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/utilities/json_service.py +0 -0
  149. {isar-1.24.1 → isar-1.24.2}/src/robot_interface/utilities/uuid_string_factory.py +0 -0
  150. {isar-1.24.1 → isar-1.24.2}/tests/__init__.py +0 -0
  151. {isar-1.24.1 → isar-1.24.2}/tests/conftest.py +0 -0
  152. {isar-1.24.1 → isar-1.24.2}/tests/integration/__init__.py +0 -0
  153. {isar-1.24.1 → isar-1.24.2}/tests/integration/turtlebot/__init__.py +0 -0
  154. {isar-1.24.1 → isar-1.24.2}/tests/integration/turtlebot/config/__init__.py +0 -0
  155. {isar-1.24.1 → isar-1.24.2}/tests/integration/turtlebot/config/maps/__init__.py +0 -0
  156. {isar-1.24.1 → isar-1.24.2}/tests/integration/turtlebot/config/maps/turtleworld.json +0 -0
  157. {isar-1.24.1 → isar-1.24.2}/tests/integration/turtlebot/config/missions/__init__.py +0 -0
  158. {isar-1.24.1 → isar-1.24.2}/tests/integration/turtlebot/config/missions/default.json +0 -0
  159. {isar-1.24.1 → isar-1.24.2}/tests/integration/turtlebot/test_successful_mission.py +0 -0
  160. {isar-1.24.1 → isar-1.24.2}/tests/isar/__init__.py +0 -0
  161. {isar-1.24.1 → isar-1.24.2}/tests/isar/apis/__init__.py +0 -0
  162. {isar-1.24.1 → isar-1.24.2}/tests/isar/apis/scheduler/__init__.py +0 -0
  163. {isar-1.24.1 → isar-1.24.2}/tests/isar/apis/security/__init__.py +0 -0
  164. {isar-1.24.1 → isar-1.24.2}/tests/isar/apis/security/test_authentication.py +0 -0
  165. {isar-1.24.1 → isar-1.24.2}/tests/isar/mission/__init__.py +0 -0
  166. {isar-1.24.1 → isar-1.24.2}/tests/isar/mission/test_mission.py +0 -0
  167. {isar-1.24.1 → isar-1.24.2}/tests/isar/models/__init__.py +0 -0
  168. {isar-1.24.1 → isar-1.24.2}/tests/isar/models/communication/__init__.py +0 -0
  169. {isar-1.24.1 → isar-1.24.2}/tests/isar/models/communication/test_queues.py +0 -0
  170. {isar-1.24.1 → isar-1.24.2}/tests/isar/models/example_mission_definition.json +0 -0
  171. {isar-1.24.1 → isar-1.24.2}/tests/isar/models/test_start_mission_definition.py +0 -0
  172. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/__init__.py +0 -0
  173. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/readers/__init__.py +0 -0
  174. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/readers/test_base_reader.py +0 -0
  175. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/readers/test_mission_reader.py +0 -0
  176. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/service_connections/__init__.py +0 -0
  177. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/service_connections/echo/__init__.py +0 -0
  178. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/service_connections/test_base_request_handler.py +0 -0
  179. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/utilities/__init__.py +0 -0
  180. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/utilities/test_queue_utilities.py +0 -0
  181. {isar-1.24.1 → isar-1.24.2}/tests/isar/services/utilities/test_scheduling_utilities.py +0 -0
  182. {isar-1.24.1 → isar-1.24.2}/tests/isar/state_machine/__init__.py +0 -0
  183. {isar-1.24.1 → isar-1.24.2}/tests/isar/state_machine/states/__init__.py +0 -0
  184. {isar-1.24.1 → isar-1.24.2}/tests/isar/state_machine/states/test_monitor.py +0 -0
  185. {isar-1.24.1 → isar-1.24.2}/tests/isar/state_machine/test_state_machine.py +0 -0
  186. {isar-1.24.1 → isar-1.24.2}/tests/isar/storage/test_blob_storage.py +0 -0
  187. {isar-1.24.1 → isar-1.24.2}/tests/isar/storage/test_uploader.py +0 -0
  188. {isar-1.24.1 → isar-1.24.2}/tests/mocks/__init__.py +0 -0
  189. {isar-1.24.1 → isar-1.24.2}/tests/mocks/blob_storage.py +0 -0
  190. {isar-1.24.1 → isar-1.24.2}/tests/mocks/mission_definition.py +0 -0
  191. {isar-1.24.1 → isar-1.24.2}/tests/mocks/mqtt_client.py +0 -0
  192. {isar-1.24.1 → isar-1.24.2}/tests/mocks/pose.py +0 -0
  193. {isar-1.24.1 → isar-1.24.2}/tests/mocks/request.py +0 -0
  194. {isar-1.24.1 → isar-1.24.2}/tests/mocks/robot_interface.py +0 -0
  195. {isar-1.24.1 → isar-1.24.2}/tests/mocks/status.py +0 -0
  196. {isar-1.24.1 → isar-1.24.2}/tests/mocks/task.py +0 -0
  197. {isar-1.24.1 → isar-1.24.2}/tests/mocks/token.py +0 -0
  198. {isar-1.24.1 → isar-1.24.2}/tests/test_data/test_json_file.json +0 -0
  199. {isar-1.24.1 → isar-1.24.2}/tests/test_data/test_map_config/test_map_config.json +0 -0
  200. {isar-1.24.1 → isar-1.24.2}/tests/test_data/test_mission_not_working.json +0 -0
  201. {isar-1.24.1 → isar-1.24.2}/tests/test_data/test_mission_working.json +0 -0
  202. {isar-1.24.1 → isar-1.24.2}/tests/test_data/test_mission_working_no_tasks.json +0 -0
  203. {isar-1.24.1 → isar-1.24.2}/tests/test_data/test_thermal_image_mission.json +0 -0
  204. {isar-1.24.1 → isar-1.24.2}/tests/test_modules.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: isar
3
- Version: 1.24.1
3
+ Version: 1.24.2
4
4
  Summary: Integration and Supervisory control of Autonomous Robots
5
5
  Author-email: Equinor ASA <fg_robots_dev@equinor.com>
6
6
  License: Eclipse Public License version 2.0
@@ -21,13 +21,7 @@ from isar.mission_planner.mission_planner_interface import MissionPlannerError
21
21
  from isar.services.utilities.scheduling_utilities import SchedulingUtilities
22
22
  from isar.state_machine.states_enum import States
23
23
  from robot_interface.models.mission.mission import Mission
24
- from robot_interface.models.mission.task import (
25
- TASKS,
26
- Localize,
27
- MoveArm,
28
- ReturnToHome,
29
- )
30
- from robot_interface.models.mission.task import Task
24
+ from robot_interface.models.mission.task import TASKS, Localize, MoveArm, ReturnToHome
31
25
 
32
26
 
33
27
  class SchedulingController:
@@ -192,7 +186,7 @@ class SchedulingController:
192
186
 
193
187
  state: States = self.scheduling_utilities.get_state()
194
188
 
195
- if state in [States.Off, States.Idle]:
189
+ if state == States.Off:
196
190
  error_message = (
197
191
  f"Conflict - Stop command received in invalid state - State: {state}"
198
192
  )
@@ -32,11 +32,7 @@ from isar.state_machine.states_enum import States
32
32
  from robot_interface.models.exceptions.robot_exceptions import ErrorMessage
33
33
  from robot_interface.models.initialize.initialize_params import InitializeParams
34
34
  from robot_interface.models.mission.mission import Mission
35
- from robot_interface.models.mission.status import (
36
- MissionStatus,
37
- RobotStatus,
38
- TaskStatus,
39
- )
35
+ from robot_interface.models.mission.status import MissionStatus, RobotStatus, TaskStatus
40
36
  from robot_interface.models.mission.task import TASKS, Task
41
37
  from robot_interface.robot_interface import RobotInterface
42
38
  from robot_interface.telemetry.mqtt_client import MqttClientInterface
@@ -134,7 +130,11 @@ class StateMachine(object):
134
130
  },
135
131
  {
136
132
  "trigger": "stop",
137
- "source": [self.initiate_state, self.monitor_state],
133
+ "source": [
134
+ self.initiate_state,
135
+ self.monitor_state,
136
+ self.idle_state,
137
+ ],
138
138
  "dest": self.stop_state,
139
139
  "before": self._stop,
140
140
  },
@@ -371,6 +371,11 @@ class StateMachine(object):
371
371
  self.iterate_current_task()
372
372
 
373
373
  def _mission_stopped(self) -> None:
374
+ if self.current_mission is None:
375
+ self._queue_empty_response()
376
+ self.reset_state_machine()
377
+ return
378
+
374
379
  self.current_mission.status = MissionStatus.Cancelled
375
380
 
376
381
  for task in self.current_mission.tasks:
@@ -588,6 +593,16 @@ class StateMachine(object):
588
593
  task_status=self.current_task.status,
589
594
  )
590
595
 
596
+ def _queue_empty_response(self):
597
+ self.queues.stop_mission.output.put(
598
+ ControlMissionResponse(
599
+ mission_id="None",
600
+ mission_status="None",
601
+ task_id="None",
602
+ task_status="None",
603
+ )
604
+ )
605
+
591
606
 
592
607
  def main(state_machine: StateMachine):
593
608
  """Starts a state machine instance."""
@@ -36,6 +36,9 @@ class Idle(State):
36
36
 
37
37
  def _run(self) -> None:
38
38
  while True:
39
+ if self.state_machine.should_stop_mission():
40
+ transition = self.state_machine.stop # type: ignore
41
+ break
39
42
  start_mission: Optional[StartMissionMessage] = (
40
43
  self.state_machine.should_start_mission()
41
44
  )
@@ -49,7 +49,6 @@ class Monitor(State):
49
49
  if self.task_status_thread:
50
50
  self.task_status_thread.wait_for_thread()
51
51
  self.task_status_thread = None
52
- self.request_status_failure_counter = 0
53
52
 
54
53
  def _run(self) -> None:
55
54
  transition: Callable
@@ -76,15 +75,19 @@ class Monitor(State):
76
75
  except ThreadedRequestNotFinishedError:
77
76
  time.sleep(self.state_machine.sleep_time)
78
77
  continue
79
-
80
78
  except (
81
79
  RobotCommunicationTimeoutException,
82
80
  RobotCommunicationException,
83
81
  ) as e:
84
- task_failed: bool = self._handle_communication_retry(e)
85
- if task_failed:
82
+ retry_limit_exceeded: bool = self._check_if_exceeded_retry_limit(e)
83
+ if retry_limit_exceeded:
84
+ self.logger.error(
85
+ f"Monitoring task {self.state_machine.current_task.id[:8]} failed "
86
+ f"because: {e.error_description}"
87
+ )
86
88
  status = TaskStatus.Failed
87
89
  else:
90
+ time.sleep(self.state_machine.sleep_time)
88
91
  continue
89
92
 
90
93
  except RobotTaskStatusException as e:
@@ -111,7 +114,7 @@ class Monitor(State):
111
114
  )
112
115
  break
113
116
 
114
- if self.state_machine.current_task == None:
117
+ if self.state_machine.current_task is None:
115
118
  self.state_machine.iterate_current_task()
116
119
 
117
120
  self.state_machine.current_task.status = status
@@ -142,7 +145,7 @@ class Monitor(State):
142
145
  )
143
146
 
144
147
  self.state_machine.iterate_current_task()
145
- if self.state_machine.current_task == None:
148
+ if self.state_machine.current_task is None:
146
149
  transition = self.state_machine.full_mission_finished # type: ignore
147
150
  break
148
151
 
@@ -193,6 +196,7 @@ class Monitor(State):
193
196
  self.logger.info(f"Inspection: {str(inspection.id)[:8]} queued for upload")
194
197
 
195
198
  def _report_task_status(self, task: Task) -> None:
199
+ self.request_status_failure_counter = 0
196
200
  if task.status == TaskStatus.Failed:
197
201
  self.logger.warning(
198
202
  f"Task: {str(task.id)[:8]} was reported as failed by the robot"
@@ -215,7 +219,7 @@ class Monitor(State):
215
219
  )
216
220
  self.state_machine.current_task.error_message = error_message
217
221
 
218
- def _handle_communication_retry(
222
+ def _check_if_exceeded_retry_limit(
219
223
  self, e: Union[RobotCommunicationTimeoutException, RobotCommunicationException]
220
224
  ) -> bool:
221
225
  self.state_machine.current_mission.error_message = ErrorMessage(
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: isar
3
- Version: 1.24.1
3
+ Version: 1.24.2
4
4
  Summary: Integration and Supervisory control of Autonomous Robots
5
5
  Author-email: Equinor ASA <fg_robots_dev@equinor.com>
6
6
  License: Eclipse Public License version 2.0
@@ -269,6 +269,7 @@ class TestStopMission:
269
269
  valid_states = [
270
270
  States.Initiate,
271
271
  States.Initialize,
272
+ States.Idle,
272
273
  States.Monitor,
273
274
  States.Paused,
274
275
  States.Stop,
@@ -286,14 +287,6 @@ class TestStopMission:
286
287
  assert response.status_code == HTTPStatus.OK
287
288
  assert response.json() == jsonable_encoder(mock_control_mission_response)
288
289
 
289
- @mock.patch.object(SchedulingUtilities, "get_state", mock_return_idle)
290
- @mock.patch.object(
291
- SchedulingUtilities, "stop_mission", mock_control_mission_response
292
- )
293
- def test_can_not_stop_mission_in_idle(self, client: TestClient):
294
- response = client.post(url=self.schedule_stop_mission_path)
295
- assert response.status_code == HTTPStatus.CONFLICT
296
-
297
290
  @mock.patch.object(SchedulingUtilities, "get_state", mock_return_off)
298
291
  @mock.patch.object(
299
292
  SchedulingUtilities, "stop_mission", mock_control_mission_response
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes