Skip to content

Commit

Permalink
Add PowerShell 7.4 language worker for integration testing (#3270)
Browse files Browse the repository at this point in the history
* Add PowerShell 7.4 language worker

* Filter runtimes for PowerShell 7.4

* Add PowerShell 7.4 to the list of workers to validate
  • Loading branch information
Francisco-Gamino authored Mar 28, 2023
1 parent 092e05d commit 8c31f21
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 13 deletions.
57 changes: 45 additions & 12 deletions build/Settings.cs
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ private static string config(string @default = null, [CallerMemberName] string k
public const string TemplateJsonVersion = "3.1.1648";

public static readonly string SBOMManifestToolPath = Path.GetFullPath("../ManifestTool/Microsoft.ManifestTool.dll");

public static readonly string SrcProjectPath = Path.GetFullPath("../src/Azure.Functions.Cli/");

public static readonly string ConstantsFile = Path.Combine(SrcProjectPath, "Common", "Constants.cs");
Expand Down Expand Up @@ -79,6 +79,43 @@ private static string config(string @default = null, [CallerMemberName] string k
"win7-x64"
};

private static readonly string[] _linPowershellRuntimes = new[]
{
"linux",
"linux-x64",
"unix",
"linux-musl-x64"
};

private static readonly string[] _osxPowershellRuntimes = new[]
{
"osx",
"osx-x64",
"unix"
};

private static readonly string[] _osxARMPowershellRuntimes = new[]
{
"osx",
"osx-arm64",
"unix"
};

private static Dictionary<string, string[]> GetPowerShellRuntimes()
{
var runtimes = new Dictionary<string, string[]>
{
{ "win-x86", _winPowershellRuntimes },
{ "win-x64", _winPowershellRuntimes },
{ "win-arm64", _winPowershellRuntimes },
{ "linux-x64", _linPowershellRuntimes },
{ "osx-x64", _osxPowershellRuntimes },
{ "osx-arm64", _osxARMPowershellRuntimes }
};

return runtimes;
}

public static readonly Dictionary<string, Dictionary<string, string[]>> ToolsRuntimeToPowershellRuntimes = new Dictionary<string, Dictionary<string, string[]>>
{
{
Expand All @@ -88,8 +125,8 @@ private static string config(string @default = null, [CallerMemberName] string k
{ "win-x86", _winPowershellRuntimes },
{ "win-x64", _winPowershellRuntimes },
{ "win-arm64", _winPowershellRuntimes },
{ "linux-x64", new [] { "linux", "linux-x64", "unix", "linux-musl-x64" } },
{ "osx-x64", new [] { "osx", "osx-x64", "unix" } },
{ "linux-x64", _linPowershellRuntimes },
{ "osx-x64", _osxPowershellRuntimes },
// NOTE: PowerShell 7.0 does not support arm. First version supporting it is 7.2
// https://docs.microsoft.com/en-us/powershell/scripting/install/installing-powershell-on-macos?view=powershell-7.2#supported-versions
// That being said, we might as well include "osx" and "unix" since it'll hardly affect package size and should lead to more accurate error messages
Expand All @@ -98,15 +135,11 @@ private static string config(string @default = null, [CallerMemberName] string k
},
{
"7.2",
new Dictionary<string, string[]>
{
{ "win-x86", _winPowershellRuntimes },
{ "win-x64", _winPowershellRuntimes },
{ "win-arm64", _winPowershellRuntimes },
{ "linux-x64", new [] { "linux", "linux-x64", "unix", "linux-musl-x64" } },
{ "osx-x64", new [] { "osx", "osx-x64", "unix" } },
{ "osx-arm64", new [] { "osx", "osx-arm64", "unix" } }
}
GetPowerShellRuntimes()
},
{
"7.4",
GetPowerShellRuntimes()
}
};

Expand Down
1 change: 1 addition & 0 deletions src/Azure.Functions.Cli/Azure.Functions.Cli.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,7 @@
<PackageReference Include="Microsoft.Azure.Functions.NodeJsWorker" Version="3.5.2" />
<PackageReference Include="Microsoft.Azure.Functions.PowerShellWorker.PS7.0" Version="4.0.2302" />
<PackageReference Include="Microsoft.Azure.Functions.PowerShellWorker.PS7.2" Version="4.0.2673" />
<PackageReference Include="Microsoft.Azure.Functions.PowerShellWorker.PS7.4" Version="4.0.2669" />
<PackageReference Include="Microsoft.Azure.Functions.PythonWorker" Version="4.10.1" />
</ItemGroup>
<Target Name="ExcludeWorkersFromReadyToRun">
Expand Down
2 changes: 1 addition & 1 deletion validateWorkerVersions.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ function getHostFileContent([string]$filePath) {
$hostCsprojContent = getHostFileContent "src/WebJobs.Script/WebJobs.Script.csproj"
$pythonPropsContent = getHostFileContent "build/python.props"

$workers = "JavaWorker", "NodeJsWorker", "PowerShellWorker.PS7.0", "PowerShellWorker.PS7.2", "PythonWorker"
$workers = "JavaWorker", "NodeJsWorker", "PowerShellWorker.PS7.0", "PowerShellWorker.PS7.2", "PowerShellWorker.PS7.4", "PythonWorker"

$failedValidation = $false
foreach($worker in $workers) {
Expand Down

0 comments on commit 8c31f21

Please sign in to comment.