]> git.proxmox.com Git - mirror_edk2.git/blame - .pytool/CISettings.py
.pytool/CISettings: Remove Windows only scope for host based unit tests
[mirror_edk2.git] / .pytool / CISettings.py
CommitLineData
4eb2baba
SB
1# @file\r
2#\r
3# Copyright (c) Microsoft Corporation.\r
e6956d00 4# Copyright (c) 2020, Hewlett Packard Enterprise Development LP. All rights reserved.<BR>\r
4eb2baba
SB
5# SPDX-License-Identifier: BSD-2-Clause-Patent\r
6##\r
7import os\r
8import logging\r
9from edk2toolext.environment import shell_environment\r
10from edk2toolext.invocables.edk2_ci_build import CiBuildSettingsManager\r
11from edk2toolext.invocables.edk2_setup import SetupSettingsManager, RequiredSubmodule\r
12from edk2toolext.invocables.edk2_update import UpdateSettingsManager\r
13from edk2toolext.invocables.edk2_pr_eval import PrEvalSettingsManager\r
14from edk2toollib.utility_functions import GetHostInfo\r
15\r
16\r
17class Settings(CiBuildSettingsManager, UpdateSettingsManager, SetupSettingsManager, PrEvalSettingsManager):\r
18\r
19 def __init__(self):\r
20 self.ActualPackages = []\r
21 self.ActualTargets = []\r
22 self.ActualArchitectures = []\r
23 self.ActualToolChainTag = ""\r
24\r
25 # ####################################################################################### #\r
26 # Extra CmdLine configuration #\r
27 # ####################################################################################### #\r
28\r
29 def AddCommandLineOptions(self, parserObj):\r
30 pass\r
31\r
32 def RetrieveCommandLineOptions(self, args):\r
33 pass\r
34\r
35 # ####################################################################################### #\r
36 # Default Support for this Ci Build #\r
37 # ####################################################################################### #\r
38\r
39 def GetPackagesSupported(self):\r
40 ''' return iterable of edk2 packages supported by this build.\r
41 These should be edk2 workspace relative paths '''\r
42\r
0358c0bf
SB
43 return ("ArmVirtPkg",\r
44 "EmulatorPkg",\r
45 "MdePkg",\r
4eb2baba
SB
46 "MdeModulePkg",\r
47 "NetworkPkg",\r
48 "PcAtChipsetPkg",\r
49 "SecurityPkg",\r
50 "UefiCpuPkg",\r
51 "FmpDevicePkg",\r
52 "ShellPkg",\r
53 "FatPkg",\r
61364ab9 54 "CryptoPkg",\r
0358c0bf
SB
55 "UnitTestFrameworkPkg",\r
56 "OvmfPkg"\r
4eb2baba
SB
57 )\r
58\r
59 def GetArchitecturesSupported(self):\r
60 ''' return iterable of edk2 architectures supported by this build '''\r
e6956d00
AC
61 return (\r
62 "IA32",\r
4eb2baba
SB
63 "X64",\r
64 "ARM",\r
e6956d00
AC
65 "AARCH64",\r
66 "RISCV64")\r
4eb2baba
SB
67\r
68 def GetTargetsSupported(self):\r
69 ''' return iterable of edk2 target tags supported by this build '''\r
70 return ("DEBUG", "RELEASE", "NO-TARGET", "NOOPT")\r
71\r
72 # ####################################################################################### #\r
73 # Verify and Save requested Ci Build Config #\r
74 # ####################################################################################### #\r
75\r
76 def SetPackages(self, list_of_requested_packages):\r
77 ''' Confirm the requested package list is valid and configure SettingsManager\r
78 to build the requested packages.\r
79\r
80 Raise UnsupportedException if a requested_package is not supported\r
81 '''\r
82 unsupported = set(list_of_requested_packages) - \\r
83 set(self.GetPackagesSupported())\r
84 if(len(unsupported) > 0):\r
85 logging.critical(\r
86 "Unsupported Package Requested: " + " ".join(unsupported))\r
87 raise Exception("Unsupported Package Requested: " +\r
88 " ".join(unsupported))\r
89 self.ActualPackages = list_of_requested_packages\r
90\r
91 def SetArchitectures(self, list_of_requested_architectures):\r
92 ''' Confirm the requests architecture list is valid and configure SettingsManager\r
93 to run only the requested architectures.\r
94\r
95 Raise Exception if a list_of_requested_architectures is not supported\r
96 '''\r
97 unsupported = set(list_of_requested_architectures) - \\r
98 set(self.GetArchitecturesSupported())\r
99 if(len(unsupported) > 0):\r
100 logging.critical(\r
101 "Unsupported Architecture Requested: " + " ".join(unsupported))\r
102 raise Exception(\r
103 "Unsupported Architecture Requested: " + " ".join(unsupported))\r
104 self.ActualArchitectures = list_of_requested_architectures\r
105\r
106 def SetTargets(self, list_of_requested_target):\r
107 ''' Confirm the request target list is valid and configure SettingsManager\r
108 to run only the requested targets.\r
109\r
110 Raise UnsupportedException if a requested_target is not supported\r
111 '''\r
112 unsupported = set(list_of_requested_target) - \\r
113 set(self.GetTargetsSupported())\r
114 if(len(unsupported) > 0):\r
115 logging.critical(\r
116 "Unsupported Targets Requested: " + " ".join(unsupported))\r
117 raise Exception("Unsupported Targets Requested: " +\r
118 " ".join(unsupported))\r
119 self.ActualTargets = list_of_requested_target\r
120\r
121 # ####################################################################################### #\r
122 # Actual Configuration for Ci Build #\r
123 # ####################################################################################### #\r
124\r
125 def GetActiveScopes(self):\r
126 ''' return tuple containing scopes that should be active for this process '''\r
61364ab9 127 scopes = ("cibuild", "edk2-build", "host-based-test")\r
4eb2baba
SB
128\r
129 self.ActualToolChainTag = shell_environment.GetBuildVars().GetValue("TOOL_CHAIN_TAG", "")\r
130\r
131 if GetHostInfo().os.upper() == "LINUX" and self.ActualToolChainTag.upper().startswith("GCC"):\r
132 if "AARCH64" in self.ActualArchitectures:\r
133 scopes += ("gcc_aarch64_linux",)\r
134 if "ARM" in self.ActualArchitectures:\r
135 scopes += ("gcc_arm_linux",)\r
e6956d00
AC
136 if "RISCV64" in self.ActualArchitectures:\r
137 scopes += ("gcc_riscv64_unknown",)\r
4eb2baba
SB
138\r
139 return scopes\r
140\r
141 def GetRequiredSubmodules(self):\r
142 ''' return iterable containing RequiredSubmodule objects.\r
143 If no RequiredSubmodules return an empty iterable\r
144 '''\r
61364ab9 145 rs = []\r
4eb2baba
SB
146 rs.append(RequiredSubmodule(\r
147 "ArmPkg/Library/ArmSoftFloatLib/berkeley-softfloat-3", False))\r
148 rs.append(RequiredSubmodule(\r
149 "CryptoPkg/Library/OpensslLib/openssl", False))\r
61364ab9
MK
150 rs.append(RequiredSubmodule(\r
151 "UnitTestFrameworkPkg/Library/CmockaLib/cmocka", False))\r
48b6c60c
SZ
152 rs.append(RequiredSubmodule(\r
153 "MdeModulePkg/Universal/RegularExpressionDxe/oniguruma", False))\r
58802e02
SZ
154 rs.append(RequiredSubmodule(\r
155 "MdeModulePkg/Library/BrotliCustomDecompressLib/brotli", False))\r
06033f5a
SZ
156 rs.append(RequiredSubmodule(\r
157 "BaseTools/Source/C/BrotliCompress/brotli", False))\r
4eb2baba
SB
158 return rs\r
159\r
160 def GetName(self):\r
161 return "Edk2"\r
162\r
163 def GetDependencies(self):\r
61364ab9
MK
164 return [\r
165 ]\r
4eb2baba
SB
166\r
167 def GetPackagesPath(self):\r
168 return ()\r
169\r
170 def GetWorkspaceRoot(self):\r
171 ''' get WorkspacePath '''\r
172 return os.path.dirname(os.path.dirname(os.path.abspath(__file__)))\r
173\r
174 def FilterPackagesToTest(self, changedFilesList: list, potentialPackagesList: list) -> list:\r
175 ''' Filter potential packages to test based on changed files. '''\r
61364ab9
MK
176 build_these_packages = []\r
177 possible_packages = potentialPackagesList.copy()\r
4eb2baba 178 for f in changedFilesList:\r
61364ab9
MK
179 # split each part of path for comparison later\r
180 nodes = f.split("/")\r
4eb2baba
SB
181\r
182 # python file change in .pytool folder causes building all\r
183 if f.endswith(".py") and ".pytool" in nodes:\r
184 build_these_packages = possible_packages\r
185 break\r
186\r
187 # BaseTools files that might change the build\r
188 if "BaseTools" in nodes:\r
189 if os.path.splitext(f) not in [".txt", ".md"]:\r
190 build_these_packages = possible_packages\r
191 break\r
192 return build_these_packages\r