You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1162 lines
61 KiB
1162 lines
61 KiB
#!/usr/bin/env python3
|
|
#
|
|
# Copyright 2018, The Android Open Source Project
|
|
#
|
|
# 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.
|
|
|
|
"""Unittests for module_finder."""
|
|
|
|
# pylint: disable=line-too-long
|
|
# pylint: disable=too-many-lines
|
|
# pylint: disable=unsubscriptable-object
|
|
|
|
import copy
|
|
import re
|
|
import unittest
|
|
import os
|
|
|
|
from unittest import mock
|
|
|
|
import atest_error
|
|
import atest_configs
|
|
import atest_utils
|
|
import constants
|
|
import module_info
|
|
import unittest_constants as uc
|
|
import unittest_utils
|
|
|
|
from test_finders import module_finder
|
|
from test_finders import test_finder_utils
|
|
from test_finders import test_info
|
|
from test_runners import atest_tf_test_runner as atf_tr
|
|
|
|
MODULE_CLASS = '%s:%s' % (uc.MODULE_NAME, uc.CLASS_NAME)
|
|
MODULE_PACKAGE = '%s:%s' % (uc.MODULE_NAME, uc.PACKAGE)
|
|
CC_MODULE_CLASS = '%s:%s' % (uc.CC_MODULE_NAME, uc.CC_CLASS_NAME)
|
|
KERNEL_TEST_CLASS = 'test_class_1'
|
|
KERNEL_TEST_CONFIG = 'KernelTest.xml.data'
|
|
KERNEL_MODULE_CLASS = '%s:%s' % (constants.REQUIRED_KERNEL_TEST_MODULES[0],
|
|
KERNEL_TEST_CLASS)
|
|
KERNEL_CONFIG_FILE = os.path.join(uc.TEST_DATA_DIR, KERNEL_TEST_CONFIG)
|
|
KERNEL_CLASS_FILTER = test_info.TestFilter(KERNEL_TEST_CLASS, frozenset())
|
|
KERNEL_MODULE_CLASS_DATA = {constants.TI_REL_CONFIG: KERNEL_CONFIG_FILE,
|
|
constants.TI_FILTER: frozenset([KERNEL_CLASS_FILTER])}
|
|
KERNEL_MODULE_CLASS_INFO = test_info.TestInfo(
|
|
constants.REQUIRED_KERNEL_TEST_MODULES[0],
|
|
atf_tr.AtestTradefedTestRunner.NAME,
|
|
uc.CLASS_BUILD_TARGETS, KERNEL_MODULE_CLASS_DATA)
|
|
FLAT_METHOD_INFO = test_info.TestInfo(
|
|
uc.MODULE_NAME,
|
|
atf_tr.AtestTradefedTestRunner.NAME,
|
|
uc.MODULE_BUILD_TARGETS,
|
|
data={constants.TI_FILTER: frozenset([uc.FLAT_METHOD_FILTER]),
|
|
constants.TI_REL_CONFIG: uc.CONFIG_FILE})
|
|
MODULE_CLASS_METHOD = '%s#%s' % (MODULE_CLASS, uc.METHOD_NAME)
|
|
CC_MODULE_CLASS_METHOD = '%s#%s' % (CC_MODULE_CLASS, uc.CC_METHOD_NAME)
|
|
CLASS_INFO_MODULE_2 = test_info.TestInfo(
|
|
uc.MODULE2_NAME,
|
|
atf_tr.AtestTradefedTestRunner.NAME,
|
|
uc.CLASS_BUILD_TARGETS,
|
|
data={constants.TI_FILTER: frozenset([uc.CLASS_FILTER]),
|
|
constants.TI_REL_CONFIG: uc.CONFIG2_FILE})
|
|
CC_CLASS_INFO_MODULE_2 = test_info.TestInfo(
|
|
uc.CC_MODULE2_NAME,
|
|
atf_tr.AtestTradefedTestRunner.NAME,
|
|
uc.CLASS_BUILD_TARGETS,
|
|
data={constants.TI_FILTER: frozenset([uc.CC_CLASS_FILTER]),
|
|
constants.TI_REL_CONFIG: uc.CC_CONFIG2_FILE})
|
|
DEFAULT_INSTALL_PATH = ['/path/to/install']
|
|
ROBO_MOD_PATH = ['/shared/robo/path']
|
|
NON_RUN_ROBO_MOD_NAME = 'robo_mod'
|
|
RUN_ROBO_MOD_NAME = 'run_robo_mod'
|
|
NON_RUN_ROBO_MOD = {constants.MODULE_NAME: NON_RUN_ROBO_MOD_NAME,
|
|
constants.MODULE_PATH: ROBO_MOD_PATH,
|
|
constants.MODULE_CLASS: ['random_class']}
|
|
RUN_ROBO_MOD = {constants.MODULE_NAME: RUN_ROBO_MOD_NAME,
|
|
constants.MODULE_PATH: ROBO_MOD_PATH,
|
|
constants.MODULE_CLASS: [constants.MODULE_CLASS_ROBOLECTRIC]}
|
|
|
|
SEARCH_DIR_RE = re.compile(r'^find ([^ ]*).*$')
|
|
|
|
#pylint: disable=unused-argument
|
|
def classoutside_side_effect(find_cmd, shell=False):
|
|
"""Mock the check output of a find cmd where class outside module path."""
|
|
search_dir = SEARCH_DIR_RE.match(find_cmd).group(1).strip()
|
|
if search_dir == uc.ROOT:
|
|
return uc.FIND_ONE
|
|
return None
|
|
|
|
|
|
#pylint: disable=protected-access
|
|
class ModuleFinderUnittests(unittest.TestCase):
|
|
"""Unit tests for module_finder.py"""
|
|
|
|
def setUp(self):
|
|
"""Set up stuff for testing."""
|
|
self.mod_finder = module_finder.ModuleFinder()
|
|
self.mod_finder.module_info = mock.Mock(spec=module_info.ModuleInfo)
|
|
self.mod_finder.module_info.path_to_module_info = {}
|
|
self.mod_finder.root_dir = uc.ROOT
|
|
|
|
def test_is_vts_module(self):
|
|
"""Test _load_module_info_file regular operation."""
|
|
mod_name = 'mod'
|
|
is_vts_module_info = {'compatibility_suites': ['vts10', 'tests']}
|
|
self.mod_finder.module_info.get_module_info.return_value = is_vts_module_info
|
|
self.assertTrue(self.mod_finder._is_vts_module(mod_name))
|
|
|
|
is_not_vts_module = {'compatibility_suites': ['vts10', 'cts']}
|
|
self.mod_finder.module_info.get_module_info.return_value = is_not_vts_module
|
|
self.assertFalse(self.mod_finder._is_vts_module(mod_name))
|
|
|
|
# pylint: disable=unused-argument
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets',
|
|
return_value=copy.deepcopy(uc.MODULE_BUILD_TARGETS))
|
|
def test_find_test_by_module_name(self, _get_targ):
|
|
"""Test find_test_by_module_name."""
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mod_info = {'installed': ['/path/to/install'],
|
|
'path': [uc.MODULE_DIR],
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
t_infos = self.mod_finder.find_test_by_module_name(uc.MODULE_NAME)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self,
|
|
t_infos[0],
|
|
uc.MODULE_INFO)
|
|
self.mod_finder.module_info.get_module_info.return_value = None
|
|
self.mod_finder.module_info.is_testable_module.return_value = False
|
|
self.assertIsNone(self.mod_finder.find_test_by_module_name('Not_Module'))
|
|
|
|
@mock.patch('builtins.input', return_value='1')
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets',
|
|
return_value=copy.deepcopy(uc.MODULE_BUILD_TARGETS))
|
|
def test_find_test_by_module_name_w_multiple_config(
|
|
self, _get_targ, _mock_input):
|
|
"""Test find_test_by_module_name."""
|
|
atest_configs.GLOBAL_ARGS = mock.Mock()
|
|
atest_configs.GLOBAL_ARGS.test_config_select = True
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mod_info = {'installed': ['/path/to/install'],
|
|
'path': [uc.MODULE_DIR],
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: [],
|
|
constants.MODULE_TEST_CONFIG: [
|
|
uc.CONFIG_FILE,
|
|
uc.EXTRA_CONFIG_FILE]}
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
t_infos = self.mod_finder.find_test_by_module_name(uc.MODULE_NAME)
|
|
# Only select one test
|
|
self.assertEqual(len(t_infos), 1)
|
|
# The t_info should be the EXTRA_CONFIG_FILE one.
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.MODULE_INFO_W_CONFIG)
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets',
|
|
return_value=copy.deepcopy(uc.MODULE_BUILD_TARGETS))
|
|
def test_find_test_by_module_name_w_multiple_config_all(
|
|
self, _get_targ,):
|
|
"""Test find_test_by_module_name."""
|
|
atest_configs.GLOBAL_ARGS = mock.Mock()
|
|
atest_configs.GLOBAL_ARGS.test_config_select = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mod_info = {'installed': ['/path/to/install'],
|
|
'path': [uc.MODULE_DIR],
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: [],
|
|
constants.MODULE_TEST_CONFIG: [
|
|
uc.CONFIG_FILE,
|
|
uc.EXTRA_CONFIG_FILE]}
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
t_infos = self.mod_finder.find_test_by_module_name(uc.MODULE_NAME)
|
|
unittest_utils.assert_equal_testinfos(self, t_infos[0], uc.MODULE_INFO)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[1], uc.MODULE_INFO_W_CONFIG)
|
|
|
|
@mock.patch.object(test_finder_utils, 'find_host_unit_tests',
|
|
return_value=[])
|
|
@mock.patch.object(atest_utils, 'is_build_file', return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'is_parameterized_java_class',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'has_method_in_file',
|
|
return_value=True)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value=uc.FIND_ONE)
|
|
@mock.patch.object(test_finder_utils, 'get_fully_qualified_class_name',
|
|
return_value=uc.FULL_CLASS_NAME)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch('os.path.isdir', return_value=True)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_class_name(self, _isdir, _isfile, _fqcn,
|
|
mock_checkoutput, mock_build,
|
|
_vts, _has_method_in_file,
|
|
_is_parameterized, _is_build_file,
|
|
_mock_unit_tests):
|
|
"""Test find_test_by_class_name."""
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
t_infos = self.mod_finder.find_test_by_class_name(uc.CLASS_NAME)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.CLASS_INFO)
|
|
|
|
# with method
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
class_with_method = '%s#%s' % (uc.CLASS_NAME, uc.METHOD_NAME)
|
|
t_infos = self.mod_finder.find_test_by_class_name(class_with_method)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.METHOD_INFO)
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
class_methods = '%s,%s' % (class_with_method, uc.METHOD2_NAME)
|
|
t_infos = self.mod_finder.find_test_by_class_name(class_methods)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0],
|
|
FLAT_METHOD_INFO)
|
|
# module and rel_config passed in
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
t_infos = self.mod_finder.find_test_by_class_name(
|
|
uc.CLASS_NAME, uc.MODULE_NAME, uc.CONFIG_FILE)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.CLASS_INFO)
|
|
# find output fails to find class file
|
|
mock_checkoutput.return_value = ''
|
|
self.assertIsNone(self.mod_finder.find_test_by_class_name('Not class'))
|
|
# class is outside given module path
|
|
mock_checkoutput.side_effect = classoutside_side_effect
|
|
t_infos = self.mod_finder.find_test_by_class_name(uc.CLASS_NAME,
|
|
uc.MODULE2_NAME,
|
|
uc.CONFIG2_FILE)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0],
|
|
CLASS_INFO_MODULE_2)
|
|
|
|
@mock.patch.object(test_finder_utils, 'is_parameterized_java_class',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'has_method_in_file',
|
|
return_value=True)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value=uc.FIND_ONE)
|
|
@mock.patch.object(test_finder_utils, 'get_fully_qualified_class_name',
|
|
return_value=uc.FULL_CLASS_NAME)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_module_and_class(self, _isfile, _fqcn,
|
|
mock_checkoutput, mock_build,
|
|
_vts, _has_method_in_file,
|
|
_is_parameterized):
|
|
"""Test find_test_by_module_and_class."""
|
|
# Native test was tested in test_find_test_by_cc_class_name().
|
|
self.mod_finder.module_info.is_native_test.return_value = False
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
mod_info = {constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_PATH: [uc.MODULE_DIR],
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
t_infos = self.mod_finder.find_test_by_module_and_class(MODULE_CLASS)
|
|
unittest_utils.assert_equal_testinfos(self, t_infos[0], uc.CLASS_INFO)
|
|
# with method
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
t_infos = self.mod_finder.find_test_by_module_and_class(MODULE_CLASS_METHOD)
|
|
unittest_utils.assert_equal_testinfos(self, t_infos[0], uc.METHOD_INFO)
|
|
self.mod_finder.module_info.is_testable_module.return_value = False
|
|
# bad module, good class, returns None
|
|
bad_module = '%s:%s' % ('BadMod', uc.CLASS_NAME)
|
|
self.mod_finder.module_info.get_module_info.return_value = None
|
|
self.assertIsNone(self.mod_finder.find_test_by_module_and_class(bad_module))
|
|
# find output fails to find class file
|
|
mock_checkoutput.return_value = ''
|
|
bad_class = '%s:%s' % (uc.MODULE_NAME, 'Anything')
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
self.assertIsNone(self.mod_finder.find_test_by_module_and_class(bad_class))
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder, 'find_test_by_kernel_class_name',
|
|
return_value=None)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value=uc.FIND_CC_ONE)
|
|
@mock.patch.object(test_finder_utils, 'find_class_file',
|
|
side_effect=[None, None, '/'])
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_module_and_class_part_2(self, _isfile, mock_fcf,
|
|
mock_checkoutput, mock_build,
|
|
_vts, _find_kernel):
|
|
"""Test find_test_by_module_and_class for MODULE:CC_CLASS."""
|
|
# Native test was tested in test_find_test_by_cc_class_name()
|
|
self.mod_finder.module_info.is_native_test.return_value = False
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
self.mod_finder.module_info.get_paths.return_value = []
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
mod_info = {constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_PATH: [uc.CC_MODULE_DIR],
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
t_infos = self.mod_finder.find_test_by_module_and_class(CC_MODULE_CLASS)
|
|
unittest_utils.assert_equal_testinfos(self, t_infos[0], uc.CC_MODULE_CLASS_INFO)
|
|
# with method
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
mock_fcf.side_effect = [None, None, '/']
|
|
t_infos = self.mod_finder.find_test_by_module_and_class(CC_MODULE_CLASS_METHOD)
|
|
unittest_utils.assert_equal_testinfos(self, t_infos[0], uc.CC_METHOD_INFO)
|
|
# bad module, good class, returns None
|
|
bad_module = '%s:%s' % ('BadMod', uc.CC_CLASS_NAME)
|
|
self.mod_finder.module_info.get_module_info.return_value = None
|
|
self.mod_finder.module_info.is_testable_module.return_value = False
|
|
self.assertIsNone(self.mod_finder.find_test_by_module_and_class(bad_module))
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_module_test_config',
|
|
return_value=[KERNEL_CONFIG_FILE])
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value=uc.FIND_CC_ONE)
|
|
@mock.patch.object(test_finder_utils, 'find_class_file',
|
|
side_effect=[None, None, '/'])
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_module_and_class_for_kernel_test(
|
|
self, _isfile, mock_fcf, mock_checkoutput, mock_build, _vts,
|
|
_test_config):
|
|
"""Test find_test_by_module_and_class for MODULE:CC_CLASS."""
|
|
# Kernel test was tested in find_test_by_kernel_class_name()
|
|
self.mod_finder.module_info.is_native_test.return_value = False
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
self.mod_finder.module_info.get_paths.return_value = []
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
mod_info = {constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_PATH: [uc.CC_MODULE_DIR],
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
t_infos = self.mod_finder.find_test_by_module_and_class(KERNEL_MODULE_CLASS)
|
|
unittest_utils.assert_equal_testinfos(self, t_infos[0], KERNEL_MODULE_CLASS_INFO)
|
|
|
|
@mock.patch.object(test_finder_utils, 'find_host_unit_tests',
|
|
return_value=[])
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value=uc.FIND_PKG)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch('os.path.isdir', return_value=True)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_package_name(self, _isdir, _isfile, mock_checkoutput,
|
|
mock_build, _vts, _mock_unit_tests):
|
|
"""Test find_test_by_package_name."""
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []
|
|
}
|
|
t_infos = self.mod_finder.find_test_by_package_name(uc.PACKAGE)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0],
|
|
uc.PACKAGE_INFO)
|
|
# with method, should raise
|
|
pkg_with_method = '%s#%s' % (uc.PACKAGE, uc.METHOD_NAME)
|
|
self.assertRaises(atest_error.MethodWithoutClassError,
|
|
self.mod_finder.find_test_by_package_name,
|
|
pkg_with_method)
|
|
# module and rel_config passed in
|
|
t_infos = self.mod_finder.find_test_by_package_name(
|
|
uc.PACKAGE, uc.MODULE_NAME, uc.CONFIG_FILE)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.PACKAGE_INFO)
|
|
# find output fails to find class file
|
|
mock_checkoutput.return_value = ''
|
|
self.assertIsNone(self.mod_finder.find_test_by_package_name('Not pkg'))
|
|
|
|
@mock.patch('os.path.isdir', return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value=uc.FIND_PKG)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_module_and_package(self, _isfile, mock_checkoutput,
|
|
mock_build, _vts, _isdir):
|
|
"""Test find_test_by_module_and_package."""
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
self.mod_finder.module_info.get_paths.return_value = []
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
mod_info = {constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_PATH: [uc.MODULE_DIR],
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
t_infos = self.mod_finder.find_test_by_module_and_package(MODULE_PACKAGE)
|
|
self.assertEqual(t_infos, None)
|
|
_isdir.return_value = True
|
|
t_infos = self.mod_finder.find_test_by_module_and_package(MODULE_PACKAGE)
|
|
unittest_utils.assert_equal_testinfos(self, t_infos[0], uc.PACKAGE_INFO)
|
|
|
|
# with method, raises
|
|
module_pkg_with_method = '%s:%s#%s' % (uc.MODULE2_NAME, uc.PACKAGE,
|
|
uc.METHOD_NAME)
|
|
self.assertRaises(atest_error.MethodWithoutClassError,
|
|
self.mod_finder.find_test_by_module_and_package,
|
|
module_pkg_with_method)
|
|
# bad module, good pkg, returns None
|
|
self.mod_finder.module_info.is_testable_module.return_value = False
|
|
bad_module = '%s:%s' % ('BadMod', uc.PACKAGE)
|
|
self.mod_finder.module_info.get_module_info.return_value = None
|
|
self.assertIsNone(self.mod_finder.find_test_by_module_and_package(bad_module))
|
|
# find output fails to find package path
|
|
mock_checkoutput.return_value = ''
|
|
bad_pkg = '%s:%s' % (uc.MODULE_NAME, 'Anything')
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
self.assertIsNone(self.mod_finder.find_test_by_module_and_package(bad_pkg))
|
|
|
|
@mock.patch.object(test_finder_utils, 'find_host_unit_tests',
|
|
return_value=[])
|
|
@mock.patch.object(test_finder_utils, 'get_cc_test_classes_methods',
|
|
return_value=(set(), set(), set()))
|
|
@mock.patch.object(atest_utils, 'is_build_file', return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'is_parameterized_java_class',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'has_method_in_file',
|
|
return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'has_cc_class',
|
|
return_value=True)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'get_fully_qualified_class_name',
|
|
return_value=uc.FULL_CLASS_NAME)
|
|
@mock.patch('os.path.realpath',
|
|
side_effect=unittest_utils.realpath_side_effect)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch.object(test_finder_utils, 'find_parent_module_dir')
|
|
@mock.patch('os.path.exists')
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_path(
|
|
self, mock_pathexists, mock_dir, _isfile, _real, _fqcn, _vts,
|
|
mock_build, _has_cc_class, _has_method_in_file, _is_parameterized,
|
|
_is_build_file, _get_cc_test_classed, _mock_unit_tests):
|
|
"""Test find_test_by_path."""
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mock_build.return_value = set()
|
|
# Check that we don't return anything with invalid test references.
|
|
mock_pathexists.return_value = False
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, None, self.mod_finder.find_test_by_path('bad/path'))
|
|
mock_pathexists.return_value = True
|
|
mock_dir.return_value = None
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, None, self.mod_finder.find_test_by_path('no/module'))
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
|
|
# Happy path testing.
|
|
mock_dir.return_value = uc.MODULE_DIR
|
|
|
|
class_path = '%s.kt' % uc.CLASS_NAME
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
t_infos = self.mod_finder.find_test_by_path(class_path)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, uc.CLASS_INFO, t_infos[0])
|
|
|
|
class_with_method = '%s#%s' % (class_path, uc.METHOD_NAME)
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
t_infos = self.mod_finder.find_test_by_path(class_with_method)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.METHOD_INFO)
|
|
|
|
class_path = '%s.java' % uc.CLASS_NAME
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
t_infos = self.mod_finder.find_test_by_path(class_path)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, uc.CLASS_INFO, t_infos[0])
|
|
|
|
class_with_method = '%s#%s' % (class_path, uc.METHOD_NAME)
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
t_infos = self.mod_finder.find_test_by_path(class_with_method)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.METHOD_INFO)
|
|
|
|
class_with_methods = '%s,%s' % (class_with_method, uc.METHOD2_NAME)
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
t_infos = self.mod_finder.find_test_by_path(class_with_methods)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0],
|
|
FLAT_METHOD_INFO)
|
|
|
|
# Cc path testing.
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.CC_MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.CC_MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
mock_dir.return_value = uc.CC_MODULE_DIR
|
|
class_path = '%s' % uc.CC_PATH
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
t_infos = self.mod_finder.find_test_by_path(class_path)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, uc.CC_PATH_INFO2, t_infos[0])
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets',
|
|
return_value=copy.deepcopy(uc.MODULE_BUILD_TARGETS))
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'find_parent_module_dir',
|
|
return_value=os.path.relpath(uc.TEST_DATA_DIR, uc.ROOT))
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_path_part_2(self, _find_parent, _is_vts, _get_build):
|
|
"""Test find_test_by_path for directories."""
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
# Dir with java files in it, should run as package
|
|
class_dir = os.path.join(uc.TEST_DATA_DIR, 'path_testing')
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
t_infos = self.mod_finder.find_test_by_path(class_dir)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, uc.PATH_INFO, t_infos[0])
|
|
# Dir with no java files in it, should run whole module
|
|
empty_dir = os.path.join(uc.TEST_DATA_DIR, 'path_testing_empty')
|
|
t_infos = self.mod_finder.find_test_by_path(empty_dir)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, uc.EMPTY_PATH_INFO,
|
|
t_infos[0])
|
|
# Dir with cc files in it, should run as cc class
|
|
class_dir = os.path.join(uc.TEST_DATA_DIR, 'cc_path_testing')
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.CC_MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.CC_MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
t_infos = self.mod_finder.find_test_by_path(class_dir)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, uc.CC_PATH_INFO, t_infos[0])
|
|
|
|
@mock.patch.object(test_finder_utils, 'find_host_unit_tests',
|
|
return_value=[])
|
|
@mock.patch.object(atest_utils, 'is_build_file', return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'has_method_in_file',
|
|
return_value=True)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value=uc.CC_FIND_ONE)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch('os.path.isdir', return_value=True)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_cc_class_name(self, _isdir, _isfile,
|
|
mock_checkoutput, mock_build,
|
|
_vts, _has_method, _is_build_file,
|
|
_mock_unit_tests):
|
|
"""Test find_test_by_cc_class_name."""
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.CC_MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.CC_MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
t_infos = self.mod_finder.find_test_by_cc_class_name(uc.CC_CLASS_NAME)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.CC_CLASS_INFO)
|
|
|
|
# with method
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
class_with_method = '%s#%s' % (uc.CC_CLASS_NAME, uc.CC_METHOD_NAME)
|
|
t_infos = self.mod_finder.find_test_by_cc_class_name(class_with_method)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self,
|
|
t_infos[0],
|
|
uc.CC_METHOD_INFO)
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
class_methods = '%s,%s' % (class_with_method, uc.CC_METHOD2_NAME)
|
|
t_infos = self.mod_finder.find_test_by_cc_class_name(class_methods)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0],
|
|
uc.CC_METHOD2_INFO)
|
|
# module and rel_config passed in
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
t_infos = self.mod_finder.find_test_by_cc_class_name(
|
|
uc.CC_CLASS_NAME, uc.CC_MODULE_NAME, uc.CC_CONFIG_FILE)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.CC_CLASS_INFO)
|
|
# find output fails to find class file
|
|
mock_checkoutput.return_value = ''
|
|
self.assertIsNone(self.mod_finder.find_test_by_cc_class_name(
|
|
'Not class'))
|
|
# class is outside given module path
|
|
mock_checkoutput.return_value = uc.CC_FIND_ONE
|
|
t_infos = self.mod_finder.find_test_by_cc_class_name(
|
|
uc.CC_CLASS_NAME,
|
|
uc.CC_MODULE2_NAME,
|
|
uc.CC_CONFIG2_FILE)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0],
|
|
CC_CLASS_INFO_MODULE_2)
|
|
|
|
def test_get_testable_modules_with_ld(self):
|
|
"""Test get_testable_modules_with_ld"""
|
|
self.mod_finder.module_info.get_testable_modules.return_value = [
|
|
uc.MODULE_NAME, uc.MODULE2_NAME]
|
|
# Without a misfit constraint
|
|
ld1 = self.mod_finder.get_testable_modules_with_ld(uc.TYPO_MODULE_NAME)
|
|
self.assertEqual([[16, uc.MODULE2_NAME], [1, uc.MODULE_NAME]], ld1)
|
|
# With a misfit constraint
|
|
ld2 = self.mod_finder.get_testable_modules_with_ld(uc.TYPO_MODULE_NAME, 2)
|
|
self.assertEqual([[1, uc.MODULE_NAME]], ld2)
|
|
|
|
def test_get_fuzzy_searching_modules(self):
|
|
"""Test get_fuzzy_searching_modules"""
|
|
self.mod_finder.module_info.get_testable_modules.return_value = [
|
|
uc.MODULE_NAME, uc.MODULE2_NAME]
|
|
result = self.mod_finder.get_fuzzy_searching_results(uc.TYPO_MODULE_NAME)
|
|
self.assertEqual(uc.MODULE_NAME, result[0])
|
|
|
|
def test_get_build_targets_w_vts_core(self):
|
|
"""Test _get_build_targets."""
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = True
|
|
self.mod_finder.module_info.get_paths.return_value = []
|
|
mod_info = {constants.MODULE_COMPATIBILITY_SUITES:
|
|
[constants.VTS_CORE_SUITE]}
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
self.assertEqual(self.mod_finder._get_build_targets('', ''),
|
|
{constants.VTS_CORE_TF_MODULE})
|
|
|
|
@mock.patch.object(test_finder_utils, 'is_parameterized_java_class',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value='')
|
|
@mock.patch.object(test_finder_utils, 'get_fully_qualified_class_name',
|
|
return_value=uc.FULL_CLASS_NAME)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch('os.path.isdir', return_value=True)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_class_name_w_module(self, _isdir, _isfile, _fqcn,
|
|
mock_checkoutput, mock_build,
|
|
_vts, _is_parameterized):
|
|
"""Test test_find_test_by_class_name with module but without class found."""
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
self.mod_finder.module_info.get_paths.return_value = [uc.TEST_DATA_CONFIG]
|
|
t_infos = self.mod_finder.find_test_by_class_name(
|
|
uc.FULL_CLASS_NAME, module_name=uc.MODULE_NAME,
|
|
rel_config=uc.CONFIG_FILE)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.CLASS_INFO)
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value='')
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch('os.path.isdir', return_value=True)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_package_name_w_module(self, _isdir, _isfile,
|
|
mock_checkoutput, mock_build,
|
|
_vts):
|
|
"""Test find_test_by_package_name with module but without package found."""
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []
|
|
}
|
|
self.mod_finder.module_info.get_paths.return_value = [uc.TEST_DATA_CONFIG]
|
|
t_infos = self.mod_finder.find_test_by_package_name(
|
|
uc.PACKAGE, module_name=uc.MODULE_NAME, rel_config=uc.CONFIG_FILE)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0],
|
|
uc.PACKAGE_INFO)
|
|
|
|
@mock.patch.object(atest_utils, 'is_build_file', return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'is_parameterized_java_class',
|
|
return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'has_method_in_file',
|
|
return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'has_cc_class',
|
|
return_value=True)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'get_fully_qualified_class_name',
|
|
return_value=uc.FULL_CLASS_NAME)
|
|
@mock.patch('os.path.realpath',
|
|
side_effect=unittest_utils.realpath_side_effect)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch.object(test_finder_utils, 'find_parent_module_dir')
|
|
@mock.patch('os.path.exists')
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_path_is_parameterized_java(
|
|
self, mock_pathexists, mock_dir, _isfile, _real, _fqcn, _vts,
|
|
mock_build, _has_cc_class, _has_method_in_file, _is_parameterized,
|
|
_is_build_file):
|
|
"""Test find_test_by_path and input path is parameterized class."""
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mock_build.return_value = set()
|
|
mock_pathexists.return_value = True
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
# Happy path testing.
|
|
mock_dir.return_value = uc.MODULE_DIR
|
|
class_path = '%s.java' % uc.CLASS_NAME
|
|
# Input include only one method
|
|
class_with_method = '%s#%s' % (class_path, uc.METHOD_NAME)
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
t_infos = self.mod_finder.find_test_by_path(class_with_method)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.PARAMETERIZED_METHOD_INFO)
|
|
# Input include multiple methods
|
|
class_with_methods = '%s,%s' % (class_with_method, uc.METHOD2_NAME)
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
t_infos = self.mod_finder.find_test_by_path(class_with_methods)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.PARAMETERIZED_FLAT_METHOD_INFO)
|
|
|
|
@mock.patch.object(test_finder_utils, 'find_host_unit_tests',
|
|
return_value=[])
|
|
@mock.patch.object(atest_utils, 'is_build_file', return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'is_parameterized_java_class',
|
|
return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'has_method_in_file',
|
|
return_value=True)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch('subprocess.check_output', return_value=uc.FIND_ONE)
|
|
@mock.patch.object(test_finder_utils, 'get_fully_qualified_class_name',
|
|
return_value=uc.FULL_CLASS_NAME)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch('os.path.isdir', return_value=True)
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_class_name_is_parameterized(
|
|
self, _isdir, _isfile, _fqcn, mock_checkoutput, mock_build, _vts,
|
|
_has_method_in_file, _is_parameterized, _is_build_file,
|
|
_mock_unit_tests):
|
|
"""Test find_test_by_class_name and the class is parameterized java."""
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = False
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
# With method
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
class_with_method = '%s#%s' % (uc.CLASS_NAME, uc.METHOD_NAME)
|
|
t_infos = self.mod_finder.find_test_by_class_name(class_with_method)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.PARAMETERIZED_METHOD_INFO)
|
|
# With multiple method
|
|
mock_build.return_value = copy.deepcopy(uc.MODULE_BUILD_TARGETS)
|
|
class_methods = '%s,%s' % (class_with_method, uc.METHOD2_NAME)
|
|
t_infos = self.mod_finder.find_test_by_class_name(class_methods)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, t_infos[0], uc.PARAMETERIZED_FLAT_METHOD_INFO)
|
|
|
|
# pylint: disable=unused-argument
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets',
|
|
return_value=copy.deepcopy(uc.MODULE_BUILD_TARGETS))
|
|
def test_find_test_by_config_name(self, _get_targ):
|
|
"""Test find_test_by_config_name."""
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
|
|
mod_info = {'installed': ['/path/to/install'],
|
|
'path': [uc.MODULE_DIR],
|
|
constants.MODULE_TEST_CONFIG: [uc.CONFIG_FILE,
|
|
uc.EXTRA_CONFIG_FILE],
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
name_to_module_info = {uc.MODULE_NAME: mod_info}
|
|
self.mod_finder.module_info.name_to_module_info = name_to_module_info
|
|
t_infos = self.mod_finder.find_test_by_config_name(uc.MODULE_CONFIG_NAME)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self,
|
|
t_infos[0],
|
|
uc.TEST_CONFIG_MODULE_INFO)
|
|
|
|
@mock.patch.object(test_finder_utils, 'is_parameterized_java_class',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'has_method_in_file',
|
|
return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'has_cc_class',
|
|
return_value=True)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'get_fully_qualified_class_name',
|
|
return_value=uc.FULL_CLASS_NAME)
|
|
@mock.patch('os.path.realpath',
|
|
side_effect=unittest_utils.realpath_side_effect)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch.object(test_finder_utils, 'find_parent_module_dir')
|
|
@mock.patch('os.path.exists')
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_path_w_src_verify(
|
|
self, mock_pathexists, mock_dir, _isfile, _real, _fqcn, _vts,
|
|
mock_build, _has_cc_class, _has_method_in_file, _is_parameterized):
|
|
"""Test find_test_by_path with src information."""
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
|
|
# Happy path testing.
|
|
mock_dir.return_value = uc.MODULE_DIR
|
|
# Test path not in module's src list.
|
|
class_path = '%s.java' % uc.CLASS_NAME
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: [],
|
|
constants.MODULE_SRCS: ['not_matched_%s' % class_path]}
|
|
t_infos = self.mod_finder.find_test_by_path(class_path)
|
|
self.assertEqual(0, len(t_infos))
|
|
|
|
# Test input file is in module's src list.
|
|
class_path = '%s.java' % uc.CLASS_NAME
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: [],
|
|
constants.MODULE_SRCS: [class_path]}
|
|
t_infos = self.mod_finder.find_test_by_path(class_path)
|
|
unittest_utils.assert_equal_testinfos(self, uc.CLASS_INFO, t_infos[0])
|
|
|
|
@mock.patch.object(test_finder_utils, 'get_cc_test_classes_methods')
|
|
@mock.patch.object(atest_utils, 'is_build_file', return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'is_parameterized_java_class',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'has_method_in_file',
|
|
return_value=True)
|
|
@mock.patch.object(test_finder_utils, 'has_cc_class',
|
|
return_value=True)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets')
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(test_finder_utils, 'get_fully_qualified_class_name',
|
|
return_value=uc.FULL_CLASS_NAME)
|
|
@mock.patch('os.path.realpath',
|
|
side_effect=unittest_utils.realpath_side_effect)
|
|
@mock.patch('os.path.isfile', side_effect=unittest_utils.isfile_side_effect)
|
|
@mock.patch.object(test_finder_utils, 'find_parent_module_dir')
|
|
@mock.patch('os.path.exists')
|
|
#pylint: disable=unused-argument
|
|
def test_find_test_by_path_for_cc_file(self, mock_pathexists, mock_dir,
|
|
_isfile, _real, _fqcn, _vts, mock_build, _has_cc_class,
|
|
_has_method_in_file, _is_parameterized, _is_build_file,
|
|
_mock_get_cc_test_class):
|
|
"""Test find_test_by_path for handling correct CC filter."""
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.has_test_config.return_value = True
|
|
mock_build.return_value = set()
|
|
# Check that we don't return anything with invalid test references.
|
|
mock_pathexists.return_value = False
|
|
mock_pathexists.return_value = True
|
|
mock_dir.return_value = None
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
# Happy path testing.
|
|
mock_dir.return_value = uc.MODULE_DIR
|
|
# Cc path testing if get_cc_test_classes_methods found those information.
|
|
self.mod_finder.module_info.get_module_names.return_value = [uc.CC_MODULE_NAME]
|
|
self.mod_finder.module_info.get_module_info.return_value = {
|
|
constants.MODULE_INSTALLED: DEFAULT_INSTALL_PATH,
|
|
constants.MODULE_NAME: uc.CC_MODULE_NAME,
|
|
constants.MODULE_CLASS: [],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
mock_dir.return_value = uc.CC_MODULE_DIR
|
|
class_path = '%s' % uc.CC_PATH
|
|
mock_build.return_value = uc.CLASS_BUILD_TARGETS
|
|
# Test without paramertize test
|
|
founded_classed = {'class1'}
|
|
founded_methods = {'method1'}
|
|
founded_para_classes = set()
|
|
_mock_get_cc_test_class.return_value = (founded_classed,
|
|
founded_methods,
|
|
founded_para_classes)
|
|
cc_path_data = {constants.TI_REL_CONFIG: uc.CC_CONFIG_FILE,
|
|
constants.TI_FILTER: frozenset(
|
|
{test_info.TestFilter(class_name='class1.*',
|
|
methods=frozenset())})}
|
|
cc_path_info = test_info.TestInfo(uc.CC_MODULE_NAME,
|
|
atf_tr.AtestTradefedTestRunner.NAME,
|
|
uc.CLASS_BUILD_TARGETS, cc_path_data)
|
|
t_infos = self.mod_finder.find_test_by_path(class_path)
|
|
unittest_utils.assert_equal_testinfos(self, cc_path_info, t_infos[0])
|
|
# Test with paramertize test defined in input path
|
|
founded_classed = {'class1'}
|
|
founded_methods = {'method1'}
|
|
founded_para_classes = {'class1'}
|
|
_mock_get_cc_test_class.return_value = (founded_classed,
|
|
founded_methods,
|
|
founded_para_classes)
|
|
cc_path_data = {constants.TI_REL_CONFIG: uc.CC_CONFIG_FILE,
|
|
constants.TI_FILTER: frozenset(
|
|
{test_info.TestFilter(class_name='*/class1.*',
|
|
methods=frozenset())})}
|
|
cc_path_info = test_info.TestInfo(uc.CC_MODULE_NAME,
|
|
atf_tr.AtestTradefedTestRunner.NAME,
|
|
uc.CLASS_BUILD_TARGETS, cc_path_data)
|
|
t_infos = self.mod_finder.find_test_by_path(class_path)
|
|
unittest_utils.assert_equal_testinfos(self, cc_path_info, t_infos[0])
|
|
|
|
# pylint: disable=unused-argument
|
|
@mock.patch.object(module_finder.ModuleFinder, '_is_vts_module',
|
|
return_value=False)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_build_targets',
|
|
return_value=copy.deepcopy(uc.MODULE_BUILD_TARGETS))
|
|
def test_process_test_info(self, _get_targ, _is_vts):
|
|
"""Test _process_test_info."""
|
|
mod_info = {'installed': ['/path/to/install'],
|
|
'path': [uc.MODULE_DIR],
|
|
constants.MODULE_CLASS: [
|
|
constants.MODULE_CLASS_JAVA_LIBRARIES],
|
|
constants.MODULE_COMPATIBILITY_SUITES: []}
|
|
self.mod_finder.module_info.is_robolectric_test.return_value = False
|
|
self.mod_finder.module_info.is_auto_gen_test_config.return_value = True
|
|
self.mod_finder.module_info.get_module_info.return_value = mod_info
|
|
processed_info = self.mod_finder._process_test_info(
|
|
copy.copy(uc.MODULE_INFO))
|
|
unittest_utils.assert_equal_testinfos(
|
|
self,
|
|
processed_info,
|
|
uc.MODULE_INFO_W_DALVIK)
|
|
|
|
@mock.patch.object(test_finder_utils, 'get_annotated_methods')
|
|
def test_is_srcs_match_method_annotation_include_anno(
|
|
self, _mock_get_anno_methods):
|
|
"""Test _is_srcs_match_method_annotation with include annotation."""
|
|
annotation_dict = {constants.INCLUDE_ANNOTATION: 'includeAnnotation1'}
|
|
input_method = 'my_input_method'
|
|
input_srcs = ['src1']
|
|
# Test if input method matched include annotation.
|
|
_mock_get_anno_methods.return_value = {input_method,
|
|
'not_my_input_method'}
|
|
|
|
is_matched = self.mod_finder._is_srcs_match_method_annotation(
|
|
input_method, input_srcs, annotation_dict)
|
|
|
|
self.assertTrue(is_matched)
|
|
# Test if input method not matched include annotation.
|
|
_mock_get_anno_methods.return_value = {'not_my_input_method'}
|
|
|
|
is_matched = self.mod_finder._is_srcs_match_method_annotation(
|
|
input_method, input_srcs, annotation_dict)
|
|
|
|
self.assertFalse(is_matched)
|
|
|
|
@mock.patch.object(test_finder_utils, 'get_annotated_methods')
|
|
@mock.patch.object(test_finder_utils, 'get_java_methods')
|
|
def test_is_srcs_match_method_exclude_anno(self, _mock_get_java_methods,
|
|
_mock_get_exclude_anno_methods):
|
|
"""Test _is_srcs_match_method_annotation with exclude annotation."""
|
|
annotation_dict = {constants.EXCLUDE_ANNOTATION: 'excludeAnnotation1'}
|
|
input_method = 'my_input_method'
|
|
input_srcs = ['src1']
|
|
_mock_get_java_methods.return_value = {input_method,
|
|
'method1',
|
|
'method2'}
|
|
# Test if input method matched exclude annotation.
|
|
_mock_get_exclude_anno_methods.return_value = {input_method, 'method1'}
|
|
|
|
is_matched = self.mod_finder._is_srcs_match_method_annotation(
|
|
input_method, input_srcs, annotation_dict)
|
|
|
|
self.assertFalse(is_matched)
|
|
|
|
# Test if input method not matched exclude annotation.
|
|
_mock_get_exclude_anno_methods.return_value = {'method2'}
|
|
|
|
is_matched = self.mod_finder._is_srcs_match_method_annotation(
|
|
input_method, input_srcs, annotation_dict)
|
|
|
|
self.assertTrue(is_matched)
|
|
|
|
@mock.patch.object(atest_utils, 'get_android_junit_config_filters')
|
|
@mock.patch.object(test_finder_utils, 'get_test_config_and_srcs')
|
|
def test_get_matched_test_infos_no_filter(self, _mock_get_conf_srcs,
|
|
_mock_get_filters):
|
|
"""Test _get_matched_test_infos without test filters."""
|
|
test_info1 = 'test_info1'
|
|
test_infos = [test_info1]
|
|
test_config = 'test_config'
|
|
test_srcs = ['src1', 'src2']
|
|
_mock_get_conf_srcs.return_value = test_config, test_srcs
|
|
filter_dict = {}
|
|
_mock_get_filters.return_value = filter_dict
|
|
|
|
self.assertEqual(
|
|
self.mod_finder._get_matched_test_infos(test_infos, {'method'}),
|
|
test_infos)
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder,
|
|
'_is_srcs_match_method_annotation')
|
|
@mock.patch.object(atest_utils, 'get_android_junit_config_filters')
|
|
@mock.patch.object(test_finder_utils, 'get_test_config_and_srcs')
|
|
def test_get_matched_test_infos_get_filter_method_match(
|
|
self, _mock_get_conf_srcs, _mock_get_filters, _mock_method_match):
|
|
"""Test _get_matched_test_infos with test filters and method match."""
|
|
test_infos = [KERNEL_MODULE_CLASS_INFO]
|
|
test_config = 'test_config'
|
|
test_srcs = ['src1', 'src2']
|
|
_mock_get_conf_srcs.return_value = test_config, test_srcs
|
|
filter_dict = {'include-annotation': 'annotate1'}
|
|
_mock_get_filters.return_value = filter_dict
|
|
_mock_method_match.return_value = True
|
|
|
|
unittest_utils.assert_strict_equal(
|
|
self,
|
|
self.mod_finder._get_matched_test_infos(test_infos, {'method'}),
|
|
test_infos)
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder,
|
|
'_is_srcs_match_method_annotation')
|
|
@mock.patch.object(atest_utils, 'get_android_junit_config_filters')
|
|
@mock.patch.object(test_finder_utils, 'get_test_config_and_srcs')
|
|
def test_get_matched_test_infos_filter_method_not_match(
|
|
self, _mock_get_conf_srcs, _mock_get_filters, _mock_method_match):
|
|
"""Test _get_matched_test_infos but method not match."""
|
|
test_infos = [KERNEL_MODULE_CLASS_INFO]
|
|
test_config = 'test_config'
|
|
test_srcs = ['src1', 'src2']
|
|
_mock_get_conf_srcs.return_value = test_config, test_srcs
|
|
filter_dict = {'include-annotation': 'annotate1'}
|
|
_mock_get_filters.return_value = filter_dict
|
|
_mock_method_match.return_value = False
|
|
|
|
self.assertEqual(
|
|
self.mod_finder._get_matched_test_infos(test_infos, {'method'}),
|
|
[])
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_matched_test_infos')
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_test_infos',
|
|
return_value=uc.MODULE_INFO)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_test_info_filter',
|
|
return_value=uc.CLASS_FILTER)
|
|
@mock.patch.object(test_finder_utils, 'find_class_file',
|
|
return_value=['path1'])
|
|
def test_find_test_by_class_name_not_matched_filters(
|
|
self, _mock_class_path, _mock_test_filters,
|
|
_mock_test_infos, _mock_matched_test_infos):
|
|
"""Test find_test_by_class_name which has not matched filters."""
|
|
found_test_infos = [uc.MODULE_INFO, uc.MODULE_INFO2]
|
|
_mock_test_infos.return_value = found_test_infos
|
|
matched_test_infos = [uc.MODULE_INFO2]
|
|
_mock_matched_test_infos.return_value = matched_test_infos
|
|
|
|
# Test if class without method
|
|
test_infos = self.mod_finder.find_test_by_class_name('my.test.class')
|
|
self.assertEqual(len(test_infos), 2)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, test_infos[0], uc.MODULE_INFO)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, test_infos[1], uc.MODULE_INFO2)
|
|
|
|
# Test if class with method
|
|
test_infos = self.mod_finder.find_test_by_class_name(
|
|
'my.test.class#myMethod')
|
|
self.assertEqual(len(test_infos), 1)
|
|
unittest_utils.assert_equal_testinfos(
|
|
self, test_infos[0], uc.MODULE_INFO2)
|
|
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_test_infos',
|
|
return_value=None)
|
|
@mock.patch.object(module_finder.ModuleFinder, '_get_test_info_filter',
|
|
return_value=uc.CLASS_FILTER)
|
|
@mock.patch.object(test_finder_utils, 'find_class_file',
|
|
return_value=['path1'])
|
|
def test_find_test_by_class_name_get_test_infos_none(
|
|
self, _mock_class_path, _mock_test_filters, _mock_test_infos):
|
|
"""Test find_test_by_class_name which has not matched test infos."""
|
|
self.assertEqual(
|
|
self.mod_finder.find_test_by_class_name('my.test.class'),
|
|
None)
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|