Coverage for tsfpga/test/test_git_simulation_subset.py: 97%
69 statements
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-21 20:51 +0000
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-21 20:51 +0000
1# --------------------------------------------------------------------------------------------------
2# Copyright (c) Lukas Vik. All rights reserved.
3#
4# This file is part of the tsfpga project, a project platform for modern FPGA development.
5# https://tsfpga.com
6# https://github.com/tsfpga/tsfpga
7# --------------------------------------------------------------------------------------------------
9# Standard libraries
10from unittest.mock import MagicMock, patch
12# First party libraries
13from tsfpga.git_simulation_subset import GitSimulationSubset
14from tsfpga.module import get_modules
15from tsfpga.system_utils import create_file
18def test_find_subset(tmp_path): # pylint: disable=too-many-statements,too-many-locals
19 """
20 Set up a scenario with a few files that have diffs and a few files that do not.
21 TBs without diffs will be set up so that it depends on the source file that
22 has diffs.
23 This means that these TBs should also be returned by find_subset().
24 """
25 module_paths = tmp_path / "modules"
27 vhd_with_diff = create_file(module_paths / "foo" / "file_with_diff.vhdl")
28 vhd_with_no_diff = create_file(module_paths / "foo" / "file_with_no_diff.vhd")
29 tb_vhd_with_diff = create_file(module_paths / "foo" / "tb_file_with_diff.vhd")
30 tb_vhd1_with_no_diff = create_file(module_paths / "foo" / "file1_with_no_diff_tb.vhdl")
31 tb_vhd2_with_no_diff = create_file(module_paths / "foo" / "file2_with_no_diff_tb.vhdl")
32 tb_vhd3_with_no_diff = create_file(module_paths / "foo" / "file3_with_no_diff_tb.vhdl")
33 regs_toml_with_diff = create_file(module_paths / "bar" / "regs_bar.toml")
34 regs_pkg_vhd_untracked = create_file(module_paths / "bar" / "regs_src" / "bar_regs_pkg.vhd")
36 modules = get_modules(modules_folder=module_paths)
38 vunit_proj = MagicMock()
40 git_simulation_subset = GitSimulationSubset(
41 repo_root=tmp_path, reference_branch="origin/master", vunit_proj=vunit_proj, modules=modules
42 )
44 with patch("tsfpga.git_simulation_subset.Repo", autospec=True) as mocked_repo:
45 repo = mocked_repo.return_value
46 head_commit = repo.head.commit
48 reference_commit = repo.commit.return_value
50 def diff_commit(arg):
51 """
52 Return the files that have diffs. One or the other depending on what the argument
53 (reference commit, or None=local tree) is.
54 """
55 if arg is None:
56 diff = MagicMock()
57 diff.b_path = tb_vhd_with_diff
58 return [diff]
60 if arg is reference_commit:
61 diff1 = MagicMock()
62 diff1.b_path = vhd_with_diff
64 diff2 = MagicMock()
65 diff2.b_path = regs_toml_with_diff
67 return [diff1, diff2]
69 assert False
71 head_commit.diff.side_effect = diff_commit
73 source_file_vhd_with_diff = MagicMock()
74 source_file_vhd_with_diff.name = str(vhd_with_diff)
75 source_file_vhd_with_diff.library.name = "apa"
77 source_file_vhd_with_no_diff = MagicMock()
78 source_file_vhd_with_no_diff.name = str(vhd_with_no_diff)
79 source_file_vhd_with_no_diff.library.name = "hest"
81 source_file_tb_vhd_with_diff = MagicMock()
82 source_file_tb_vhd_with_diff.name = str(tb_vhd_with_diff)
83 source_file_tb_vhd_with_diff.library.name = "zebra"
85 source_file_tb_vhd1_with_no_diff = MagicMock()
86 source_file_tb_vhd1_with_no_diff.name = str(tb_vhd1_with_no_diff)
87 source_file_tb_vhd1_with_no_diff.library.name = "foo"
89 source_file_tb_vhd2_with_no_diff = MagicMock()
90 source_file_tb_vhd2_with_no_diff.name = str(tb_vhd2_with_no_diff)
91 source_file_tb_vhd2_with_no_diff.library.name = "bar"
93 source_file_tb_vhd3_with_no_diff = MagicMock()
94 source_file_tb_vhd3_with_no_diff.name = str(tb_vhd3_with_no_diff)
95 source_file_tb_vhd3_with_no_diff.library.name = "bar"
97 source_file_regs_pkg_vhd_untracked = MagicMock()
98 source_file_regs_pkg_vhd_untracked.name = str(regs_pkg_vhd_untracked)
99 source_file_regs_pkg_vhd_untracked.library.name = "bar"
101 vunit_proj.get_source_files.return_value = [
102 source_file_vhd_with_diff,
103 source_file_vhd_with_no_diff,
104 source_file_tb_vhd_with_diff,
105 source_file_tb_vhd1_with_no_diff,
106 source_file_tb_vhd2_with_no_diff,
107 source_file_tb_vhd3_with_no_diff,
108 source_file_regs_pkg_vhd_untracked,
109 ]
111 def get_implementation_subset(arg):
112 if arg == [source_file_tb_vhd_with_diff]:
113 # This tb, which has a diff, depends on a vhd file with no diff
114 return [source_file_tb_vhd_with_diff, source_file_vhd_with_no_diff]
116 if arg == [source_file_tb_vhd1_with_no_diff]:
117 # This tb, which has no diff, depends on a vhd file that does have a diff
118 return [source_file_tb_vhd1_with_no_diff, source_file_vhd_with_diff]
120 if arg == [source_file_tb_vhd2_with_no_diff]:
121 # This tb, which has no diff, depends on the register package generated
122 # from toml which has diff.
123 return [source_file_tb_vhd2_with_no_diff, source_file_regs_pkg_vhd_untracked]
125 if arg == [source_file_tb_vhd3_with_no_diff]:
126 # This tb, which has no diff, depends only on itself, and should not
127 # be listed by find_subset().
128 return [source_file_tb_vhd3_with_no_diff]
130 assert False
132 vunit_proj.get_implementation_subset.side_effect = get_implementation_subset
134 assert git_simulation_subset.find_subset() == [
135 (tb_vhd_with_diff.stem, "zebra"),
136 (tb_vhd1_with_no_diff.stem, "foo"),
137 (tb_vhd2_with_no_diff.stem, "bar"),
138 ]
140 repo.commit.assert_called_once_with("origin/master")