Coverage for tsfpga/vivado/test/test_simlib_commercial.py: 100%

59 statements  

« prev     ^ index     » next       coverage.py v7.6.10, created at 2025-01-28 20:52 +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# -------------------------------------------------------------------------------------------------- 

8 

9# Standard libraries 

10from pathlib import Path 

11from unittest.mock import MagicMock, patch 

12 

13# Third party libraries 

14import pytest 

15 

16# First party libraries 

17from tsfpga.test.test_utils import file_contains_string 

18from tsfpga.vivado.simlib import VivadoSimlib 

19 

20 

21# pylint: disable=redefined-outer-name 

22@pytest.fixture 

23def simlib_test(tmp_path): 

24 class SimlibCommercialTestFixture: 

25 def __init__(self): 

26 self.output_path = tmp_path / "simlib" 

27 

28 self.simulator_prefix = "/opt/Aldec/Riviera-PRO-2018.10-x64/bin" 

29 self.vivado_path = Path("/tools/xilinx/Vivado/2019.2/bin/vivado") 

30 

31 self.vivado_simlib = self.get_vivado_simlib(self.simulator_prefix, self.vivado_path) 

32 

33 def get_vivado_simlib( 

34 self, simulator_prefix, vivado_path, simulator_class_name="rivierapro" 

35 ): 

36 simulator_class = MagicMock() 

37 simulator_class.name = simulator_class_name 

38 simulator_class.find_prefix.return_value = simulator_prefix 

39 

40 vunit_proj = MagicMock() 

41 vunit_proj._simulator_class = simulator_class # pylint: disable=protected-access 

42 

43 return VivadoSimlib.init(self.output_path, vunit_proj, vivado_path) 

44 

45 @staticmethod 

46 def assert_should_compile(vivado_simlib): 

47 assert vivado_simlib.compile_is_needed 

48 with patch("tsfpga.vivado.simlib_commercial.run_vivado_tcl", autospec=True) as mock: 

49 vivado_simlib.compile_if_needed() 

50 mock.assert_called_once() 

51 

52 @staticmethod 

53 def assert_should_not_compile(vivado_simlib): 

54 assert not vivado_simlib.compile_is_needed 

55 with patch("tsfpga.vivado.simlib_commercial.run_vivado_tcl", autospec=True) as mock: 

56 vivado_simlib.compile_if_needed() 

57 mock.assert_not_called() 

58 

59 return SimlibCommercialTestFixture() 

60 

61 

62def test_should_not_recompile(simlib_test): 

63 simlib_test.assert_should_compile(simlib_test.vivado_simlib) 

64 simlib_test.assert_should_not_compile(simlib_test.vivado_simlib) 

65 

66 

67def test_new_simulator_version_should_cause_recompile(simlib_test): 

68 simlib_test.assert_should_compile(simlib_test.vivado_simlib) 

69 simlib_test.assert_should_not_compile(simlib_test.vivado_simlib) 

70 

71 vivado_simlib = simlib_test.get_vivado_simlib( 

72 simulator_prefix="/opt/Aldec/Riviera-PRO-1975.01-x64/bin", 

73 vivado_path=simlib_test.vivado_path, 

74 ) 

75 simlib_test.assert_should_compile(vivado_simlib) 

76 simlib_test.assert_should_not_compile(vivado_simlib) 

77 

78 

79def test_new_vivado_version_should_cause_recompile(simlib_test): 

80 simlib_test.assert_should_compile(simlib_test.vivado_simlib) 

81 simlib_test.assert_should_not_compile(simlib_test.vivado_simlib) 

82 

83 vivado_simlib = simlib_test.get_vivado_simlib( 

84 simulator_prefix=simlib_test.simulator_prefix, 

85 vivado_path=Path("/tools/xilinx/Vivado/1337.2/bin/vivado"), 

86 ) 

87 simlib_test.assert_should_compile(vivado_simlib) 

88 simlib_test.assert_should_not_compile(vivado_simlib) 

89 

90 

91def test_remapping_of_vivado_simulator_names(simlib_test): 

92 def check_simulator_name(vivado_simlib, name): 

93 with patch("tsfpga.vivado.simlib_commercial.run_vivado_tcl", autospec=True) as _: 

94 vivado_simlib.compile_if_needed() 

95 

96 assert file_contains_string( 

97 file=vivado_simlib.output_path / "compile_simlib.tcl", 

98 string=f"compile_simlib -simulator {name} -simulator_exec_path ", 

99 ) 

100 

101 # Regular Siemens ModelSim should be called "modelsim" 

102 vivado_simlib = simlib_test.get_vivado_simlib( 

103 simulator_prefix=Path("/opt/intelFPGA/20.1/modelsim_ase/bin/"), 

104 vivado_path=Path("/tools/xilinx/Vivado/2019.2/bin/vivado"), 

105 simulator_class_name="modelsim", 

106 ) 

107 check_simulator_name(vivado_simlib=vivado_simlib, name="modelsim") 

108 

109 # Siemens Questa is called "modelsim" in VUnit but Vivado needs the name "questasim". 

110 vivado_simlib = simlib_test.get_vivado_simlib( 

111 simulator_prefix=Path("/opt/intelFPGA_pro/22.2/questa_fse/bin"), 

112 vivado_path=Path("/tools/xilinx/Vivado/2019.2/bin/vivado"), 

113 simulator_class_name="modelsim", 

114 ) 

115 check_simulator_name(vivado_simlib=vivado_simlib, name="questasim") 

116 

117 # Aldec Riviera-PRO is called "rivierapro" in VUnit but Vivado needs the name "riviera" 

118 vivado_simlib = simlib_test.get_vivado_simlib( 

119 simulator_prefix=Path("/opt/Aldec/Riviera-PRO-1975.01-x64/bin"), 

120 vivado_path=Path("/tools/xilinx/Vivado/2019.2/bin/vivado"), 

121 simulator_class_name="rivierapro", 

122 ) 

123 check_simulator_name(vivado_simlib=vivado_simlib, name="riviera")