isar 1.32.1__tar.gz → 1.32.3__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 (213) hide show
  1. {isar-1.32.1 → isar-1.32.3}/PKG-INFO +1 -1
  2. {isar-1.32.1 → isar-1.32.3}/src/isar/config/settings.py +3 -0
  3. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/returning_home.py +3 -0
  4. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/return_home.py +17 -1
  5. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/return_home.py +23 -1
  6. {isar-1.32.1 → isar-1.32.3}/src/isar/storage/blob_storage.py +29 -31
  7. {isar-1.32.1 → isar-1.32.3}/src/isar/storage/local_storage.py +5 -2
  8. {isar-1.32.1 → isar-1.32.3}/src/isar/storage/storage_interface.py +3 -3
  9. {isar-1.32.1 → isar-1.32.3}/src/isar.egg-info/PKG-INFO +1 -1
  10. {isar-1.32.1 → isar-1.32.3}/tests/isar/state_machine/test_state_machine.py +79 -0
  11. {isar-1.32.1 → isar-1.32.3}/.dockerignore +0 -0
  12. {isar-1.32.1 → isar-1.32.3}/.env.test +0 -0
  13. {isar-1.32.1 → isar-1.32.3}/.github/ISSUE_TEMPLATE/bug_report.md +0 -0
  14. {isar-1.32.1 → isar-1.32.3}/.github/ISSUE_TEMPLATE/feature.md +0 -0
  15. {isar-1.32.1 → isar-1.32.3}/.github/ISSUE_TEMPLATE/improvement.md +0 -0
  16. {isar-1.32.1 → isar-1.32.3}/.github/PULL_REQUEST_TEMPLATE.md +0 -0
  17. {isar-1.32.1 → isar-1.32.3}/.github/release.yml +0 -0
  18. {isar-1.32.1 → isar-1.32.3}/.github/workflows/compile_requirements.yml +0 -0
  19. {isar-1.32.1 → isar-1.32.3}/.github/workflows/project_automations.yml +0 -0
  20. {isar-1.32.1 → isar-1.32.3}/.github/workflows/pythonpackage.yml +0 -0
  21. {isar-1.32.1 → isar-1.32.3}/.github/workflows/pythonpublish.yml +0 -0
  22. {isar-1.32.1 → isar-1.32.3}/.github/workflows/stale.yml +0 -0
  23. {isar-1.32.1 → isar-1.32.3}/.gitignore +0 -0
  24. {isar-1.32.1 → isar-1.32.3}/.pre-commit-config.yaml +0 -0
  25. {isar-1.32.1 → isar-1.32.3}/LICENSE +0 -0
  26. {isar-1.32.1 → isar-1.32.3}/README.md +0 -0
  27. {isar-1.32.1 → isar-1.32.3}/SECURITY.md +0 -0
  28. {isar-1.32.1 → isar-1.32.3}/docs/Makefile +0 -0
  29. {isar-1.32.1 → isar-1.32.3}/docs/full_state_machine_diagram.png +0 -0
  30. {isar-1.32.1 → isar-1.32.3}/docs/make.bat +0 -0
  31. {isar-1.32.1 → isar-1.32.3}/docs/mission_state_machine_diagram.png +0 -0
  32. {isar-1.32.1 → isar-1.32.3}/docs/robot_status_state_machine_diagram.png +0 -0
  33. {isar-1.32.1 → isar-1.32.3}/docs/rst_processing.py +0 -0
  34. {isar-1.32.1 → isar-1.32.3}/docs/source/conf.py +0 -0
  35. {isar-1.32.1 → isar-1.32.3}/docs/source/index.rst +0 -0
  36. {isar-1.32.1 → isar-1.32.3}/docs/source/readme_link.md +0 -0
  37. {isar-1.32.1 → isar-1.32.3}/docs/update_state_diagram.py +0 -0
  38. {isar-1.32.1 → isar-1.32.3}/main.py +0 -0
  39. {isar-1.32.1 → isar-1.32.3}/pyproject.toml +0 -0
  40. {isar-1.32.1 → isar-1.32.3}/radixconfig.yml +0 -0
  41. {isar-1.32.1 → isar-1.32.3}/requirements.txt +0 -0
  42. {isar-1.32.1 → isar-1.32.3}/setup.cfg +0 -0
  43. {isar-1.32.1 → isar-1.32.3}/src/isar/__init__.py +0 -0
  44. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/__init__.py +0 -0
  45. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/api.py +0 -0
  46. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/models/__init__.py +0 -0
  47. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/models/models.py +0 -0
  48. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/models/start_mission_definition.py +0 -0
  49. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/robot_control/robot_controller.py +0 -0
  50. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/schedule/__init__.py +0 -0
  51. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/schedule/scheduling_controller.py +0 -0
  52. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/security/__init__.py +0 -0
  53. {isar-1.32.1 → isar-1.32.3}/src/isar/apis/security/authentication.py +0 -0
  54. {isar-1.32.1 → isar-1.32.3}/src/isar/config/__init__.py +0 -0
  55. {isar-1.32.1 → isar-1.32.3}/src/isar/config/certs/ca-cert.pem +0 -0
  56. {isar-1.32.1 → isar-1.32.3}/src/isar/config/configuration_error.py +0 -0
  57. {isar-1.32.1 → isar-1.32.3}/src/isar/config/keyvault/__init__.py +0 -0
  58. {isar-1.32.1 → isar-1.32.3}/src/isar/config/keyvault/keyvault_error.py +0 -0
  59. {isar-1.32.1 → isar-1.32.3}/src/isar/config/keyvault/keyvault_service.py +0 -0
  60. {isar-1.32.1 → isar-1.32.3}/src/isar/config/log.py +0 -0
  61. {isar-1.32.1 → isar-1.32.3}/src/isar/config/logging.conf +0 -0
  62. {isar-1.32.1 → isar-1.32.3}/src/isar/config/maps/JSP1_intermediate_deck.json +0 -0
  63. {isar-1.32.1 → isar-1.32.3}/src/isar/config/maps/JSP1_weather_deck.json +0 -0
  64. {isar-1.32.1 → isar-1.32.3}/src/isar/config/maps/default_map.json +0 -0
  65. {isar-1.32.1 → isar-1.32.3}/src/isar/config/maps/klab_b.json +0 -0
  66. {isar-1.32.1 → isar-1.32.3}/src/isar/config/maps/klab_compressor.json +0 -0
  67. {isar-1.32.1 → isar-1.32.3}/src/isar/config/maps/klab_turtlebot.json +0 -0
  68. {isar-1.32.1 → isar-1.32.3}/src/isar/config/maps/turtleworld.json +0 -0
  69. {isar-1.32.1 → isar-1.32.3}/src/isar/config/open_telemetry.py +0 -0
  70. {isar-1.32.1 → isar-1.32.3}/src/isar/config/predefined_mission_definition/__init__.py +0 -0
  71. {isar-1.32.1 → isar-1.32.3}/src/isar/config/predefined_mission_definition/default_exr.json +0 -0
  72. {isar-1.32.1 → isar-1.32.3}/src/isar/config/predefined_mission_definition/default_mission.json +0 -0
  73. {isar-1.32.1 → isar-1.32.3}/src/isar/config/predefined_mission_definition/default_turtlebot.json +0 -0
  74. {isar-1.32.1 → isar-1.32.3}/src/isar/config/predefined_missions/__init__.py +0 -0
  75. {isar-1.32.1 → isar-1.32.3}/src/isar/config/predefined_missions/default.json +0 -0
  76. {isar-1.32.1 → isar-1.32.3}/src/isar/config/predefined_missions/default_turtlebot.json +0 -0
  77. {isar-1.32.1 → isar-1.32.3}/src/isar/eventhandlers/eventhandler.py +0 -0
  78. {isar-1.32.1 → isar-1.32.3}/src/isar/mission_planner/__init__.py +0 -0
  79. {isar-1.32.1 → isar-1.32.3}/src/isar/mission_planner/local_planner.py +0 -0
  80. {isar-1.32.1 → isar-1.32.3}/src/isar/mission_planner/mission_planner_interface.py +0 -0
  81. {isar-1.32.1 → isar-1.32.3}/src/isar/mission_planner/sequential_task_selector.py +0 -0
  82. {isar-1.32.1 → isar-1.32.3}/src/isar/mission_planner/task_selector_interface.py +0 -0
  83. {isar-1.32.1 → isar-1.32.3}/src/isar/models/__init__.py +0 -0
  84. {isar-1.32.1 → isar-1.32.3}/src/isar/models/events.py +0 -0
  85. {isar-1.32.1 → isar-1.32.3}/src/isar/modules.py +0 -0
  86. {isar-1.32.1 → isar-1.32.3}/src/isar/robot/robot.py +0 -0
  87. {isar-1.32.1 → isar-1.32.3}/src/isar/robot/robot_start_mission.py +0 -0
  88. {isar-1.32.1 → isar-1.32.3}/src/isar/robot/robot_status.py +0 -0
  89. {isar-1.32.1 → isar-1.32.3}/src/isar/robot/robot_stop_mission.py +0 -0
  90. {isar-1.32.1 → isar-1.32.3}/src/isar/robot/robot_task_status.py +0 -0
  91. {isar-1.32.1 → isar-1.32.3}/src/isar/script.py +0 -0
  92. {isar-1.32.1 → isar-1.32.3}/src/isar/services/__init__.py +0 -0
  93. {isar-1.32.1 → isar-1.32.3}/src/isar/services/auth/__init__.py +0 -0
  94. {isar-1.32.1 → isar-1.32.3}/src/isar/services/auth/azure_credentials.py +0 -0
  95. {isar-1.32.1 → isar-1.32.3}/src/isar/services/service_connections/__init__.py +0 -0
  96. {isar-1.32.1 → isar-1.32.3}/src/isar/services/service_connections/mqtt/__init__.py +0 -0
  97. {isar-1.32.1 → isar-1.32.3}/src/isar/services/service_connections/mqtt/mqtt_client.py +0 -0
  98. {isar-1.32.1 → isar-1.32.3}/src/isar/services/service_connections/mqtt/robot_heartbeat_publisher.py +0 -0
  99. {isar-1.32.1 → isar-1.32.3}/src/isar/services/service_connections/mqtt/robot_info_publisher.py +0 -0
  100. {isar-1.32.1 → isar-1.32.3}/src/isar/services/service_connections/request_handler.py +0 -0
  101. {isar-1.32.1 → isar-1.32.3}/src/isar/services/utilities/__init__.py +0 -0
  102. {isar-1.32.1 → isar-1.32.3}/src/isar/services/utilities/robot_utilities.py +0 -0
  103. {isar-1.32.1 → isar-1.32.3}/src/isar/services/utilities/scheduling_utilities.py +0 -0
  104. {isar-1.32.1 → isar-1.32.3}/src/isar/services/utilities/threaded_request.py +0 -0
  105. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/__init__.py +0 -0
  106. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/state_machine.py +0 -0
  107. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/__init__.py +0 -0
  108. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/await_next_mission.py +0 -0
  109. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/blocked_protective_stop.py +0 -0
  110. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/home.py +0 -0
  111. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/intervention_needed.py +0 -0
  112. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/monitor.py +0 -0
  113. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/offline.py +0 -0
  114. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/paused.py +0 -0
  115. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/robot_standing_still.py +0 -0
  116. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/stopping.py +0 -0
  117. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states/unknown_status.py +0 -0
  118. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/states_enum.py +0 -0
  119. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/fail_mission.py +0 -0
  120. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/finish_mission.py +0 -0
  121. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/pause.py +0 -0
  122. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/resume.py +0 -0
  123. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/robot_status.py +0 -0
  124. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/start_mission.py +0 -0
  125. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/stop.py +0 -0
  126. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/functions/utils.py +0 -0
  127. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/mission.py +0 -0
  128. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/transitions/robot_status.py +0 -0
  129. {isar-1.32.1 → isar-1.32.3}/src/isar/state_machine/utils/common_event_handlers.py +0 -0
  130. {isar-1.32.1 → isar-1.32.3}/src/isar/storage/__init__.py +0 -0
  131. {isar-1.32.1 → isar-1.32.3}/src/isar/storage/uploader.py +0 -0
  132. {isar-1.32.1 → isar-1.32.3}/src/isar/storage/utilities.py +0 -0
  133. {isar-1.32.1 → isar-1.32.3}/src/isar.egg-info/SOURCES.txt +0 -0
  134. {isar-1.32.1 → isar-1.32.3}/src/isar.egg-info/dependency_links.txt +0 -0
  135. {isar-1.32.1 → isar-1.32.3}/src/isar.egg-info/entry_points.txt +0 -0
  136. {isar-1.32.1 → isar-1.32.3}/src/isar.egg-info/requires.txt +0 -0
  137. {isar-1.32.1 → isar-1.32.3}/src/isar.egg-info/top_level.txt +0 -0
  138. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/__init__.py +0 -0
  139. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/__init__.py +0 -0
  140. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/exceptions/__init__.py +0 -0
  141. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/exceptions/robot_exceptions.py +0 -0
  142. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/initialize/__init__.py +0 -0
  143. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/inspection/__init__.py +0 -0
  144. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/inspection/inspection.py +0 -0
  145. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/mission/__init__.py +0 -0
  146. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/mission/mission.py +0 -0
  147. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/mission/status.py +0 -0
  148. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/mission/task.py +0 -0
  149. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/robots/__init__.py +0 -0
  150. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/robots/battery_state.py +0 -0
  151. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/robots/media.py +0 -0
  152. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/models/robots/robot_model.py +0 -0
  153. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/robot_interface.py +0 -0
  154. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/telemetry/__init__.py +0 -0
  155. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/telemetry/mqtt_client.py +0 -0
  156. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/telemetry/payloads.py +0 -0
  157. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/test_robot_interface.py +0 -0
  158. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/utilities/__init__.py +0 -0
  159. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/utilities/json_service.py +0 -0
  160. {isar-1.32.1 → isar-1.32.3}/src/robot_interface/utilities/uuid_string_factory.py +0 -0
  161. {isar-1.32.1 → isar-1.32.3}/tests/__init__.py +0 -0
  162. {isar-1.32.1 → isar-1.32.3}/tests/conftest.py +0 -0
  163. {isar-1.32.1 → isar-1.32.3}/tests/integration/__init__.py +0 -0
  164. {isar-1.32.1 → isar-1.32.3}/tests/integration/turtlebot/__init__.py +0 -0
  165. {isar-1.32.1 → isar-1.32.3}/tests/integration/turtlebot/config/__init__.py +0 -0
  166. {isar-1.32.1 → isar-1.32.3}/tests/integration/turtlebot/config/maps/__init__.py +0 -0
  167. {isar-1.32.1 → isar-1.32.3}/tests/integration/turtlebot/config/maps/turtleworld.json +0 -0
  168. {isar-1.32.1 → isar-1.32.3}/tests/integration/turtlebot/config/missions/__init__.py +0 -0
  169. {isar-1.32.1 → isar-1.32.3}/tests/integration/turtlebot/config/missions/default.json +0 -0
  170. {isar-1.32.1 → isar-1.32.3}/tests/integration/turtlebot/test_successful_mission.py +0 -0
  171. {isar-1.32.1 → isar-1.32.3}/tests/isar/__init__.py +0 -0
  172. {isar-1.32.1 → isar-1.32.3}/tests/isar/apis/__init__.py +0 -0
  173. {isar-1.32.1 → isar-1.32.3}/tests/isar/apis/models/__init__.py +0 -0
  174. {isar-1.32.1 → isar-1.32.3}/tests/isar/apis/models/example_mission_definition.json +0 -0
  175. {isar-1.32.1 → isar-1.32.3}/tests/isar/apis/models/test_start_mission_definition.py +0 -0
  176. {isar-1.32.1 → isar-1.32.3}/tests/isar/apis/scheduler/__init__.py +0 -0
  177. {isar-1.32.1 → isar-1.32.3}/tests/isar/apis/scheduler/test_scheduler_router.py +0 -0
  178. {isar-1.32.1 → isar-1.32.3}/tests/isar/apis/security/__init__.py +0 -0
  179. {isar-1.32.1 → isar-1.32.3}/tests/isar/apis/security/test_authentication.py +0 -0
  180. {isar-1.32.1 → isar-1.32.3}/tests/isar/mission/__init__.py +0 -0
  181. {isar-1.32.1 → isar-1.32.3}/tests/isar/mission/test_mission.py +0 -0
  182. {isar-1.32.1 → isar-1.32.3}/tests/isar/models/__init__.py +0 -0
  183. {isar-1.32.1 → isar-1.32.3}/tests/isar/models/communication/__init__.py +0 -0
  184. {isar-1.32.1 → isar-1.32.3}/tests/isar/models/communication/test_events.py +0 -0
  185. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/__init__.py +0 -0
  186. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/readers/__init__.py +0 -0
  187. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/readers/test_mission_reader.py +0 -0
  188. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/service_connections/__init__.py +0 -0
  189. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/service_connections/echo/__init__.py +0 -0
  190. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/service_connections/test_base_request_handler.py +0 -0
  191. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/utilities/__init__.py +0 -0
  192. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/utilities/test_queue_utilities.py +0 -0
  193. {isar-1.32.1 → isar-1.32.3}/tests/isar/services/utilities/test_scheduling_utilities.py +0 -0
  194. {isar-1.32.1 → isar-1.32.3}/tests/isar/state_machine/__init__.py +0 -0
  195. {isar-1.32.1 → isar-1.32.3}/tests/isar/state_machine/states/__init__.py +0 -0
  196. {isar-1.32.1 → isar-1.32.3}/tests/isar/state_machine/states/test_monitor.py +0 -0
  197. {isar-1.32.1 → isar-1.32.3}/tests/isar/storage/test_blob_storage.py +0 -0
  198. {isar-1.32.1 → isar-1.32.3}/tests/isar/storage/test_uploader.py +0 -0
  199. {isar-1.32.1 → isar-1.32.3}/tests/test_data/test_map_config/test_map_config.json +0 -0
  200. {isar-1.32.1 → isar-1.32.3}/tests/test_data/test_mission_not_working.json +0 -0
  201. {isar-1.32.1 → isar-1.32.3}/tests/test_data/test_mission_working.json +0 -0
  202. {isar-1.32.1 → isar-1.32.3}/tests/test_data/test_mission_working_no_tasks.json +0 -0
  203. {isar-1.32.1 → isar-1.32.3}/tests/test_data/test_thermal_image_mission.json +0 -0
  204. {isar-1.32.1 → isar-1.32.3}/tests/test_double/__init__.py +0 -0
  205. {isar-1.32.1 → isar-1.32.3}/tests/test_double/blob_storage.py +0 -0
  206. {isar-1.32.1 → isar-1.32.3}/tests/test_double/mission_definition.py +0 -0
  207. {isar-1.32.1 → isar-1.32.3}/tests/test_double/mqtt_client.py +0 -0
  208. {isar-1.32.1 → isar-1.32.3}/tests/test_double/pose.py +0 -0
  209. {isar-1.32.1 → isar-1.32.3}/tests/test_double/request.py +0 -0
  210. {isar-1.32.1 → isar-1.32.3}/tests/test_double/robot_interface.py +0 -0
  211. {isar-1.32.1 → isar-1.32.3}/tests/test_double/status.py +0 -0
  212. {isar-1.32.1 → isar-1.32.3}/tests/test_double/task.py +0 -0
  213. {isar-1.32.1 → isar-1.32.3}/tests/test_double/token.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: isar
3
- Version: 1.32.1
3
+ Version: 1.32.3
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
@@ -89,6 +89,9 @@ class Settings(BaseSettings):
89
89
  # Determines how long delay time should be allowed before returning home
90
90
  RETURN_HOME_DELAY: int = Field(default=10)
91
91
 
92
+ # Sets how many times the robot should try to return home if a return home fails
93
+ RETURN_HOME_RETRY_LIMIT: int = Field(default=5)
94
+
92
95
  # Determines which mission planner module is used by ISAR
93
96
  MISSION_PLANNER: str = Field(default="local")
94
97
 
@@ -20,6 +20,7 @@ if TYPE_CHECKING:
20
20
  class ReturningHome(EventHandlerBase):
21
21
 
22
22
  def __init__(self, state_machine: "StateMachine"):
23
+ self.failed_return_home_attemps: int = 0
23
24
  events = state_machine.events
24
25
 
25
26
  def _handle_task_completed(status: TaskStatus):
@@ -28,7 +29,9 @@ class ReturningHome(EventHandlerBase):
28
29
  error_reason=ErrorReason.RobotActionException,
29
30
  error_description="Return home failed.",
30
31
  )
32
+ self.failed_return_home_attemps += 1
31
33
  return state_machine.return_home_failed # type: ignore
34
+
32
35
  return state_machine.returned_home # type: ignore
33
36
 
34
37
  def _start_mission_event_handler(
@@ -5,8 +5,9 @@ if TYPE_CHECKING:
5
5
 
6
6
  from typing import TYPE_CHECKING
7
7
 
8
+ from isar.config.settings import settings
8
9
  from robot_interface.models.mission.mission import Mission
9
- from robot_interface.models.mission.status import MissionStatus, TaskStatus
10
+ from robot_interface.models.mission.status import MissionStatus, RobotStatus, TaskStatus
10
11
  from robot_interface.models.mission.task import ReturnToHome
11
12
 
12
13
  if TYPE_CHECKING:
@@ -23,6 +24,21 @@ def start_return_home_mission(state_machine: "StateMachine") -> bool:
23
24
  return True
24
25
 
25
26
 
27
+ def should_retry_return_home(state_machine: "StateMachine") -> bool:
28
+ if state_machine.shared_state.robot_status.check() != RobotStatus.Available:
29
+ return False
30
+
31
+ return (
32
+ state_machine.returning_home_state.failed_return_home_attemps
33
+ < settings.RETURN_HOME_RETRY_LIMIT
34
+ )
35
+
36
+
37
+ def reset_return_home_failure_counter(state_machine: "StateMachine") -> bool:
38
+ state_machine.returning_home_state.failed_return_home_attemps = 0
39
+ return True
40
+
41
+
26
42
  def set_return_home_status(state_machine: "StateMachine") -> bool:
27
43
  state_machine.log_mission_overview(mission=state_machine.current_mission)
28
44
  state_machine.current_mission.status = MissionStatus.InProgress
@@ -5,8 +5,10 @@ from isar.state_machine.transitions.functions.fail_mission import (
5
5
  report_failed_return_home_and_intervention_needed,
6
6
  )
7
7
  from isar.state_machine.transitions.functions.return_home import (
8
+ reset_return_home_failure_counter,
8
9
  return_home_finished,
9
10
  set_return_home_status,
11
+ should_retry_return_home,
10
12
  start_return_home_mission,
11
13
  )
12
14
  from isar.state_machine.transitions.functions.start_mission import (
@@ -34,6 +36,7 @@ def get_return_home_transitions(state_machine: "StateMachine") -> List[dict]:
34
36
  def_transition(state_machine, start_return_home_mission),
35
37
  def_transition(state_machine, set_return_home_status),
36
38
  def_transition(state_machine, initialize_robot),
39
+ def_transition(state_machine, initialize_robot),
37
40
  ],
38
41
  "before": def_transition(state_machine, trigger_start_mission_event),
39
42
  },
@@ -59,7 +62,25 @@ def get_return_home_transitions(state_machine: "StateMachine") -> List[dict]:
59
62
  "trigger": "returned_home",
60
63
  "source": state_machine.returning_home_state,
61
64
  "dest": state_machine.home_state,
62
- "before": def_transition(state_machine, return_home_finished),
65
+ "before": [
66
+ def_transition(state_machine, reset_return_home_failure_counter),
67
+ def_transition(state_machine, return_home_finished),
68
+ ],
69
+ },
70
+ {
71
+ "trigger": "return_home_failed",
72
+ "source": state_machine.returning_home_state,
73
+ "dest": state_machine.returning_home_state,
74
+ "conditions": [
75
+ def_transition(state_machine, should_retry_return_home),
76
+ ],
77
+ "before": [
78
+ def_transition(state_machine, report_failed_mission_and_finalize),
79
+ def_transition(state_machine, start_return_home_mission),
80
+ def_transition(state_machine, set_return_home_status),
81
+ def_transition(state_machine, initialize_robot),
82
+ def_transition(state_machine, trigger_start_mission_event),
83
+ ],
63
84
  },
64
85
  {
65
86
  "trigger": "return_home_failed",
@@ -69,6 +90,7 @@ def get_return_home_transitions(state_machine: "StateMachine") -> List[dict]:
69
90
  def_transition(
70
91
  state_machine, report_failed_return_home_and_intervention_needed
71
92
  ),
93
+ def_transition(state_machine, reset_return_home_failure_counter),
72
94
  def_transition(state_machine, report_failed_mission_and_finalize),
73
95
  ],
74
96
  },
@@ -3,34 +3,49 @@ from pathlib import Path
3
3
  from typing import Union
4
4
 
5
5
  from azure.core.exceptions import ResourceExistsError
6
- from azure.storage.blob import BlobClient, BlobServiceClient, ContainerClient
6
+ from azure.storage.blob import BlobServiceClient
7
7
 
8
8
  from isar.config.keyvault.keyvault_service import Keyvault
9
9
  from isar.config.settings import settings
10
10
  from isar.storage.storage_interface import StorageException, StorageInterface
11
11
  from isar.storage.utilities import construct_metadata_file, construct_paths
12
- from robot_interface.models.inspection.inspection import Inspection
12
+ from robot_interface.models.inspection.inspection import InspectionBlob
13
13
  from robot_interface.models.mission.mission import Mission
14
14
 
15
15
 
16
16
  class BlobStorage(StorageInterface):
17
- def __init__(
18
- self, keyvault: Keyvault, container_name: str = settings.BLOB_CONTAINER
19
- ) -> None:
20
- self.keyvault = keyvault
21
- self.storage_connection_string = self.keyvault.get_secret(
17
+ def __init__(self, keyvault: Keyvault) -> None:
18
+ self.logger = logging.getLogger("uploader")
19
+
20
+ storage_connection_string = keyvault.get_secret(
22
21
  "AZURE-STORAGE-CONNECTION-STRING"
23
22
  ).value
24
- self.container_name = container_name
25
23
 
26
- self.blob_service_client = self._get_blob_service_client()
27
- self.container_client = self._get_container_client(
28
- blob_service_client=self.blob_service_client
24
+ if storage_connection_string is None:
25
+ raise RuntimeError("AZURE-STORAGE-CONNECTION-STRING from keyvault is None")
26
+
27
+ try:
28
+ blob_service_client = BlobServiceClient.from_connection_string(
29
+ storage_connection_string
30
+ )
31
+ except Exception as e:
32
+ self.logger.error("Unable to retrieve blob service client. Error: %s", e)
33
+ raise e
34
+
35
+ self.container_client = blob_service_client.get_container_client(
36
+ settings.BLOB_CONTAINER
29
37
  )
30
38
 
31
- self.logger = logging.getLogger("uploader")
39
+ if not self.container_client.exists():
40
+ raise RuntimeError(
41
+ "The configured blob container %s does not exist",
42
+ settings.BLOB_CONTAINER,
43
+ )
44
+
45
+ def store(self, inspection: InspectionBlob, mission: Mission) -> Union[str, dict]:
46
+ if inspection.data is None:
47
+ raise StorageException("Nothing to store. The inspection data is empty")
32
48
 
33
- def store(self, inspection: Inspection, mission: Mission) -> Union[str, dict]:
34
49
  data_path, metadata_path = construct_paths(
35
50
  inspection=inspection, mission=mission
36
51
  )
@@ -43,7 +58,7 @@ class BlobStorage(StorageInterface):
43
58
  return self._upload_file(path=data_path, data=inspection.data)
44
59
 
45
60
  def _upload_file(self, path: Path, data: bytes) -> Union[str, dict]:
46
- blob_client = self._get_blob_client(path)
61
+ blob_client = self.container_client.get_blob_client(path.as_posix())
47
62
  try:
48
63
  blob_client.upload_blob(data=data)
49
64
  except ResourceExistsError as e:
@@ -62,20 +77,3 @@ class BlobStorage(StorageInterface):
62
77
  "blob_name": blob_client.blob_name,
63
78
  }
64
79
  return absolute_inspection_path
65
-
66
- def _get_blob_service_client(self) -> BlobServiceClient:
67
- try:
68
- return BlobServiceClient.from_connection_string(
69
- self.storage_connection_string
70
- )
71
- except Exception as e:
72
- self.logger.error("Unable to retrieve blob service client. Error: %s", e)
73
- raise e
74
-
75
- def _get_container_client(
76
- self, blob_service_client: BlobServiceClient
77
- ) -> ContainerClient:
78
- return blob_service_client.get_container_client(self.container_name)
79
-
80
- def _get_blob_client(self, path_to_blob: Path) -> BlobClient:
81
- return self.container_client.get_blob_client(path_to_blob.as_posix())
@@ -4,7 +4,7 @@ from pathlib import Path
4
4
  from isar.config.settings import settings
5
5
  from isar.storage.storage_interface import StorageException, StorageInterface
6
6
  from isar.storage.utilities import construct_metadata_file, construct_paths
7
- from robot_interface.models.inspection.inspection import Inspection
7
+ from robot_interface.models.inspection.inspection import InspectionBlob
8
8
  from robot_interface.models.mission.mission import Mission
9
9
 
10
10
 
@@ -13,7 +13,10 @@ class LocalStorage(StorageInterface):
13
13
  self.root_folder: Path = Path(settings.LOCAL_STORAGE_PATH)
14
14
  self.logger = logging.getLogger("uploader")
15
15
 
16
- def store(self, inspection: Inspection, mission: Mission) -> str:
16
+ def store(self, inspection: InspectionBlob, mission: Mission) -> str:
17
+ if inspection.data is None:
18
+ raise StorageException("Nothing to store. The inspection data is empty")
19
+
17
20
  local_path, local_metadata_path = construct_paths(
18
21
  inspection=inspection, mission=mission
19
22
  )
@@ -1,19 +1,19 @@
1
1
  from abc import ABCMeta, abstractmethod
2
2
  from typing import Union
3
3
 
4
- from robot_interface.models.inspection.inspection import Inspection
4
+ from robot_interface.models.inspection.inspection import InspectionBlob
5
5
  from robot_interface.models.mission.mission import Mission
6
6
 
7
7
 
8
8
  class StorageInterface(metaclass=ABCMeta):
9
9
  @abstractmethod
10
- def store(self, inspection: Inspection, mission: Mission) -> Union[str, dict]:
10
+ def store(self, inspection: InspectionBlob, mission: Mission) -> Union[str, dict]:
11
11
  """
12
12
  Parameters
13
13
  ----------
14
14
  mission : Mission
15
15
  Mission the inspection is a part of.
16
- inspection : Inspection
16
+ inspection : InspectionBlob
17
17
  The inspection object to be stored.
18
18
 
19
19
  Returns
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: isar
3
- Version: 1.32.1
3
+ Version: 1.32.3
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
@@ -157,6 +157,10 @@ def test_state_machine_failed_dependency(
157
157
  States.Monitor,
158
158
  States.AwaitNextMission,
159
159
  States.ReturningHome,
160
+ States.ReturningHome,
161
+ States.ReturningHome,
162
+ States.ReturningHome,
163
+ States.ReturningHome,
160
164
  States.InterventionNeeded,
161
165
  ]
162
166
  )
@@ -478,6 +482,81 @@ def test_state_machine_with_mission_start_during_return_home_without_queueing_st
478
482
  )
479
483
 
480
484
 
485
+ def test_state_machine_with_return_home_failure_successful_retries(
486
+ container: ApplicationContainer,
487
+ mocker: MockerFixture,
488
+ state_machine_thread: StateMachineThreadMock,
489
+ robot_service_thread: RobotServiceThreadMock,
490
+ ) -> None:
491
+ state_machine_thread.state_machine.await_next_mission_state.timers[
492
+ 0
493
+ ].timeout_in_seconds = 0.01
494
+ scheduling_utilities: SchedulingUtilities = container.scheduling_utilities()
495
+ state_machine_thread.start()
496
+ mocker.patch.object(StubRobot, "robot_status", return_value=RobotStatus.Available)
497
+ mocker.patch.object(
498
+ StubRobot, "task_status", side_effect=[TaskStatus.Failed, TaskStatus.Successful]
499
+ )
500
+ robot_service_thread.start()
501
+
502
+ scheduling_utilities.return_home()
503
+ time.sleep(3) # Allow enough time to run mission and return home
504
+
505
+ assert state_machine_thread.state_machine.transitions_list == deque(
506
+ [
507
+ States.UnknownStatus,
508
+ States.RobotStandingStill,
509
+ States.ReturningHome,
510
+ States.ReturningHome,
511
+ States.Home,
512
+ States.RobotStandingStill,
513
+ ]
514
+ )
515
+
516
+
517
+ def test_state_machine_with_return_home_failure_unsuccessful_retries_twice(
518
+ container: ApplicationContainer,
519
+ mocker: MockerFixture,
520
+ state_machine_thread: StateMachineThreadMock,
521
+ robot_service_thread: RobotServiceThreadMock,
522
+ ) -> None:
523
+ state_machine_thread.state_machine.await_next_mission_state.timers[
524
+ 0
525
+ ].timeout_in_seconds = 0.01
526
+ scheduling_utilities: SchedulingUtilities = container.scheduling_utilities()
527
+ state_machine_thread.start()
528
+ mocker.patch.object(StubRobot, "robot_status", return_value=RobotStatus.Available)
529
+ mocker.patch.object(StubRobot, "task_status", return_value=TaskStatus.Failed)
530
+ robot_service_thread.start()
531
+
532
+ scheduling_utilities.return_home()
533
+ time.sleep(3) # Allow enough time to run mission and return home
534
+ scheduling_utilities.release_intervention_needed()
535
+ scheduling_utilities.return_home()
536
+ time.sleep(3) # Allow enough time to run mission and return home
537
+
538
+ assert state_machine_thread.state_machine.transitions_list == deque(
539
+ [
540
+ States.UnknownStatus,
541
+ States.RobotStandingStill,
542
+ States.ReturningHome,
543
+ States.ReturningHome,
544
+ States.ReturningHome,
545
+ States.ReturningHome,
546
+ States.ReturningHome,
547
+ States.InterventionNeeded,
548
+ States.UnknownStatus,
549
+ States.RobotStandingStill,
550
+ States.ReturningHome,
551
+ States.ReturningHome,
552
+ States.ReturningHome,
553
+ States.ReturningHome,
554
+ States.ReturningHome,
555
+ States.InterventionNeeded,
556
+ ]
557
+ )
558
+
559
+
481
560
  def test_state_machine_offline_to_robot_standing_still(
482
561
  state_machine_thread, robot_service_thread, mocker
483
562
  ) -> None:
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