1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
|
# Copyright 2023 The Chromium Authors
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Unit tests for code_coverage_utils_test.py.
Example usage:
vpython3 code_coverage_utils_test.py
"""
# pylint: disable=protected-access
import os
from pathlib import Path
import sys
import tempfile
import unittest
path_root = Path(__file__).parents[2]
sys.path.append(str(path_root))
from pylib.utils import code_coverage_utils
from py_utils import tempfile_ext
import mock # pylint: disable=import-error
class MockDevicePathExists:
def __init__(self, value):
self._path_exists = value
def PathExists(self, directory, retries): # pylint: disable=unused-argument
return self._path_exists
class CodeCoverageUtilsTest(unittest.TestCase):
@mock.patch('subprocess.check_output')
def testMergeCoverageFiles(self, mock_sub):
with tempfile_ext.NamedTemporaryDirectory() as cov_tempd:
pro_tempd = os.path.join(cov_tempd, 'profraw')
os.mkdir(pro_tempd)
profdata = tempfile.NamedTemporaryFile(
dir=pro_tempd,
delete=False,
suffix=code_coverage_utils._PROFRAW_FILE_EXTENSION)
code_coverage_utils.MergeClangCoverageFiles(cov_tempd, pro_tempd)
# Merged file should be deleted.
self.assertFalse(os.path.exists(profdata.name))
self.assertTrue(mock_sub.called)
@mock.patch('os.path.isfile', return_value=True)
@mock.patch('shutil.rmtree')
@mock.patch('pylib.utils.code_coverage_utils.PullClangCoverageFiles')
@mock.patch('pylib.utils.code_coverage_utils.MergeClangCoverageFiles')
def testPullAndMaybeMergeClangCoverageFiles(self, mock_merge_function,
mock_pull_function, mock_rmtree,
_):
mock_device = MockDevicePathExists(True)
code_coverage_utils.PullAndMaybeMergeClangCoverageFiles(
mock_device, 'device_coverage_dir', 'output_dir',
'output_subfolder_name')
mock_pull_function.assert_called_with(mock_device, 'device_coverage_dir',
'output_dir/output_subfolder_name')
mock_merge_function.assert_called_with(
'output_dir', 'output_dir/output_subfolder_name/device_coverage_dir')
self.assertTrue(mock_rmtree.called)
@mock.patch('os.path.isfile', return_value=True)
@mock.patch('shutil.rmtree')
@mock.patch('pylib.utils.code_coverage_utils.PullClangCoverageFiles')
@mock.patch('pylib.utils.code_coverage_utils.MergeClangCoverageFiles')
def testPullAndMaybeMergeClangCoverageFilesNoPull(self, mock_merge_function,
mock_pull_function,
mock_rmtree, _):
mock_device = MockDevicePathExists(False)
code_coverage_utils.PullAndMaybeMergeClangCoverageFiles(
mock_device, 'device_coverage_dir', 'output_dir',
'output_subfolder_name')
self.assertFalse(mock_pull_function.called)
self.assertFalse(mock_merge_function.called)
self.assertFalse(mock_rmtree.called)
@mock.patch('os.path.isfile', return_value=False)
@mock.patch('shutil.rmtree')
@mock.patch('pylib.utils.code_coverage_utils.PullClangCoverageFiles')
@mock.patch('pylib.utils.code_coverage_utils.MergeClangCoverageFiles')
def testPullAndMaybeMergeClangCoverageFilesNoMerge(self, mock_merge_function,
mock_pull_function,
mock_rmtree, _):
mock_device = MockDevicePathExists(True)
code_coverage_utils.PullAndMaybeMergeClangCoverageFiles(
mock_device, 'device_coverage_dir', 'output_dir',
'output_subfolder_name')
mock_pull_function.assert_called_with(mock_device, 'device_coverage_dir',
'output_dir/output_subfolder_name')
self.assertFalse(mock_merge_function.called)
self.assertFalse(mock_rmtree.called)
if __name__ == '__main__':
unittest.main(verbosity=2)
|