Skip to content

chore(deps): bump taiki-e/install-action from 2.46.8 to 2.46.11 #3719

chore(deps): bump taiki-e/install-action from 2.46.8 to 2.46.11

chore(deps): bump taiki-e/install-action from 2.46.8 to 2.46.11 #3719

name: secrets-nats-kv
on:
merge_group:
push:
branches: [main]
tags:
- 'secrets-nats-kv-v[0-9].[0-9]+.[0-9]+'
- 'secrets-nats-kv-v[0-9].[0-9]+.[0-9]+-*'
pull_request:
branches: [main]
paths:
- .github/workflows/secrets-nats-kv.yml
- Cargo.lock
- Cargo.toml
- crates/secrets-nats-kv/**
- crates/secrets-client/**
- crates/secrets-types/**
permissions:
contents: read
concurrency:
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
cancel-in-progress: true
env:
CARGO_TERM_COLOR: always
jobs:
integration_tests:
name: Integration Tests
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
- run: rustup show
- uses: Swatinem/rust-cache@82a92a6e8fbeee089604da2575dc567ae9ddeaab
with:
shared-key: "ubuntu-22.04-shared-cache"
- name: Launch integration test services
uses: sudo-bot/action-docker-compose@ef4c4da08a9673f93d4eb8a5da1e942bf24a37ea
with:
cli-args: "-f ./crates/secrets-nats-kv/tools/docker-compose.yml up --detach"
- name: Install nextest
uses: taiki-e/install-action@ed8c79bccf0b1cb1544a358f81684d3acaa5133f
with:
tool: nextest
- name: Run integration tests
run: make test-integration-ci
working-directory: ./crates/secrets-nats-kv
release-build:
if: ${{ startsWith(github.ref, 'refs/tags/secrets-nats-kv-v') }}
runs-on: ${{ matrix.build.runs-on }}
permissions:
contents: write
strategy:
matrix:
build:
- os: linux
arch: amd64
abi: gnu
runs-on: ubuntu-22.04
rust-target: x86_64-unknown-linux-gnu
- os: linux
arch: amd64
abi: musl
runs-on: ubuntu-22.04
rust-target: x86_64-unknown-linux-musl
- os: darwin
arch: amd64
runs-on: macos-13
rust-target: x86_64-apple-darwin
- os: darwin
arch: aarch64
runs-on: macos-14
rust-target: aarch64-apple-darwin
- os: windows
arch: amd64
abi: msvc
runs-on: windows-2022
rust-target: x86_64-pc-windows-msvc
- os: linux
arch: aarch64
abi: gnu
runs-on: ubuntu-22.04
rust-target: aarch64-unknown-linux-gnu
skip-test: true # No runner on GH for this yet
- os: linux
arch: aarch64
abi: musl
runs-on: ubuntu-22.04
rust-target: aarch64-unknown-linux-musl
skip-test: true # No runner on GH for this yet
steps:
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
- run: rustup target add ${{ matrix.build.rust-target }}
- uses: Swatinem/rust-cache@82a92a6e8fbeee089604da2575dc567ae9ddeaab
with:
shared-key: "ubuntu-22.04-shared-cache"
- name: Extract tag context
id: ctx
shell: bash
run: |
sha_short=$(git rev-parse --short HEAD)
echo "sha_short=${sha_short}" >> "$GITHUB_OUTPUT"
version=$(cargo metadata --manifest-path "./crates/secrets-nats-kv/Cargo.toml" --no-deps --format-version 1 | jq -r '.packages[] | select(.name == "wasmcloud-nats-kv-secrets") | .version')
echo "untagged version is ${version}"
echo "untagged version ${version} is a pre-release"
echo "version=${version}" >> "$GITHUB_OUTPUT"
if [[ $version == *"-"* ]]; then
echo "tagged version ${version} is a pre-release"
echo "prerelease=true" >> "$GITHUB_OUTPUT"
fi
- name: Install musl toolchain
if: ${{ matrix.build.abi == 'musl' }}
run: |
sudo apt-get install -y musl-tools clang llvm
- name: Install aarch64 toolchain
if: ${{ matrix.build.abi == 'gnu' && matrix.build.arch == 'aarch64' }}
run: |
sudo apt-get install -y gcc-aarch64-linux-gnu
- name: Build
shell: bash
run: |
export PLATFORM="${{ matrix.build.arch }}-${{ matrix.build.os }}-${{ matrix.build.abi }}";
if [ "aarch64-linux-gnu" == "$PLATFORM" ]; then
export CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER=/usr/bin/aarch64-linux-gnu-gcc
elif [ "aarch64-linux-musl" == "$PLATFORM" ]; then
export CC_aarch64_unknown_linux_musl=clang;
export AR_aarch64_unknown_linux_musl=llvm-ar;
export CARGO_TARGET_AARCH64_UNKNOWN_LINUX_MUSL_RUSTFLAGS="-Clink-self-contained=yes -Clinker=rust-lld";
fi
cargo build --release -p secrets-nats-kv --target ${{ matrix.build.rust-target }}
- name: Determine binary name
id: bin-name
shell: bash
run: |
if [ "" == "${{ matrix.build.abi }}" ]; then
export BIN_NAME=secrets-nats-kv-${{ matrix.build.arch }}-${{ matrix.build.os }};
else
export BIN_NAME=secrets-nats-kv-${{ matrix.build.arch }}-${{ matrix.build.os }}-${{ matrix.build.abi }};
fi
echo "bin-name=$BIN_NAME" >> $GITHUB_OUTPUT;
- name: Basic binary test
if: ${{ !matrix.build.skip-test }}
run: |
./target/${{ matrix.build.rust-target}}/release/secrets-nats-kv --version
- name: Copy binary
shell: bash
run: |
mkdir artifacts;
cp ./target/${{ matrix.build.rust-target}}/release/secrets-nats-kv artifacts/${{ steps.bin-name.outputs.bin-name }}
- uses: actions/upload-artifact@b4b15b8c7c6ac21ea08fcf65892d2ee8f75cf882
with:
name: ${{ steps.bin-name.outputs.bin-name }}
path:
artifacts/*
release:
if: ${{ startsWith(github.ref, 'refs/tags/secrets-nats-kv-v') }}
needs: [ release-build ]
runs-on: ubuntu-22.04
permissions:
contents: write
steps:
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
- name: Extract tag context
id: ctx
shell: bash
run: |
sha_short=$(git rev-parse --short HEAD)
echo "sha_short=${sha_short}" >> "$GITHUB_OUTPUT"
version=$(cargo metadata --manifest-path "./crates/secrets-nats-kv/Cargo.toml" --no-deps --format-version 1 | jq -r '.packages[] | select(.name == "wasmcloud-nats-kv-secrets") | .version')
echo "untagged version is ${version}"
echo "untagged version ${version} is a pre-release"
echo "version=${version}" >> "$GITHUB_OUTPUT"
if [[ $version == *"-"* ]]; then
echo "tagged version ${version} is a pre-release"
echo "prerelease=true" >> "$GITHUB_OUTPUT"
fi
- uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16
with:
pattern: secrets-nats-kv-*
merge-multiple: true
path: artifacts
- name: Add musl versions as default linux binaries
run: |
cp artifacts/secrets-nats-kv-amd64-linux-musl artifacts/secrets-nats-kv-amd64-linux
cp artifacts/secrets-nats-kv-aarch64-linux-musl artifacts/secrets-nats-kv-aarch64-linux
- name: Release
uses: softprops/action-gh-release@7b4da11513bf3f43f9999e90eabced41ab8bb048
with:
draft: true
prerelease: ${{ steps.ctx.outputs.prerelease != '' }}
generate_release_notes: true
files: |
./artifacts/*