Skip to content

Commit

Permalink
chore: update execute_api to accept querry parameters
Browse files Browse the repository at this point in the history
  • Loading branch information
rrkumarshikhar committed Oct 21, 2024
1 parent 39d9033 commit 46e8c6e
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 11 deletions.
14 changes: 7 additions & 7 deletions rapyuta_io/clients/device.py
Original file line number Diff line number Diff line change
Expand Up @@ -305,10 +305,10 @@ def validate(name, runtime, runtime_docker, runtime_preinstalled, ros_distro, ro
if description is not None and not isinstance(description, six.string_types):
raise InvalidParameterException('description must be of type string')

def _execute_api(self, url, request_method=HttpMethod.GET, payload=None, retry_limit=0):
def _execute_api(self, url, request_method=HttpMethod.GET, payload=None, retry_limit=0, query=None):
headers = create_auth_header(self._auth_token, self._project)
headers['Content-Type'] = 'application/json'
rest_client = RestClient(url).method(request_method).headers(headers)
rest_client = RestClient(url).method(request_method).headers(headers).query_param(query)
response = rest_client.retry(retry_limit).execute(payload=payload)
return response

Expand Down Expand Up @@ -575,9 +575,10 @@ def fetch_command_result(self, jid: str, deviceids: list, timeout: int, interval
"""
Fetch the result of the command execution using the job ID (jid) and the first device ID from the list.
Args:
jobid (str): The job ID of the executed command.
jid (str): The job ID of the executed command.
deviceids (list): A list of device IDs on which the command was executed.
timeout (int): The maximum time to wait for the result (in seconds). Default is 300 seconds.
interval (int): time interval for retry
Returns:
dict: The result of the command execution.
Raises:
Expand All @@ -587,15 +588,14 @@ def fetch_command_result(self, jid: str, deviceids: list, timeout: int, interval

if not deviceids or not isinstance(deviceids, list):
raise ValueError("Device IDs must be provided as a non-empty list.")
url = self._device_api_host + DEVICE_COMMAND_API_PATH + "jobid"
payload = {
"jid": jid,
url = self._device_api_host + DEVICE_COMMAND_API_PATH + jid
query = {
"device_id": deviceids[0]
}
time_elapsed = 0
wait_interval = interval
while time_elapsed < timeout:
response = self._execute_api(url, HttpMethod.POST, payload)
response = self._execute_api(url, HttpMethod.GET, query=query)
if response.status_code == requests.codes.OK:
result = get_api_response_data(response)
return result[deviceids[0]]
Expand Down
8 changes: 4 additions & 4 deletions tests/device_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -733,7 +733,7 @@ def test_onboard_script_dockercompose_success(self, mock_request):
temp_header['Content-Type'] = 'application/json'

mock_request.assert_called_once_with(
url=expected_onboard_script_url, method='GET', headers=temp_header, params={}, json=None)
url=expected_onboard_script_url, method='GET', headers=temp_header, params=None, json=None)
self.assertEqual(onboard_script.url, 'https://gaapiserver.apps.okd4v2.prod.rapyuta.io/start')
self.assertEqual(onboard_script.command, 'sudo bash start -r dockercompose -d melodic -b test/path')
self.assertEqual(onboard_script.token, 'sample-token')
Expand Down Expand Up @@ -762,7 +762,7 @@ def test_onboard_script_preinstalled_success(self, mock_request):
temp_header['Content-Type'] = 'application/json'

mock_request.assert_called_once_with(
url=expected_onboard_script_url, method='GET', headers=temp_header, params={}, json=None)
url=expected_onboard_script_url, method='GET', headers=temp_header, params=None, json=None)
self.assertEqual(onboard_script.url, 'https://gaapiserver.apps.okd4v2.prod.rapyuta.io/start')
self.assertEqual(onboard_script.command, 'sudo bash start -r preinstalled -w test/path')
self.assertEqual(onboard_script.token, 'sample-token')
Expand Down Expand Up @@ -792,7 +792,7 @@ def test_onboard_script_both_runtimes_success(self, mock_request):
temp_header['Content-Type'] = 'application/json'

mock_request.assert_called_once_with(
url=expected_onboard_script_url, method='GET', headers=temp_header, params={}, json=None)
url=expected_onboard_script_url, method='GET', headers=temp_header, params=None, json=None)
self.assertEqual(onboard_script.url, 'https://gaapiserver.apps.okd4v2.prod.rapyuta.io/start')
self.assertEqual(onboard_script.command, 'sudo bash start -r dockercompose -d melodic -b test/path -r '
'preinstalled')
Expand Down Expand Up @@ -869,7 +869,7 @@ def test_upgrade_device_dockercompose_success(self, mock_request):
temp_header['Content-Type'] = 'application/json'

mock_request.assert_called_once_with(
url=expected_upgrade_device_url, method='PUT', headers=temp_header, params={}, json=None)
url=expected_upgrade_device_url, method='PUT', headers=temp_header, params=None, json=None)

@patch('requests.request')
def test_upgrade_device_not_found(self, mock_request):
Expand Down

0 comments on commit 46e8c6e

Please sign in to comment.