Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 15 additions & 5 deletions Tasks/PackageTask.cs
Original file line number Diff line number Diff line change
Expand Up @@ -17,30 +17,40 @@ public override async Task RunAsync(BuildContext context)
// local artifacts so we can test/run this locally as well
if (context.BuildSystem().IsRunningOnGitHubActions)
{
context.Information("Running on github actions, attempting to download artifacts from previous publish step");
string[] requiredRids = context.IsUniversalBinary ?
["windows-x64", "linux-x64", "linux-arm64", "osx"] :
["windows-x64", "linux-x64", "linux-arm64", "osx-x64", "osx-arm64"];
["windows-x64", "windows-arm64", "linux-x64", "linux-arm64", "osx"] :
["windows-x64", "windows-arm64", "linux-x64", "linux-arm64", "osx-x64", "osx-arm64"];

foreach (var rid in requiredRids)
{
var directoryPath = new DirectoryPath($"{projectDir}/binaries/{rid}");
if (context.DirectoryExists(directoryPath))
continue;

context.Information($"Attempting to download artifacts for {rid} to {directoryPath}");
context.CreateDirectory(directoryPath);
try
{
await context.BuildSystem().GitHubActions.Commands.DownloadArtifact($"artifacts-{rid}", directoryPath);
}
catch { }
catch (Exception ex)
{
context.Warning($"Failed to download artifacts for {rid}, exception: {ex}");
}
}
}
else
{
context.Information("Not running on github actions, copying local artifacts");
string rid = string.Empty;
if (context.IsRunningOnWindows())
{
rid = "windows-x64";
rid = RuntimeInformation.ProcessArchitecture switch
{
Architecture.Arm or Architecture.Arm64 => "windows-arm64",
_ => "windows-x64"
};
}
else if (context.IsRunningOnLinux())
{
Expand Down Expand Up @@ -144,4 +154,4 @@ private static async Task SaveEmbeddedResourceAsync(string resourceName, string
await stream.CopyToAsync(writer);
writer.Close();
}
}
}
16 changes: 15 additions & 1 deletion Tasks/PublishToolTask.cs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,20 @@ public override async Task RunAsync(BuildContext context)
var copyToDir = $"artifacts-{rid}";
if (context.BuildSystem().IsRunningOnGitHubActions)
{
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
{
// we need to upload each rid of windows separately.
var directories = Directory.GetDirectories(context.ArtifactsDir, "windows-*");
if (directories.Any())
{
foreach (var dir in directories)
{
var dirName = new DirectoryInfo(dir).Name;
await context.BuildSystem().GitHubActions.Commands.UploadArtifact(DirectoryPath.FromString(dir), $"artifacts-{dirName}");
}
return;
}
}
await context.BuildSystem().GitHubActions.Commands.UploadArtifact(DirectoryPath.FromString(context.ArtifactsDir), copyToDir);
}
else
Expand All @@ -41,4 +55,4 @@ public override async Task RunAsync(BuildContext context)
}
}
}
}
}