mirror of
https://github.com/alexpasmantier/television.git
synced 2025-06-07 12:05:34 +00:00
parent
d601eb2c02
commit
f954e81e4c
68
.github/workflows/cd.yml
vendored
68
.github/workflows/cd.yml
vendored
@ -1,11 +1,18 @@
|
|||||||
name: CD # Continuous Deployment
|
name: CD # Continuous Deployment
|
||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
tags:
|
tags:
|
||||||
- '[v]?[0-9]+.[0-9]+.[0-9]+'
|
- '[v]?[0-9]+.[0-9]+.[0-9]+'
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
tag:
|
||||||
|
description: 'Tag to deploy'
|
||||||
|
required: true
|
||||||
|
default: '0.0.0'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
create-release:
|
create-release:
|
||||||
name: Create a release
|
name: Create a release
|
||||||
@ -17,6 +24,7 @@ jobs:
|
|||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Generate a changelog
|
- name: Generate a changelog
|
||||||
uses: orhun/git-cliff-action@v4
|
uses: orhun/git-cliff-action@v4
|
||||||
with:
|
with:
|
||||||
@ -24,14 +32,19 @@ jobs:
|
|||||||
args: --latest --strip header
|
args: --latest --strip header
|
||||||
env:
|
env:
|
||||||
OUTPUT: BODY.md
|
OUTPUT: BODY.md
|
||||||
|
|
||||||
- name: Publish on GitHub
|
- name: Publish on GitHub
|
||||||
uses: ncipollo/release-action@v1
|
uses: ncipollo/release-action@v1
|
||||||
with:
|
with:
|
||||||
prerelease: false
|
prerelease: false
|
||||||
bodyFile: BODY.md
|
bodyFile: BODY.md
|
||||||
|
|
||||||
|
|
||||||
publish-release:
|
publish-release:
|
||||||
|
|
||||||
name: Publishing for ${{ matrix.os }}
|
name: Publishing for ${{ matrix.os }}
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
@ -77,6 +90,7 @@ jobs:
|
|||||||
binary-postfix: ""
|
binary-postfix: ""
|
||||||
use-cross: true
|
use-cross: true
|
||||||
binary-name: tv
|
binary-name: tv
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@ -84,7 +98,9 @@ jobs:
|
|||||||
uses: actions-rs/toolchain@v1
|
uses: actions-rs/toolchain@v1
|
||||||
with:
|
with:
|
||||||
toolchain: stable
|
toolchain: stable
|
||||||
|
|
||||||
target: ${{ matrix.target }}
|
target: ${{ matrix.target }}
|
||||||
|
|
||||||
profile: minimal
|
profile: minimal
|
||||||
override: true
|
override: true
|
||||||
- uses: Swatinem/rust-cache@v2
|
- uses: Swatinem/rust-cache@v2
|
||||||
@ -92,12 +108,18 @@ jobs:
|
|||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: build
|
command: build
|
||||||
|
|
||||||
use-cross: ${{ matrix.use-cross }}
|
use-cross: ${{ matrix.use-cross }}
|
||||||
|
|
||||||
toolchain: stable
|
toolchain: stable
|
||||||
|
|
||||||
args: --release --target ${{ matrix.target }}
|
args: --release --target ${{ matrix.target }}
|
||||||
|
|
||||||
|
|
||||||
- name: install strip command
|
- name: install strip command
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |2
|
run: |
|
||||||
|
|
||||||
if [[ ${{ matrix.target }} == aarch64-unknown-linux-gnu ]]; then
|
if [[ ${{ matrix.target }} == aarch64-unknown-linux-gnu ]]; then
|
||||||
|
|
||||||
sudo apt update
|
sudo apt update
|
||||||
@ -105,7 +127,8 @@ jobs:
|
|||||||
fi
|
fi
|
||||||
- name: Packaging final binary
|
- name: Packaging final binary
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |2
|
run: |
|
||||||
|
|
||||||
cd target/${{ matrix.target }}/release
|
cd target/${{ matrix.target }}/release
|
||||||
|
|
||||||
|
|
||||||
@ -142,62 +165,84 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
Compress-Archive -Path "$env:BINARY_NAME" -Destination "$($env:RELEASE_NAME).zip"
|
Compress-Archive -Path "$env:BINARY_NAME" -Destination "$($env:RELEASE_NAME).zip"
|
||||||
(Get-FileHash "$($env:RELEASE_NAME).zip" -Algorithm SHA256).Hash.ToLower() > "$($env:RELEASE_NAME).zip.sha256"
|
(Get-FileHash "$($env:RELEASE_NAME).zip" -Algorithm SHA256).Hash.ToLower() > "$($env:RELEASE_NAME).zip.sha256"
|
||||||
|
|
||||||
- name: Releasing assets
|
- name: Releasing assets
|
||||||
uses: softprops/action-gh-release@v2
|
uses: softprops/action-gh-release@v2
|
||||||
with:
|
with:
|
||||||
files: |
|
files: |
|
||||||
|
|
||||||
target/${{ matrix.target }}/release/${{ matrix.binary-name }}-*.tar.gz
|
target/${{ matrix.target }}/release/${{ matrix.binary-name }}-*.tar.gz
|
||||||
target/${{ matrix.target }}/release/${{ matrix.binary-name }}-*.zip
|
target/${{ matrix.target }}/release/${{ matrix.binary-name }}-*.zip
|
||||||
target/${{ matrix.target }}/release/${{ matrix.binary-name }}-*.sha256
|
target/${{ matrix.target }}/release/${{ matrix.binary-name }}-*.sha256
|
||||||
|
|
||||||
env:
|
env:
|
||||||
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
publish-release-deb:
|
publish-release-deb:
|
||||||
name: publish-release-deb for ${{ matrix.target }}
|
name: publish-release-deb
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
include:
|
|
||||||
- target: x86_64-unknown-linux-musl
|
|
||||||
env:
|
env:
|
||||||
TARGET: ${{ matrix.target }}
|
TARGET: x86_64-unknown-linux-musl
|
||||||
# Emit backtraces on panics.
|
# Emit backtraces on panics.
|
||||||
RUST_BACKTRACE: 1
|
RUST_BACKTRACE: 1
|
||||||
# Since we're distributing the dpkg, we don't know whether the user will
|
# Since we're distributing the dpkg, we don't know whether the user will
|
||||||
# have PCRE2 installed, so just do a static build.
|
# have PCRE2 installed, so just do a static build.
|
||||||
PCRE2_SYS_STATIC: 1
|
PCRE2_SYS_STATIC: 1
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Install packages (Ubuntu)
|
- name: Install packages (Ubuntu)
|
||||||
shell: bash
|
shell: bash
|
||||||
run: "if ! command -V sudo; then\n apt-get update\n apt-get install -y --no-install-recommends sudo\nfi\nsudo apt-get update\nsudo apt-get install -y --no-install-recommends \\\n zsh xz-utils liblz4-tool musl-tools brotli zstd \n"
|
run: |
|
||||||
|
if ! command -V sudo; then
|
||||||
|
apt-get update
|
||||||
|
apt-get install -y --no-install-recommends sudo
|
||||||
|
fi
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y --no-install-recommends \
|
||||||
|
zsh xz-utils liblz4-tool musl-tools brotli zstd
|
||||||
|
|
||||||
- name: Install Rust
|
- name: Install Rust
|
||||||
uses: dtolnay/rust-toolchain@master
|
uses: dtolnay/rust-toolchain@master
|
||||||
with:
|
with:
|
||||||
toolchain: nightly
|
toolchain: nightly
|
||||||
target: ${{ env.TARGET }}
|
target: ${{ env.TARGET }}
|
||||||
|
|
||||||
# for some reason, the above action doesn't seem to set the target correctly
|
# for some reason, the above action doesn't seem to set the target correctly
|
||||||
- name: Add rustup target
|
- name: Add rustup target
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
rustup target add ${{ env.TARGET }}
|
rustup target add x86_64-unknown-linux-musl
|
||||||
|
|
||||||
|
# for some reason, the above action doesn't seem to set the target correctly
|
||||||
|
- name: Add rustup target
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
rustup target add x86_64-unknown-linux-musl
|
||||||
|
|
||||||
- name: Install cargo-deb
|
- name: Install cargo-deb
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
cargo install cargo-deb
|
cargo install cargo-deb
|
||||||
|
|
||||||
- name: Create deployment directory
|
- name: Create deployment directory
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
dir=deployment/deb
|
dir=deployment/deb
|
||||||
mkdir -p "$dir"
|
mkdir -p "$dir"
|
||||||
echo "DEPLOY_DIR=$dir" >> $GITHUB_ENV
|
echo "DEPLOY_DIR=$dir" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Build release binary
|
- name: Build release binary
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
cargo deb --profile deb --target ${{ env.TARGET }}
|
cargo deb --profile deb --target ${{ env.TARGET }}
|
||||||
version="${{ github.ref_name }}"
|
version="${{ github.ref_name }}"
|
||||||
echo "DEB_DIR=target/${{ env.TARGET }}/debian" >> $GITHUB_ENV
|
echo "DEB_DIR=target/${{ env.TARGET }}/debian" >> $GITHUB_ENV
|
||||||
echo "DEB_NAME=television_$version-1_${{ env.TARGET }}.deb" >> $GITHUB_ENV
|
echo "DEB_NAME=television_$version-1_amd64.deb" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Create sha256 sum of deb file
|
- name: Create sha256 sum of deb file
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
@ -205,6 +250,7 @@ jobs:
|
|||||||
sum="$DEB_NAME.sha256"
|
sum="$DEB_NAME.sha256"
|
||||||
shasum -a 256 "$DEB_NAME" > "$sum"
|
shasum -a 256 "$DEB_NAME" > "$sum"
|
||||||
echo "SUM=$sum" >> $GITHUB_ENV
|
echo "SUM=$sum" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Upload release archive
|
- name: Upload release archive
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user