Unify configuration testing and the travis command

pull/4984/head
Jimmy Brisson 2017-08-28 15:10:50 -05:00
parent de9f9dd3a2
commit 817eb5ab05
102 changed files with 215 additions and 266 deletions

View File

@ -19,9 +19,7 @@ script:
- | - |
find -name "*.s" | tee BUILD/badasm | sed -e "s/^/Bad Assembler file name found: /" && [ ! -s BUILD/badasm ] find -name "*.s" | tee BUILD/badasm | sed -e "s/^/Bad Assembler file name found: /" && [ ! -s BUILD/badasm ]
- make -C events/equeue test clean - 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 -m pytest tools/test
- PYTHONPATH=. coverage run tools/test/build_api/build_api_test.py
- PYTHONPATH=. coverage run tools/test/targets/target_test.py
- coverage run tools/test/pylint.py - coverage run tools/test/pylint.py
- coverage run tools/project.py -S - coverage run tools/project.py -S
- coverage run tools/build_travis.py - coverage run tools/build_travis.py

View File

@ -1,6 +1,6 @@
""" """
mbed SDK mbed SDK
Copyright (c) 2016 ARM Limited Copyright (c) 2011-2016 ARM Limited
Licensed under the Apache License, Version 2.0 (the "License"); Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with 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. limitations under the License.
""" """
import os.path import os
import unittest import sys
import json
import pytest
from mock import patch 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
""" # Compare the output of config against a dictionary of known good results
Tests for config.py 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:
""" """
set_targets_json_location()
def setUp(self): with patch.object(Config, '_process_config_and_overrides'),\
""" patch('tools.config.json_file_to_dict') as mock_json_file_to_dict:
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:
"""
app_config = "app_config" app_config = "app_config"
mock_return = {'config': 'test'} mock_return = {'config': {'test': False}}
mock_json_file_to_dict.return_value = mock_return 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) mock_json_file_to_dict.assert_called_with(app_config)
self.assertEqual(config.app_config_data, mock_return, assert config.app_config_data == mock_return
"app_config_data should be set to the returned value")
@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 @pytest.mark.parametrize("target", ["K64F"])
:param _: patch of function _process_config_and_overrides (not tested) def test_init_no_app_config(target):
:return: """
""" Test that the initialisation works without app config
config = Config(self.target)
: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() mock_json_file_to_dict.assert_not_called()
self.assertEqual(config.app_config_data, {}, assert config.app_config_data == {}
"app_config_data should be set an empty dictionary")
@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 @pytest.mark.parametrize("target", ["K64F"])
:param _: patch of function _process_config_and_overrides (not tested) def test_init_no_app_config_with_dir(target):
:return: """
""" 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 = '.' directory = '.'
path = os.path.join('.', 'mbed_app.json') 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_json_file_to_dict.return_value = mock_return
mock_isfile.return_value = True mock_isfile.return_value = True
config = Config(self.target, [directory]) config = Config(target, [directory])
mock_isfile.assert_called_with(path) mock_isfile.assert_called_with(path)
mock_json_file_to_dict.assert_called_once_with(path) mock_json_file_to_dict.assert_called_once_with(path)
self.assertEqual(config.app_config_data, mock_return, assert config.app_config_data == mock_return
"app_config_data should be set to the returned value")
@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 @pytest.mark.parametrize("target", ["K64F"])
:param _: patch of function _process_config_and_overrides (not tested) def test_init_override_app_config(target):
:return: """
""" 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" app_config = "app_config"
directory = '.' directory = '.'
mock_return = {'config': 'test'} mock_return = {'config': {'test': False}}
mock_json_file_to_dict.return_value = mock_return 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) mock_json_file_to_dict.assert_called_once_with(app_config)
self.assertEqual(config.app_config_data, mock_return, assert config.app_config_data == mock_return
"app_config_data should be set to the returned value")
if __name__ == '__main__':
unittest.main()

View File

@ -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