refactor: streamline artifact packaging and upload process in CI workflows

main
Yoo1tic 2025-08-11 00:29:13 +08:00
parent 0e5c03c468
commit c6a9c1d39b
2 changed files with 83 additions and 33 deletions

View File

@ -49,19 +49,15 @@ jobs:
- name: Build project - name: Build project
run: cargo build --release --target ${{ matrix.target_triple }} run: cargo build --release --target ${{ matrix.target_triple }}
- name: Create release package - name: Package artifact
run: | run: |
mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} . mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} ${{ matrix.release_name }}
mkdir -p release-package
mv ${{ matrix.artifact_name }} release-package/
cd release-package
zip -r ../${{ matrix.release_name }}.zip .
- name: Upload zipped artifact - name: Upload artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: ${{ matrix.release_name }} name: ${{ matrix.release_name }}
path: ${{ matrix.release_name }}.zip path: ${{ matrix.release_name }}
retention-days: 30 retention-days: 30
build-windows: build-windows:
@ -97,17 +93,16 @@ jobs:
- name: Build project - name: Build project
run: cargo build --release --target ${{ matrix.target_triple }} run: cargo build --release --target ${{ matrix.target_triple }}
- name: Create release package - name: Package artifact
run: | run: |
mkdir -p release-package mkdir -p release-package
mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} release-package/ mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} ${{ matrix.release_name }}
Compress-Archive -Path 'release-package\*' -DestinationPath "${{ matrix.release_name }}.zip" -CompressionLevel Optimal -Force
- name: Upload zipped artifact - name: Upload artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: ${{ matrix.release_name }} name: ${{ matrix.release_name }}
path: ${{ matrix.release_name }}.zip path: ${{ matrix.release_name }}
retention-days: 30 retention-days: 30
build-macos: build-macos:
@ -147,17 +142,13 @@ jobs:
- name: Build project - name: Build project
run: cargo build --release --target ${{ matrix.target_triple }} run: cargo build --release --target ${{ matrix.target_triple }}
- name: Create release package - name: Package artifact
run: | run: |
mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} . mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} ${{ matrix.release_name }}
mkdir -p release-package
mv ${{ matrix.artifact_name }} release-package/
cd release-package
zip -r ../${{ matrix.release_name }}.zip .
- name: Upload zipped artifact - name: Upload artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: ${{ matrix.release_name }} name: ${{ matrix.release_name }}
path: ${{ matrix.release_name }}.zip path: ${{ matrix.release_name }}
retention-days: 30 retention-days: 30

View File

@ -51,14 +51,15 @@ jobs:
- name: Build project - name: Build project
run: cargo build --release --target ${{ matrix.target_triple }} run: cargo build --release --target ${{ matrix.target_triple }}
- name: Create release package and zip - name: Create release package
run: | run: |
mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} .
mkdir -p release-package mkdir -p release-package
cp target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} release-package/ mv ${{ matrix.artifact_name }} release-package/
cd release-package cd release-package
zip -r ../${{ matrix.release_name }}.zip . zip -r ../${{ matrix.release_name }}.zip .
- name: Upload artifact - name: Upload zipped artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: ${{ matrix.release_name }} name: ${{ matrix.release_name }}
@ -68,6 +69,13 @@ jobs:
build-windows: build-windows:
name: Build Windows name: Build Windows
runs-on: windows-latest runs-on: windows-latest
strategy:
matrix:
include:
- target: x86_64
target_triple: x86_64-pc-windows-msvc
artifact_name: gemini-keychecker.exe
release_name: gemini-keychecker-windows-x86_64
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
@ -75,7 +83,7 @@ jobs:
- name: Install Rust toolchain - name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable uses: dtolnay/rust-toolchain@stable
with: with:
targets: x86_64-pc-windows-msvc targets: ${{ matrix.target_triple }}
- name: Cache cargo dependencies - name: Cache cargo dependencies
uses: actions/cache@v4 uses: actions/cache@v4
@ -89,20 +97,71 @@ jobs:
${{ runner.os }}-cargo- ${{ runner.os }}-cargo-
- name: Build project - name: Build project
run: cargo build --release --target x86_64-pc-windows-msvc run: cargo build --release --target ${{ matrix.target_triple }}
- name: Create release package and zip - name: Create release package
run: | run: |
mkdir -p release-package mkdir -p release-package
cp target/x86_64-pc-windows-msvc/release/gemini-keychecker.exe release-package/ mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} release-package/
cd release-package Compress-Archive -Path 'release-package\*' -DestinationPath "${{ matrix.release_name }}.zip" -CompressionLevel Optimal -Force
Compress-Archive -Path * -DestinationPath ../gemini-keychecker-windows-x86_64.zip
- name: Upload artifact - name: Upload zipped artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: gemini-keychecker-windows-x86_64 name: ${{ matrix.release_name }}
path: gemini-keychecker-windows-x86_64.zip path: ${{ matrix.release_name }}.zip
retention-days: 1
build-macos:
name: Build macOS
runs-on: macos-latest
strategy:
matrix:
include:
- target: x86_64
target_triple: x86_64-apple-darwin
artifact_name: gemini-keychecker
release_name: gemini-keychecker-macos-x86_64
- target: aarch64
target_triple: aarch64-apple-darwin
artifact_name: gemini-keychecker
release_name: gemini-keychecker-macos-aarch64
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
with:
targets: ${{ matrix.target_triple }}
- name: Cache cargo dependencies
uses: actions/cache@v4
with:
path: |
~/.cargo/registry
~/.cargo/git
target
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
restore-keys: |
${{ runner.os }}-cargo-
- name: Build project
run: cargo build --release --target ${{ matrix.target_triple }}
- name: Create release package
run: |
mv target/${{ matrix.target_triple }}/release/${{ matrix.artifact_name }} .
mkdir -p release-package
mv ${{ matrix.artifact_name }} release-package/
cd release-package
zip -r ../${{ matrix.release_name }}.zip .
- name: Upload zipped artifact
uses: actions/upload-artifact@v4
with:
name: ${{ matrix.release_name }}
path: ${{ matrix.release_name }}.zip
retention-days: 1 retention-days: 1
release: release: