Skip to content

Commit

Permalink
Testing new CD
Browse files Browse the repository at this point in the history
  • Loading branch information
jtsagata committed Jun 21, 2024
1 parent 61ecbcf commit 7766564
Show file tree
Hide file tree
Showing 4 changed files with 135 additions and 162 deletions.
5 changes: 0 additions & 5 deletions .cargo/config.toml

This file was deleted.

155 changes: 0 additions & 155 deletions .github/workflows/cd.yml

This file was deleted.

135 changes: 135 additions & 0 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,135 @@
name: CD #Continuous Deployment

on:
push:
tags:
- '[v]?[0-9]+.[0-9]+.[0-9]+'
workflow_dispatch:

env:
CRATE_NAME: places-cli
GITHUB_TOKEN: ${{ github.token }}
RUST_BACKTRACE: 1

jobs:
test:
name: ${{ matrix.platform.os_name }} with rust ${{ matrix.toolchain }}
runs-on: ${{ matrix.platform.os }}
strategy:
fail-fast: false
matrix:
platform:

- os_name: Linux-x86_64
os: ubuntu-20.04
target: x86_64-unknown-linux-musl
bin: places-cli
name: places-cli-Linux-x86_64-musl.tar.gz

- os_name: Linux-aarch64
os: ubuntu-20.04
target: aarch64-unknown-linux-musl
bin: places-cli
name: places-cli-Linux-aarch64-musl.tar.gz

- os_name: Linux-arm
os: ubuntu-20.04
target: arm-unknown-linux-musleabi
bin: places-cli
name: places-cli-Linux-arm-musl.tar.gz

- os_name: Linux-i686
os: ubuntu-20.04
target: i686-unknown-linux-musl
bin: places-cli
name: places-cli-Linux-i686-musl.tar.gz
skip_tests: true

- os_name: Linux-riscv64
os: ubuntu-20.04
target: riscv64gc-unknown-linux-gnu
bin: places-cli
name: places-cli-Linux-riscv64gc-gnu.tar.gz

- os_name: NetBSD-x86_64
os: ubuntu-20.04
target: x86_64-unknown-netbsd
bin: places-cli
name: places-cli-NetBSD-x86_64.tar.gz
skip_tests: true

- os_name: Windows-aarch64
os: windows-latest
target: aarch64-pc-windows-msvc
bin: places-cli.exe
name: places-cli-Windows-aarch64.zip
skip_tests: true

- os_name: Windows-x86_64
os: windows-latest
target: x86_64-pc-windows-msvc
bin: places-cli.exe
name: places-cli-Windows-x86_64.zip

- os_name: macOS-x86_64
os: macOS-latest
target: x86_64-apple-darwin
bin: places-cli
name: places-cli-Darwin-x86_64.tar.gz

- os_name: macOS-aarch64
os: macOS-latest
target: aarch64-apple-darwin
bin: places-cli
name: places-cli-Darwin-aarch64.tar.gz
skip_tests: true
toolchain:
- stable
steps:
- uses: actions/checkout@v4
- name: Cache cargo & target directories
uses: Swatinem/rust-cache@v2

- name: Install musl-tools on Linux
run: sudo apt-get update --yes && sudo apt-get install --yes musl-tools
if: contains(matrix.platform.name, 'musl')

- name: Build binary
uses: houseabsolute/actions-rust-cross@v0
with:
command: "build"
target: ${{ matrix.platform.target }}
toolchain: ${{ matrix.toolchain }}
args: "--locked --release"
strip: true

- name: Package as archive
shell: bash
run: |
cd target/${{ matrix.platform.target }}/release
if [[ "${{ matrix.platform.os }}" == "windows-latest" ]]; then
7z a ../../../${{ matrix.platform.name }} ${{ matrix.platform.bin }}
else
tar czvf ../../../${{ matrix.platform.name }} ${{ matrix.platform.bin }}
fi
cd -
if: |
matrix.toolchain == 'stable' &&
( startsWith( github.ref, 'refs/tags/v' ) ||
github.ref == 'refs/tags/test-release' )
- name: Generate SHA-256
run: shasum -a 256 ${{ matrix.platform.name }}
if: |
matrix.toolchain == 'stable' &&
matrix.platform.os == 'macOS-latest' &&
( startsWith( github.ref, 'refs/tags/v' ) ||
github.ref == 'refs/tags/test-release' )
- name: Publish GitHub release
uses: softprops/action-gh-release@v2
with:
draft: true
files: "places-cli-*"
body_path: CHANGELOG.md
if: matrix.toolchain == 'stable' && startsWith( github.ref, 'refs/tags/v' )
2 changes: 0 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -91,8 +91,6 @@ depends = "libc6:arm64 (>= 2.28)"
[package.metadata.deb.variants.armhf]
depends = "libc6:armhf (>= 2.28)"

[package.metadata.wix]
output = "places-cli_x86_64_installer.msi"

[package.metadata.generate-rpm]
assets = [
Expand Down

0 comments on commit 7766564

Please sign in to comment.