mirror of https://github.com/ARMmbed/mbed-os.git
Unify configuration testing and the travis command
parent
de9f9dd3a2
commit
817eb5ab05
|
@ -19,9 +19,7 @@ script:
|
|||
- |
|
||||
find -name "*.s" | tee BUILD/badasm | sed -e "s/^/Bad Assembler file name found: /" && [ ! -s BUILD/badasm ]
|
||||
- make -C events/equeue test clean
|
||||
- PYTHONPATH=. coverage run -m pytest tools/test/config_test/config_test.py tools/test/toolchains/api.py tools/test/memap/memap_test.py
|
||||
- PYTHONPATH=. coverage run tools/test/build_api/build_api_test.py
|
||||
- PYTHONPATH=. coverage run tools/test/targets/target_test.py
|
||||
- PYTHONPATH=. coverage run -m pytest tools/test
|
||||
- coverage run tools/test/pylint.py
|
||||
- coverage run tools/project.py -S
|
||||
- coverage run tools/build_travis.py
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
"""
|
||||
mbed SDK
|
||||
Copyright (c) 2016 ARM Limited
|
||||
Copyright (c) 2011-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.
|
||||
|
@ -15,118 +15,153 @@ See the License for the specific language governing permissions and
|
|||
limitations under the License.
|
||||
"""
|
||||
|
||||
import os.path
|
||||
import unittest
|
||||
import os
|
||||
import sys
|
||||
import json
|
||||
import pytest
|
||||
from mock import patch
|
||||
from tools.config import Config
|
||||
from hypothesis import given
|
||||
from hypothesis.strategies import sampled_from
|
||||
from os.path import join, isfile, dirname, abspath
|
||||
from tools.build_api import get_config
|
||||
from tools.targets import set_targets_json_location, Target, TARGET_NAMES
|
||||
from tools.config import ConfigException, Config
|
||||
|
||||
"""
|
||||
Tests for config.py
|
||||
"""
|
||||
# Compare the output of config against a dictionary of known good results
|
||||
def compare_config(cfg, expected):
|
||||
try:
|
||||
for k in cfg:
|
||||
if cfg[k].value != expected[k]:
|
||||
return "'%s': expected '%s', got '%s'" % (k, expected[k], cfg[k].value)
|
||||
except KeyError:
|
||||
return "Unexpected key '%s' in configuration data" % k
|
||||
for k in expected:
|
||||
if k not in ["expected_macros", "expected_features"] + cfg.keys():
|
||||
return "Expected key '%s' was not found in configuration data" % k
|
||||
return ""
|
||||
|
||||
class ConfigTests(unittest.TestCase):
|
||||
def data_path(path):
|
||||
return join(path, "test_data.json")
|
||||
|
||||
def is_test(path):
|
||||
return isfile(data_path(path))
|
||||
|
||||
root_dir = abspath(dirname(__file__))
|
||||
|
||||
@pytest.mark.parametrize("name", filter(lambda d: is_test(join(root_dir, d)),
|
||||
os.listdir(root_dir)))
|
||||
def test_config(name):
|
||||
test_dir = join(root_dir, name)
|
||||
test_data = json.load(open(data_path(test_dir)))
|
||||
targets_json = os.path.join(test_dir, "targets.json")
|
||||
set_targets_json_location(targets_json if isfile(targets_json) else None)
|
||||
for target, expected in test_data.items():
|
||||
try:
|
||||
cfg, macros, features = get_config(test_dir, target, "GCC_ARM")
|
||||
res = compare_config(cfg, expected)
|
||||
assert not(res), res
|
||||
expected_macros = expected.get("expected_macros", None)
|
||||
expected_features = expected.get("expected_features", None)
|
||||
|
||||
if expected_macros is not None:
|
||||
macros = Config.config_macros_to_macros(macros)
|
||||
assert sorted(expected_macros) == sorted(macros)
|
||||
if expected_features is not None:
|
||||
assert sorted(expected_features) == sorted(features)
|
||||
except ConfigException as e:
|
||||
err_msg = e.message
|
||||
if "exception_msg" not in expected:
|
||||
assert not(err_msg), "Unexpected Error: %s" % e
|
||||
else:
|
||||
assert expected["exception_msg"] in err_msg
|
||||
|
||||
|
||||
@pytest.mark.parametrize("target", ["K64F"])
|
||||
def test_init_app_config(target):
|
||||
"""
|
||||
Test cases for Config class
|
||||
Test that the initialisation correctly uses app_config
|
||||
|
||||
:param mock_json_file_to_dict: mock of function json_file_to_dict
|
||||
:param _: mock of function _process_config_and_overrides (not tested)
|
||||
:return:
|
||||
"""
|
||||
|
||||
def setUp(self):
|
||||
"""
|
||||
Called before each test case
|
||||
|
||||
:return:
|
||||
"""
|
||||
self.target = "K64F"
|
||||
|
||||
def tearDown(self):
|
||||
"""
|
||||
Called after each test case
|
||||
|
||||
:return:
|
||||
"""
|
||||
pass
|
||||
|
||||
@patch.object(Config, '_process_config_and_overrides')
|
||||
@patch('tools.config.json_file_to_dict')
|
||||
def test_init_app_config(self, mock_json_file_to_dict, _):
|
||||
"""
|
||||
Test that the initialisation correctly uses app_config
|
||||
|
||||
:param mock_json_file_to_dict: mock of function json_file_to_dict
|
||||
:param _: mock of function _process_config_and_overrides (not tested)
|
||||
:return:
|
||||
"""
|
||||
set_targets_json_location()
|
||||
with patch.object(Config, '_process_config_and_overrides'),\
|
||||
patch('tools.config.json_file_to_dict') as mock_json_file_to_dict:
|
||||
app_config = "app_config"
|
||||
mock_return = {'config': 'test'}
|
||||
mock_return = {'config': {'test': False}}
|
||||
mock_json_file_to_dict.return_value = mock_return
|
||||
|
||||
config = Config(self.target, app_config=app_config)
|
||||
config = Config(target, app_config=app_config)
|
||||
|
||||
mock_json_file_to_dict.assert_called_with(app_config)
|
||||
self.assertEqual(config.app_config_data, mock_return,
|
||||
"app_config_data should be set to the returned value")
|
||||
assert config.app_config_data == mock_return
|
||||
|
||||
@patch.object(Config, '_process_config_and_overrides')
|
||||
@patch('tools.config.json_file_to_dict')
|
||||
def test_init_no_app_config(self, mock_json_file_to_dict, _):
|
||||
"""
|
||||
Test that the initialisation works without app config
|
||||
|
||||
:param mock_json_file_to_dict: mock of function json_file_to_dict
|
||||
:param _: patch of function _process_config_and_overrides (not tested)
|
||||
:return:
|
||||
"""
|
||||
config = Config(self.target)
|
||||
@pytest.mark.parametrize("target", ["K64F"])
|
||||
def test_init_no_app_config(target):
|
||||
"""
|
||||
Test that the initialisation works without app config
|
||||
|
||||
:param mock_json_file_to_dict: mock of function json_file_to_dict
|
||||
:param _: patch of function _process_config_and_overrides (not tested)
|
||||
:return:
|
||||
"""
|
||||
set_targets_json_location()
|
||||
with patch.object(Config, '_process_config_and_overrides'),\
|
||||
patch('tools.config.json_file_to_dict') as mock_json_file_to_dict:
|
||||
config = Config(target)
|
||||
|
||||
mock_json_file_to_dict.assert_not_called()
|
||||
self.assertEqual(config.app_config_data, {},
|
||||
"app_config_data should be set an empty dictionary")
|
||||
assert config.app_config_data == {}
|
||||
|
||||
@patch.object(Config, '_process_config_and_overrides')
|
||||
@patch('os.path.isfile')
|
||||
@patch('tools.config.json_file_to_dict')
|
||||
def test_init_no_app_config_with_dir(self, mock_json_file_to_dict, mock_isfile, _):
|
||||
"""
|
||||
Test that the initialisation works without app config and with a
|
||||
specified top level directory
|
||||
|
||||
:param mock_json_file_to_dict: mock of function json_file_to_dict
|
||||
:param _: patch of function _process_config_and_overrides (not tested)
|
||||
:return:
|
||||
"""
|
||||
@pytest.mark.parametrize("target", ["K64F"])
|
||||
def test_init_no_app_config_with_dir(target):
|
||||
"""
|
||||
Test that the initialisation works without app config and with a
|
||||
specified top level directory
|
||||
|
||||
:param mock_json_file_to_dict: mock of function json_file_to_dict
|
||||
:param _: patch of function _process_config_and_overrides (not tested)
|
||||
:return:
|
||||
"""
|
||||
set_targets_json_location()
|
||||
with patch.object(Config, '_process_config_and_overrides'),\
|
||||
patch('os.path.isfile') as mock_isfile, \
|
||||
patch('tools.config.json_file_to_dict') as mock_json_file_to_dict:
|
||||
directory = '.'
|
||||
path = os.path.join('.', 'mbed_app.json')
|
||||
mock_return = {'config': 'test'}
|
||||
mock_return = {'config': {'test': False}}
|
||||
mock_json_file_to_dict.return_value = mock_return
|
||||
mock_isfile.return_value = True
|
||||
|
||||
config = Config(self.target, [directory])
|
||||
config = Config(target, [directory])
|
||||
|
||||
mock_isfile.assert_called_with(path)
|
||||
mock_json_file_to_dict.assert_called_once_with(path)
|
||||
self.assertEqual(config.app_config_data, mock_return,
|
||||
"app_config_data should be set to the returned value")
|
||||
assert config.app_config_data == mock_return
|
||||
|
||||
@patch.object(Config, '_process_config_and_overrides')
|
||||
@patch('tools.config.json_file_to_dict')
|
||||
def test_init_override_app_config(self, mock_json_file_to_dict, _):
|
||||
"""
|
||||
Test that the initialisation uses app_config instead of top_level_dir
|
||||
when both are specified
|
||||
|
||||
:param mock_json_file_to_dict: mock of function json_file_to_dict
|
||||
:param _: patch of function _process_config_and_overrides (not tested)
|
||||
:return:
|
||||
"""
|
||||
@pytest.mark.parametrize("target", ["K64F"])
|
||||
def test_init_override_app_config(target):
|
||||
"""
|
||||
Test that the initialisation uses app_config instead of top_level_dir
|
||||
when both are specified
|
||||
|
||||
:param mock_json_file_to_dict: mock of function json_file_to_dict
|
||||
:param _: patch of function _process_config_and_overrides (not tested)
|
||||
:return:
|
||||
"""
|
||||
set_targets_json_location()
|
||||
with patch.object(Config, '_process_config_and_overrides'),\
|
||||
patch('tools.config.json_file_to_dict') as mock_json_file_to_dict:
|
||||
app_config = "app_config"
|
||||
directory = '.'
|
||||
mock_return = {'config': 'test'}
|
||||
mock_return = {'config': {'test': False}}
|
||||
mock_json_file_to_dict.return_value = mock_return
|
||||
|
||||
config = Config(self.target, [directory], app_config=app_config)
|
||||
config = Config(target, [directory], app_config=app_config)
|
||||
|
||||
mock_json_file_to_dict.assert_called_once_with(app_config)
|
||||
self.assertEqual(config.app_config_data, mock_return,
|
||||
"app_config_data should be set to the returned value")
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main()
|
||||
assert config.app_config_data == mock_return
|
||||
|
|
|
@ -1,73 +0,0 @@
|
|||
"""
|
||||
mbed SDK
|
||||
Copyright (c) 2011-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 os
|
||||
import sys
|
||||
import json
|
||||
import pytest
|
||||
from os.path import join, isfile, dirname, abspath
|
||||
from tools.build_api import get_config
|
||||
from tools.targets import set_targets_json_location, Target
|
||||
from tools.config import ConfigException, Config
|
||||
|
||||
# Compare the output of config against a dictionary of known good results
|
||||
def compare_config(cfg, expected):
|
||||
try:
|
||||
for k in cfg:
|
||||
if cfg[k].value != expected[k]:
|
||||
return "'%s': expected '%s', got '%s'" % (k, expected[k], cfg[k].value)
|
||||
except KeyError:
|
||||
return "Unexpected key '%s' in configuration data" % k
|
||||
for k in expected:
|
||||
if k not in ["expected_macros", "expected_features"] + cfg.keys():
|
||||
return "Expected key '%s' was not found in configuration data" % k
|
||||
return ""
|
||||
|
||||
def data_path(path):
|
||||
return join(path, "test_data.json")
|
||||
|
||||
def is_test(path):
|
||||
return isfile(data_path(path))
|
||||
|
||||
root_dir = abspath(dirname(__file__))
|
||||
|
||||
@pytest.mark.parametrize("name", filter(lambda d: is_test(join(root_dir, d)),
|
||||
os.listdir(root_dir)))
|
||||
def test_config(name):
|
||||
test_dir = join(root_dir, name)
|
||||
test_data = json.load(open(data_path(test_dir)))
|
||||
targets_json = os.path.join(test_dir, "targets.json")
|
||||
set_targets_json_location(targets_json if isfile(targets_json) else None)
|
||||
for target, expected in test_data.items():
|
||||
try:
|
||||
cfg, macros, features = get_config(test_dir, target, "GCC_ARM")
|
||||
res = compare_config(cfg, expected)
|
||||
assert not(res), res
|
||||
expected_macros = expected.get("expected_macros", None)
|
||||
expected_features = expected.get("expected_features", None)
|
||||
|
||||
if expected_macros is not None:
|
||||
macros = Config.config_macros_to_macros(macros)
|
||||
assert sorted(expected_macros) == sorted(macros)
|
||||
if expected_features is not None:
|
||||
assert sorted(expected_features) == sorted(features)
|
||||
except ConfigException as e:
|
||||
err_msg = e.message
|
||||
if "exception_msg" not in expected:
|
||||
assert not(err_msg), "Unexpected Error: %s" % e
|
||||
else:
|
||||
assert expected["exception_msg"] in err_msg
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue