Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Diff: test/build_api/build_api_test.py
- Revision:
- 31:8ea194f6145b
diff -r f12ce67666d0 -r 8ea194f6145b test/build_api/build_api_test.py
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/test/build_api/build_api_test.py Wed Jan 04 11:58:24 2017 -0600
@@ -0,0 +1,219 @@
+"""
+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()