Clone of official tools
Diff: test/build_api/build_api_test.py
- Revision:
- 36:96847d42f010
- Parent:
- 35:da9c89f8be7d
- Child:
- 37:f8cfeb185c30
--- a/test/build_api/build_api_test.py Wed Feb 15 13:53:18 2017 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,219 +0,0 @@ -""" -mbed SDK -Copyright (c) 2016 ARM Limited - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - -http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -""" - -import unittest -from collections import namedtuple -from mock import patch, MagicMock -from tools.build_api import prepare_toolchain, build_project, build_library,\ - scan_resources - -""" -Tests for build_api.py -""" - -class BuildApiTests(unittest.TestCase): - """ - Test cases for Build Api - """ - - def setUp(self): - """ - Called before each test case - - :return: - """ - self.target = "K64F" - self.src_paths = ['.'] - self.toolchain_name = "ARM" - self.build_path = "build_path" - - def tearDown(self): - """ - Called after each test case - - :return: - """ - pass - - @patch('tools.toolchains.arm.ARM_STD.parse_dependencies', - return_value=["foo"]) - @patch('tools.toolchains.mbedToolchain.need_update', - side_effect=[i % 2 for i in range(3000)]) - @patch('os.mkdir') - @patch('tools.toolchains.exists', return_value=True) - @patch('tools.utils.run_cmd', return_value=("", "", 0)) - def test_always_complete_build(self, *_): - with MagicMock() as notify: - toolchain = prepare_toolchain(self.src_paths, self.target, - self.toolchain_name, notify=notify) - - res = scan_resources(self.src_paths, toolchain) - - toolchain.RESPONSE_FILES=False - toolchain.config_processed = True - toolchain.config_file = "junk" - toolchain.compile_sources(res, self.build_path) - - assert any('percent' in msg[0] and msg[0]['percent'] == 100.0 - for _, msg, _ in notify.mock_calls if msg) - - - @patch('tools.build_api.Config') - def test_prepare_toolchain_app_config(self, mock_config_init): - """ - Test that prepare_toolchain uses app_config correctly - - :param mock_config_init: mock of Config __init__ - :return: - """ - app_config = "app_config" - mock_config_init.return_value = namedtuple("Config", "target")( - namedtuple("Target", - "init_hooks name features core")(lambda _, __ : None, - "Junk", [], "Cortex-M3")) - - prepare_toolchain(self.src_paths, self.target, self.toolchain_name, - app_config=app_config) - - mock_config_init.assert_called_once_with(self.target, self.src_paths, - app_config=app_config) - - @patch('tools.build_api.Config') - def test_prepare_toolchain_no_app_config(self, mock_config_init): - """ - Test that prepare_toolchain correctly deals with no app_config - - :param mock_config_init: mock of Config __init__ - :return: - """ - mock_config_init.return_value = namedtuple("Config", "target")( - namedtuple("Target", - "init_hooks name features core")(lambda _, __ : None, - "Junk", [], "Cortex-M3")) - - prepare_toolchain(self.src_paths, self.target, self.toolchain_name) - - mock_config_init.assert_called_once_with(self.target, self.src_paths, - app_config=None) - - @patch('tools.build_api.scan_resources') - @patch('tools.build_api.mkdir') - @patch('os.path.exists') - @patch('tools.build_api.prepare_toolchain') - def test_build_project_app_config(self, mock_prepare_toolchain, mock_exists, _, __): - """ - Test that build_project uses app_config correctly - - :param mock_prepare_toolchain: mock of function prepare_toolchain - :param mock_exists: mock of function os.path.exists - :param _: mock of function mkdir (not tested) - :param __: mock of function scan_resources (not tested) - :return: - """ - app_config = "app_config" - mock_exists.return_value = False - mock_prepare_toolchain().link_program.return_value = 1, 2 - - build_project(self.src_paths, self.build_path, self.target, - self.toolchain_name, app_config=app_config) - - args = mock_prepare_toolchain.call_args - self.assertTrue('app_config' in args[1], - "prepare_toolchain was not called with app_config") - self.assertEqual(args[1]['app_config'], app_config, - "prepare_toolchain was called with an incorrect app_config") - - @patch('tools.build_api.scan_resources') - @patch('tools.build_api.mkdir') - @patch('os.path.exists') - @patch('tools.build_api.prepare_toolchain') - def test_build_project_no_app_config(self, mock_prepare_toolchain, mock_exists, _, __): - """ - Test that build_project correctly deals with no app_config - - :param mock_prepare_toolchain: mock of function prepare_toolchain - :param mock_exists: mock of function os.path.exists - :param _: mock of function mkdir (not tested) - :param __: mock of function scan_resources (not tested) - :return: - """ - mock_exists.return_value = False - # Needed for the unpacking of the returned value - mock_prepare_toolchain().link_program.return_value = 1, 2 - - build_project(self.src_paths, self.build_path, self.target, - self.toolchain_name) - - args = mock_prepare_toolchain.call_args - self.assertTrue('app_config' in args[1], - "prepare_toolchain was not called with app_config") - self.assertEqual(args[1]['app_config'], None, - "prepare_toolchain was called with an incorrect app_config") - - @patch('tools.build_api.scan_resources') - @patch('tools.build_api.mkdir') - @patch('os.path.exists') - @patch('tools.build_api.prepare_toolchain') - def test_build_library_app_config(self, mock_prepare_toolchain, mock_exists, _, __): - """ - Test that build_library uses app_config correctly - - :param mock_prepare_toolchain: mock of function prepare_toolchain - :param mock_exists: mock of function os.path.exists - :param _: mock of function mkdir (not tested) - :param __: mock of function scan_resources (not tested) - :return: - """ - app_config = "app_config" - mock_exists.return_value = False - - build_library(self.src_paths, self.build_path, self.target, - self.toolchain_name, app_config=app_config) - - args = mock_prepare_toolchain.call_args - self.assertTrue('app_config' in args[1], - "prepare_toolchain was not called with app_config") - self.assertEqual(args[1]['app_config'], app_config, - "prepare_toolchain was called with an incorrect app_config") - - @patch('tools.build_api.scan_resources') - @patch('tools.build_api.mkdir') - @patch('os.path.exists') - @patch('tools.build_api.prepare_toolchain') - def test_build_library_no_app_config(self, mock_prepare_toolchain, mock_exists, _, __): - """ - Test that build_library correctly deals with no app_config - - :param mock_prepare_toolchain: mock of function prepare_toolchain - :param mock_exists: mock of function os.path.exists - :param _: mock of function mkdir (not tested) - :param __: mock of function scan_resources (not tested) - :return: - """ - mock_exists.return_value = False - - build_library(self.src_paths, self.build_path, self.target, - self.toolchain_name) - - args = mock_prepare_toolchain.call_args - self.assertTrue('app_config' in args[1], - "prepare_toolchain was not called with app_config") - self.assertEqual(args[1]['app_config'], None, - "prepare_toolchain was called with an incorrect app_config") - -if __name__ == '__main__': - unittest.main()