Fix CI issues!

This commit is contained in:
Caelan Sayler
2024-05-23 21:55:03 +01:00
parent 27ccd5c3ae
commit 3654e90e66
2 changed files with 92 additions and 173 deletions

View File

@@ -2,11 +2,6 @@ name: Build
on: [ push, pull_request ] on: [ push, pull_request ]
env:
VELOPACK_GITHUB_TEST_TOKEN: ${{ secrets.VELOPACK_GITHUB_TEST_TOKEN }}
VELOPACK_B2_TEST_TOKEN: ${{ secrets.VELOPACK_B2_TEST_TOKEN }}
VELOPACK_AZ_TEST_TOKEN: ${{ secrets.VELOPACK_AZ_TEST_TOKEN }}
jobs: jobs:
test-rust-bins: test-rust-bins:
strategy: strategy:
@@ -23,81 +18,6 @@ jobs:
run: | run: |
rustup update rustup update
rustc --version rustc --version
# https://github.com/actions/runner-images/issues/9701
- name: Install missing MSVC components
if: ${{ matrix.os == 'windows-latest' }}
run: |
Set-Location "C:\Program Files (x86)\Microsoft Visual Studio\Installer\"
$InstallPath = "C:\Program Files\Microsoft Visual Studio\2022\Enterprise"
$componentsToAdd = @(
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.ARM",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.ARM64",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.ARM",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.ARM64",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.x86.x64",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.x86.x64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ARM",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ARM64",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.ARM",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.ARM64",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.ARM",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.ARM64",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.x86.x64",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.x86.x64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ARM",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ARM64",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.ARM",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.ARM64",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.ARM",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.ARM64",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.x86.x64",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.x86.x64.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.ARM",
"Microsoft.VisualStudio.Component.VC.v141.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.ARM64",
"Microsoft.VisualStudio.Component.VC.v141.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.ATL",
"Microsoft.VisualStudio.Component.VC.v141.ATL.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.MFC",
"Microsoft.VisualStudio.Component.VC.v141.MFC.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.x86.x64",
"Microsoft.VisualStudio.Component.VC.v141.x86.x64.Spectre"
)
[string]$workloadArgs = $componentsToAdd | ForEach-Object {" --add " + $_}
$Arguments = ('/c', "vs_installer.exe", 'modify', '--installPath', "`"$InstallPath`"",$workloadArgs, '--quiet', '--norestart', '--nocache')
# should be run twice
$process = Start-Process -FilePath cmd.exe -ArgumentList $Arguments -Wait -PassThru -WindowStyle Hidden
$process = Start-Process -FilePath cmd.exe -ArgumentList $Arguments -Wait -PassThru -WindowStyle Hidden
- uses: actions/checkout@v4 - uses: actions/checkout@v4
with: with:
fetch-depth: 0 fetch-depth: 0
@@ -114,13 +34,11 @@ jobs:
- name: Test Rust - name: Test Rust
working-directory: src/Rust working-directory: src/Rust
run: cargo llvm-cov ${{ matrix.rust_flags }} --cobertura --output-path ../../test/coverage.rust.${{ matrix.os }}.xml run: cargo llvm-cov ${{ matrix.rust_flags }} --cobertura --output-path ../../test/coverage.rust.${{ matrix.os }}.xml
- name: Upload Coverage to Codecov - name: Upload Coverage Artifacts
uses: codecov/codecov-action@v4 uses: actions/upload-artifact@v4
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
with: with:
directory: ./test name: coverage-rust-${{ matrix.os }}
fail_ci_if_error: true path: ./test/*.xml
build-rust-bins: build-rust-bins:
strategy: strategy:
@@ -137,81 +55,6 @@ jobs:
run: | run: |
rustup update rustup update
rustc --version rustc --version
# https://github.com/actions/runner-images/issues/9701
- name: Install missing MSVC components
if: ${{ matrix.os == 'windows-latest' }}
run: |
Set-Location "C:\Program Files (x86)\Microsoft Visual Studio\Installer\"
$InstallPath = "C:\Program Files\Microsoft Visual Studio\2022\Enterprise"
$componentsToAdd = @(
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.ARM",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.ARM64",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.ATL.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.ARM",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.ARM64",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.MFC.Spectre",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.x86.x64",
"Microsoft.VisualStudio.Component.VC.14.29.16.11.x86.x64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ARM",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ARM64",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.ARM",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.ARM64",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.ATL.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.ARM",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.ARM64",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.MFC.Spectre",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.x86.x64",
"Microsoft.VisualStudio.Component.VC.14.38.17.8.x86.x64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ARM",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ARM64",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.ARM",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.ARM64",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.ATL.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.ARM",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.ARM64",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.MFC.Spectre",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.x86.x64",
"Microsoft.VisualStudio.Component.VC.14.39.17.9.x86.x64.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.ARM",
"Microsoft.VisualStudio.Component.VC.v141.ARM.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.ARM64",
"Microsoft.VisualStudio.Component.VC.v141.ARM64.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.ATL",
"Microsoft.VisualStudio.Component.VC.v141.ATL.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.MFC",
"Microsoft.VisualStudio.Component.VC.v141.MFC.Spectre",
"Microsoft.VisualStudio.Component.VC.v141.x86.x64",
"Microsoft.VisualStudio.Component.VC.v141.x86.x64.Spectre"
)
[string]$workloadArgs = $componentsToAdd | ForEach-Object {" --add " + $_}
$Arguments = ('/c', "vs_installer.exe", 'modify', '--installPath', "`"$InstallPath`"",$workloadArgs, '--quiet', '--norestart', '--nocache')
# should be run twice
$process = Start-Process -FilePath cmd.exe -ArgumentList $Arguments -Wait -PassThru -WindowStyle Hidden
$process = Start-Process -FilePath cmd.exe -ArgumentList $Arguments -Wait -PassThru -WindowStyle Hidden
- uses: actions/checkout@v4 - uses: actions/checkout@v4
with: with:
fetch-depth: 0 fetch-depth: 0
@@ -254,10 +97,13 @@ jobs:
strategy: strategy:
matrix: matrix:
os: [macos-latest, windows-latest, ubuntu-latest] os: [macos-latest, windows-latest, ubuntu-latest]
needs: [build-rust-bins]
runs-on: ${{ matrix.os }} runs-on: ${{ matrix.os }}
env: env:
NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages
VELOPACK_GITHUB_TEST_TOKEN: ${{ secrets.VELOPACK_GITHUB_TEST_TOKEN }}
VELOPACK_B2_TEST_TOKEN: ${{ secrets.VELOPACK_B2_TEST_TOKEN }}
VELOPACK_AZ_TEST_TOKEN: ${{ secrets.VELOPACK_AZ_TEST_TOKEN }}
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} # for gh cli
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
with: with:
@@ -279,26 +125,54 @@ jobs:
if: ${{ matrix.os == 'ubuntu-latest' }} if: ${{ matrix.os == 'ubuntu-latest' }}
- name: Install dotnet-coverage - name: Install dotnet-coverage
run: dotnet tool install -g dotnet-coverage run: dotnet tool install -g dotnet-coverage
- name: Build .NET
run: dotnet build -c Release
- name: Wait for artifacts
shell: pwsh
run: |
# Wait 15 minutes for the artifact to become available
$artifactName = "rust-${{ matrix.os }}"
$maxAttempts = 90
$sleepSeconds = 10
$attempt = 0
$workflowRunId = $env:GITHUB_RUN_ID
Write-Host "Waiting for artifact '$artifactName' to become available in workflow run $workflowRunId..."
while ($attempt -lt $maxAttempts) {
Write-Host "Checking for artifact '$artifactName', attempt $($attempt + 1)/$maxAttempts"
$artifactsJson = gh api repos/$env:GITHUB_REPOSITORY/actions/runs/$workflowRunId/artifacts
$artifacts = $artifactsJson | ConvertFrom-Json
if ($artifacts.artifacts | Where-Object { $_.name -eq $artifactName }) {
Write-Host "Artifact '$artifactName' is available."
break
}
Write-Host "Artifact not available yet. Sleeping for $sleepSeconds seconds..."
Start-Sleep -Seconds $sleepSeconds
$attempt++
}
if ($attempt -ge $maxAttempts) {
Write-Host "Artifact '$artifactName' did not become available in time."
exit 1
}
- name: Download Rust Artifacts - name: Download Rust Artifacts
uses: actions/download-artifact@v4 uses: actions/download-artifact@v4
with: with:
name: rust-${{ matrix.os }} name: rust-${{ matrix.os }}
path: src/Rust/target/release path: src/Rust/target/release
- name: Build .NET
run: dotnet build -c Release
- name: Test .NET Velopack.Tests - name: Test .NET Velopack.Tests
run: dotnet test --no-build -c Release -l "console;verbosity=detailed" test/Velopack.Tests/Velopack.Tests.csproj run: dotnet test --no-build -c Release -l "console;verbosity=detailed" test/Velopack.Tests/Velopack.Tests.csproj
- name: Test .NET Velopack.Packaging.Tests - name: Test .NET Velopack.Packaging.Tests
run: dotnet test --no-build -c Release -l "console;verbosity=detailed" test/Velopack.Packaging.Tests/Velopack.Packaging.Tests.csproj run: dotnet test --no-build -c Release -l "console;verbosity=detailed" test/Velopack.Packaging.Tests/Velopack.Packaging.Tests.csproj
- name: Test .NET Velopack.CommandLine.Tests - name: Test .NET Velopack.CommandLine.Tests
run: dotnet test --no-build -c Release -l "console;verbosity=detailed" test/Velopack.CommandLine.Tests/Velopack.CommandLine.Tests.csproj run: dotnet test --no-build -c Release -l "console;verbosity=detailed" test/Velopack.CommandLine.Tests/Velopack.CommandLine.Tests.csproj
- name: Upload Coverage to Codecov - name: Upload Coverage Artifacts
uses: codecov/codecov-action@v4 uses: actions/upload-artifact@v4
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
with: with:
directory: ./test name: coverage-dotnet-${{ matrix.os }}
fail_ci_if_error: true path: ./test/*.xml
package: package:
runs-on: ubuntu-latest runs-on: ubuntu-latest
@@ -332,6 +206,25 @@ jobs:
name: packages name: packages
path: build/Release/*.nupkg path: build/Release/*.nupkg
upload-coverage:
runs-on: ubuntu-latest
needs: [test-rust-bins, test-dotnet, package]
steps:
- name: Download Coverage Artifacts
uses: actions/download-artifact@v4
with:
pattern: coverage-*
path: ./test
- name: Upload Coverage to Codecov
uses: codecov/codecov-action@v4
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
with:
directory: ./test
fail_ci_if_error: true
# - name: Publish to GitHub Packages # - name: Publish to GitHub Packages
# shell: pwsh # shell: pwsh
# run: dotnet nuget push build/Release/*.nupkg -k ${{ secrets.GITHUB_TOKEN }} -s https://nuget.pkg.github.com/${{ github.repository_owner }}/index.json --skip-duplicate # run: dotnet nuget push build/Release/*.nupkg -k ${{ secrets.GITHUB_TOKEN }} -s https://nuget.pkg.github.com/${{ github.repository_owner }}/index.json --skip-duplicate

View File

@@ -27,6 +27,8 @@ pub trait ReadSeek: Read + Seek {}
impl<T: Read + Seek> ReadSeek for T {} impl<T: Read + Seek> ReadSeek for T {}
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]
#[used]
#[no_mangle]
static BUNDLE_PLACEHOLDER: [u8; 48] = [ static BUNDLE_PLACEHOLDER: [u8; 48] = [
0, 0, 0, 0, 0, 0, 0, 0, // 8 bytes for package offset 0, 0, 0, 0, 0, 0, 0, 0, // 8 bytes for package offset
0, 0, 0, 0, 0, 0, 0, 0, // 8 bytes for package length 0, 0, 0, 0, 0, 0, 0, 0, // 8 bytes for package length
@@ -37,10 +39,34 @@ static BUNDLE_PLACEHOLDER: [u8; 48] = [
]; ];
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]
#[inline(never)]
pub fn header_offset_and_length() -> (i64, i64) { pub fn header_offset_and_length() -> (i64, i64) {
let offset = i64::from_ne_bytes(BUNDLE_PLACEHOLDER[0..8].try_into().unwrap()); use core::ptr;
let length = i64::from_ne_bytes(BUNDLE_PLACEHOLDER[8..16].try_into().unwrap()); // Perform volatile reads to avoid optimization issues
(offset, length) // TODO: refactor to use little-endian, also need to update the writer in dotnet
unsafe {
let offset = i64::from_ne_bytes([
ptr::read_volatile(&BUNDLE_PLACEHOLDER[0]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[1]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[2]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[3]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[4]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[5]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[6]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[7]),
]);
let length = i64::from_ne_bytes([
ptr::read_volatile(&BUNDLE_PLACEHOLDER[8]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[9]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[10]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[11]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[12]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[13]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[14]),
ptr::read_volatile(&BUNDLE_PLACEHOLDER[15]),
]);
(offset, length)
}
} }
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]