From 5d81f37de09efe10f90512e50252be9c36925fcf Mon Sep 17 00:00:00 2001 From: Benjamin Klimczak Date: Mon, 11 Jul 2022 12:33:42 +0100 Subject: 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 --- tests/test_core_advisor.py | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 tests/test_core_advisor.py (limited to 'tests/test_core_advisor.py') diff --git a/tests/test_core_advisor.py b/tests/test_core_advisor.py new file mode 100644 index 0000000..375ff62 --- /dev/null +++ b/tests/test_core_advisor.py @@ -0,0 +1,40 @@ +# SPDX-FileCopyrightText: Copyright 2022, Arm Limited and/or its affiliates. +# SPDX-License-Identifier: Apache-2.0 +"""Tests for module advisor.""" +from unittest.mock import MagicMock + +from mlia.core.advisor import InferenceAdvisor +from mlia.core.context import Context +from mlia.core.workflow import WorkflowExecutor + + +def test_inference_advisor_run() -> None: + """Test running sample inference advisor.""" + executor_mock = MagicMock(spec=WorkflowExecutor) + context_mock = MagicMock(spec=Context) + + class SampleAdvisor(InferenceAdvisor): + """Sample inference advisor.""" + + @classmethod + def name(cls) -> str: + """Return name of the advisor.""" + return "sample_advisor" + + @classmethod + def description(cls) -> str: + """Return description of the advisor.""" + return "Sample advisor" + + @classmethod + def info(cls) -> None: + """Print advisor info.""" + + def configure(self, context: Context) -> WorkflowExecutor: + """Configure advisor.""" + return executor_mock + + advisor = SampleAdvisor() + advisor.run(context_mock) + + executor_mock.run.assert_called_once() -- cgit v1.2.1