Skip to content

Commit

Permalink
device: do not operate on empty or ambiguous device UUIDs
Browse files Browse the repository at this point in the history
Change-type: patch
  • Loading branch information
otaviojacobi committed Oct 15, 2024
1 parent d8fbe7e commit 7f1cf70
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 1 deletion.
17 changes: 16 additions & 1 deletion balena/models/device.py
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,19 @@ def __set(
}
)
else:
if len(uuid_or_id_or_ids) < 6:
raise exceptions.InvalidParameter("UUID must have at least 6 characeters")

affected = self.__pine.get({
"resource": "device",
"options": {
"$top": 2,
"$select": "id",
"$filter": {"uuid": {"$startswith": uuid_or_id_or_ids}}}
})
if len(affected) > 1:
raise exceptions.AmbiguousDevice(uuid_or_id_or_ids)

fn(
{
"resource": "device",
Expand Down Expand Up @@ -359,6 +372,9 @@ def get(self, uuid_or_id: Union[str, int], options: AnyObject = {}) -> TypeDevic
if uuid_or_id is None:
raise exceptions.DeviceNotFound(uuid_or_id)

if len(uuid_or_id) == 0:
raise exceptions.InvalidParameter("UUID can not be empty")

is_potentially_full_uuid = is_full_uuid(uuid_or_id)
if is_potentially_full_uuid or is_id(uuid_or_id):
device = self.__pine.get(
Expand Down Expand Up @@ -576,7 +592,6 @@ def remove(self, uuid_or_id_or_ids: Union[str, int, List[int]]):
Args:
uuid_or_id_or_ids (Union[str, int, List[int]]): device uuid (str) or id (int) or ids (List[int])
"""

self.__set(uuid_or_id_or_ids, body=None, fn=self.__pine.delete)

def deactivate(self, uuid_or_id_or_ids: Union[str, int, List[int]]) -> None:
Expand Down
33 changes: 33 additions & 0 deletions tests/functional/models/test_device.py
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,9 @@ def test_07_get(self):
with self.assertRaises(self.helper.balena_exceptions.DeviceNotFound):
self.balena.models.device.get("999999999999")

with self.assertRaises(self.helper.balena_exceptions.InvalidParameter):
self.balena.models.device.get("")

def test_08_rename(self):
self.balena.models.device.rename(TestDevice.device["uuid"], "test-device")
self.assertEqual(self.balena.models.device.get_name(TestDevice.device["uuid"]), "test-device")
Expand Down Expand Up @@ -369,9 +372,39 @@ def test_30_remove(self):
app_devices_len - 1,
)

uuid = self.balena.models.device.generate_uuid()
self.balena.models.device.register(self.app["id"], uuid)
uuid2 = uuid[:-2] + uuid[-1] + uuid[-2]

self.balena.models.device.register(self.app["id"], uuid2)

device_uuids = [device["uuid"] for device in self.balena.models.device.get_all()]
self.assertIn(uuid, device_uuids)
self.assertIn(uuid2, device_uuids)

with self.assertRaises(self.helper.balena_exceptions.DeviceNotFound):
self.balena.models.device.get(TestDevice.device["uuid"])

with self.assertRaises(self.helper.balena_exceptions.InvalidParameter):
self.balena.models.device.remove("")

with self.assertRaises(self.helper.balena_exceptions.InvalidParameter):
self.balena.models.device.remove("abc")

with self.assertRaises(self.helper.balena_exceptions.AmbiguousDevice):
self.balena.models.device.remove(uuid[0:10])

device_uuids = [device["uuid"] for device in self.balena.models.device.get_all()]
self.assertIn(uuid, device_uuids)
self.assertIn(uuid2, device_uuids)

self.balena.models.device.remove(uuid)
self.balena.models.device.remove(uuid2)

device_uuids = [device["uuid"] for device in self.balena.models.device.get_all()]
self.assertNotIn(uuid, device_uuids)
self.assertNotIn(uuid2, device_uuids)


if __name__ == "__main__":
unittest.main()

0 comments on commit 7f1cf70

Please sign in to comment.