isar 1.24.1__py3-none-any.whl → 1.24.2__py3-none-any.whl

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.

@@ -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
@@ -7,7 +7,7 @@ isar/apis/models/__init__.py,sha256=NI1BYyN__Ogr00Qqe0XJ-9gEVPva2brXo2RJsbrS4tM,
7
7
  isar/apis/models/models.py,sha256=6E8VhGBti6EKJefYTDNVERxRu_g_omg4J2MriPUPkaw,1709
8
8
  isar/apis/models/start_mission_definition.py,sha256=oY2CRKNkf4DQys0lbz-WTib1Ppw_OUwHqhBTrBhUJQk,8044
9
9
  isar/apis/schedule/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
10
- isar/apis/schedule/scheduling_controller.py,sha256=GXjvkF4OPRJTWzQEvvxbKc79x2X2uzqbl1ZOv_-9Fpw,11508
10
+ isar/apis/schedule/scheduling_controller.py,sha256=JbVF0kvGACqc0Pgbt5DLsiXkRx4WWPiAZnYlHUrAHz0,11419
11
11
  isar/apis/security/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
12
12
  isar/apis/security/authentication.py,sha256=TI8U9Y_L6ihHLMeM50ZONd5EPfuHdw_XMU_Q987W4AY,1975
13
13
  isar/config/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -67,13 +67,13 @@ isar/services/utilities/queue_utilities.py,sha256=Pw3hehSwkXJNeDv-bDVDfs58VOwtt3
67
67
  isar/services/utilities/scheduling_utilities.py,sha256=UUMxhudY2mQRG6Edjq6BG7oxwlqmcu5h6fMyw4Vhl_o,8376
68
68
  isar/services/utilities/threaded_request.py,sha256=py4G-_RjnIdHljmKFAcQ6ddqMmp-ZYV39Ece-dqRqjs,1874
69
69
  isar/state_machine/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
70
- isar/state_machine/state_machine.py,sha256=A7qAaXEnErmPQ7--sM7w9VabceS0qJOProlmwMb9iaU,21299
70
+ isar/state_machine/state_machine.py,sha256=ceH0WiQNVMYIe7mVuH62L7OPPGrj1Qx2FuToIYBRQlk,21820
71
71
  isar/state_machine/states_enum.py,sha256=BlrUcBWkM5K6D_UZXRwTaUgGpAagWmVZH6HhDBGzVU4,278
72
72
  isar/state_machine/states/__init__.py,sha256=kErbKPDTwNfCLijvdyN6_AuOqDwR23nu9F0Qovsnir4,218
73
- isar/state_machine/states/idle.py,sha256=TVUVtoFwe3-InO4tEupa1_MNG3bviLuMxmHV7FX7Js0,3076
73
+ isar/state_machine/states/idle.py,sha256=wKEG3QzmEO3MfFCwbh9vBRZin3sby_cwXhm85Fke9-s,3224
74
74
  isar/state_machine/states/initialize.py,sha256=TVXV5Ps3N4_flM88j9pQiX88kZgLzLwzlJy_6hPbgcA,2359
75
75
  isar/state_machine/states/initiate.py,sha256=j1wvSC3zVODgRkKOVsQROiuWkjihSBtwCs5GsoivLvc,5655
76
- isar/state_machine/states/monitor.py,sha256=4gCSf_FpHcxPiaaAuOJ5Tqhw79kqcaY5e_fg0nmA83I,9578
76
+ isar/state_machine/states/monitor.py,sha256=bcrLKftME7tWUGCwx_wj6myZToD4BBJT3jq9WMbpd0w,9874
77
77
  isar/state_machine/states/off.py,sha256=jjqN_oJMpBtWuY7hP-c9f0w3p2CYCfe-NpmYHHPnmyI,544
78
78
  isar/state_machine/states/offline.py,sha256=IfEZ6-kl6OfJSRT1eKHOey7AU23tKiSHqpwGqclmH_c,2166
79
79
  isar/state_machine/states/paused.py,sha256=TIg1iJvAxGUIfzE_qWp0wrq4Ka0a3zEf3GNwIWLIK0M,1177
@@ -108,9 +108,9 @@ robot_interface/telemetry/payloads.py,sha256=FafpIwsOvcTNtaBZqyOX7r5EjG7nZ2uLNhy
108
108
  robot_interface/utilities/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
109
109
  robot_interface/utilities/json_service.py,sha256=nU2Q_3P9Fq9hs6F_wtUjWtHfl_g1Siy-yDhXXSKwHwg,1018
110
110
  robot_interface/utilities/uuid_string_factory.py,sha256=_NQIbBQ56w0qqO0MUDP6aPpHbxW7ATRhK8HnQiBSLkc,76
111
- isar-1.24.1.dist-info/LICENSE,sha256=3fc2-ebLwHWwzfQbulGNRdcNob3SBQeCfEVUDYxsuqw,14058
112
- isar-1.24.1.dist-info/METADATA,sha256=pwUuwsVvZLQpkRAeB0Fp4pN57jatvgLN58n4JgLLWDA,30661
113
- isar-1.24.1.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
114
- isar-1.24.1.dist-info/entry_points.txt,sha256=TFam7uNNw7J0iiDYzsH2gfG0u1eV1wh3JTw_HkhgKLk,49
115
- isar-1.24.1.dist-info/top_level.txt,sha256=UwIML2RtuQKCyJJkatcSnyp6-ldDjboB9k9JgKipO-U,21
116
- isar-1.24.1.dist-info/RECORD,,
111
+ isar-1.24.2.dist-info/LICENSE,sha256=3fc2-ebLwHWwzfQbulGNRdcNob3SBQeCfEVUDYxsuqw,14058
112
+ isar-1.24.2.dist-info/METADATA,sha256=Rh1FBaPlouwNa4sbVMC_qL66uHwrTzkGBrUsbx61WuI,30661
113
+ isar-1.24.2.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
114
+ isar-1.24.2.dist-info/entry_points.txt,sha256=TFam7uNNw7J0iiDYzsH2gfG0u1eV1wh3JTw_HkhgKLk,49
115
+ isar-1.24.2.dist-info/top_level.txt,sha256=UwIML2RtuQKCyJJkatcSnyp6-ldDjboB9k9JgKipO-U,21
116
+ isar-1.24.2.dist-info/RECORD,,
File without changes
File without changes