aboutsummaryrefslogtreecommitdiff
path: root/tests/test_utils_types.py
diff options
context:
space:
mode:
authorBenjamin Klimczak <benjamin.klimczak@arm.com>2022-07-11 12:33:42 +0100
committerBenjamin Klimczak <benjamin.klimczak@arm.com>2022-07-26 14:08:21 +0100
commit5d81f37de09efe10f90512e50252be9c36925fcf (patch)
treeb4d7cdfd051da0a6e882bdfcf280fd7ca7b39e57 /tests/test_utils_types.py
parent7899b908c1fe6d86b92a80f3827ddd0ac05b674b (diff)
downloadmlia-5d81f37de09efe10f90512e50252be9c36925fcf.tar.gz
MLIA-551 Rework remains of AIET architecture
Re-factoring the code base to further merge the old AIET code into MLIA. - Remove last traces of the backend type 'tool' - Controlled systems removed, including SSH protocol, controller, RunningCommand, locks etc. - Build command / build dir and deploy functionality removed from Applications and Systems - Moving working_dir() - Replace module 'output_parser' with new module 'output_consumer' and merge Base64 parsing into it - Change the output consumption to optionally remove (i.e. actually consume) lines - Use Base64 parsing in GenericInferenceOutputParser, replacing the regex-based parsing and remove the now unused regex parsing - Remove AIET reporting - Pre-install applications by moving them to src/mlia/resources/backends - Rename aiet-config.json to backend-config.json - Move tests from tests/mlia/ to tests/ - Adapt unit tests to code changes - Dependencies removed: paramiko, filelock, psutil - Fix bug in corstone.py: The wrong resource directory was used which broke the functionality to download backends. - Use f-string formatting. - Use logging instead of print. Change-Id: I768bc3bb6b2eda57d219ad01be4a8e0a74167d76
Diffstat (limited to 'tests/test_utils_types.py')
-rw-r--r--tests/test_utils_types.py77
1 files changed, 77 insertions, 0 deletions
diff --git a/tests/test_utils_types.py b/tests/test_utils_types.py
new file mode 100644
index 0000000..4909efe
--- /dev/null
+++ b/tests/test_utils_types.py
@@ -0,0 +1,77 @@
+# SPDX-FileCopyrightText: Copyright 2022, Arm Limited and/or its affiliates.
+# SPDX-License-Identifier: Apache-2.0
+"""Tests for the types related utility functions."""
+from typing import Any
+from typing import Iterable
+from typing import Optional
+
+import pytest
+
+from mlia.utils.types import is_list_of
+from mlia.utils.types import is_number
+from mlia.utils.types import only_one_selected
+from mlia.utils.types import parse_int
+
+
+@pytest.mark.parametrize(
+ "value, expected_result",
+ [
+ ["", False],
+ ["abc", False],
+ ["123", True],
+ ["123.1", True],
+ ["-123", True],
+ ["-123.1", True],
+ ["0", True],
+ ["1.e10", True],
+ ],
+)
+def test_is_number(value: str, expected_result: bool) -> None:
+ """Test function is_number."""
+ assert is_number(value) == expected_result
+
+
+@pytest.mark.parametrize(
+ "data, cls, elem_num, expected_result",
+ [
+ [(1, 2), int, 2, True],
+ [[1, 2], int, 2, True],
+ [[1, 2], int, 3, False],
+ [["1", "2", "3"], str, None, True],
+ [["1", "2", "3"], int, None, False],
+ ],
+)
+def test_is_list(
+ data: Any, cls: type, elem_num: Optional[int], expected_result: bool
+) -> None:
+ """Test function is_list."""
+ assert is_list_of(data, cls, elem_num) == expected_result
+
+
+@pytest.mark.parametrize(
+ "options, expected_result",
+ [
+ [[True], True],
+ [[False], False],
+ [[True, True, False, False], False],
+ ],
+)
+def test_only_one_selected(options: Iterable[bool], expected_result: bool) -> None:
+ """Test function only_one_selected."""
+ assert only_one_selected(*options) == expected_result
+
+
+@pytest.mark.parametrize(
+ "value, default, expected_int",
+ [
+ ["1", None, 1],
+ ["abc", 123, 123],
+ [None, None, None],
+ [None, 11, 11],
+ ],
+)
+def test_parse_int(
+ value: Any, default: Optional[int], expected_int: Optional[int]
+) -> None:
+ """Test function parse_int."""
+ assert parse_int(value, default) == expected_int