Update CI stages
This commit is contained in:
parent
4a0ba3cfc5
commit
7867da3707
2 changed files with 48 additions and 55 deletions
38
.github/workflows/ci.yml
vendored
38
.github/workflows/ci.yml
vendored
|
@ -11,38 +11,50 @@ on:
|
||||||
|
|
||||||
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
|
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
test:
|
||||||
# The type of runner that the job will run on
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
# Steps represent a sequence of tasks that will be executed as part of the job
|
|
||||||
steps:
|
steps:
|
||||||
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
|
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
with:
|
with:
|
||||||
submodules: 'recursive'
|
submodules: 'recursive'
|
||||||
|
- name: Install kcov
|
||||||
- name: Install kcov and shellcheck
|
run: sudo apt-get install -y kcov
|
||||||
run: sudo apt-get install -y kcov shellcheck
|
|
||||||
|
|
||||||
- name: Install restic
|
- name: Install restic
|
||||||
run: |
|
run: |
|
||||||
wget https://github.com/restic/restic/releases/download/v0.12.0/restic_0.12.0_linux_amd64.bz2
|
wget https://github.com/restic/restic/releases/download/v0.12.0/restic_0.12.0_linux_amd64.bz2
|
||||||
bzip2 -d restic_0.12.0_linux_amd64.bz2
|
bzip2 -d restic_0.12.0_linux_amd64.bz2
|
||||||
sudo cp restic_0.12.0_linux_amd64 /usr/local/bin/restic
|
sudo cp restic_0.12.0_linux_amd64 /usr/local/bin/restic
|
||||||
sudo chmod +x /usr/local/bin/restic
|
sudo chmod +x /usr/local/bin/restic
|
||||||
|
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: test/test.sh
|
run: test/test.sh
|
||||||
|
coverage:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: 'recursive'
|
||||||
|
- name: Install kcov
|
||||||
|
run: sudo apt-get install -y kcov
|
||||||
|
- name: Install restic
|
||||||
|
run: |
|
||||||
|
wget https://github.com/restic/restic/releases/download/v0.12.0/restic_0.12.0_linux_amd64.bz2
|
||||||
|
bzip2 -d restic_0.12.0_linux_amd64.bz2
|
||||||
|
sudo cp restic_0.12.0_linux_amd64 /usr/local/bin/restic
|
||||||
|
sudo chmod +x /usr/local/bin/restic
|
||||||
- name: Run coverage
|
- name: Run coverage
|
||||||
run: kcov --include-pattern=backup.sh "$(pwd)"/coverage test/test.sh
|
run: kcov --include-pattern=backup.sh "$(pwd)"/coverage test/test.sh
|
||||||
|
|
||||||
- name: Codecov
|
- name: Codecov
|
||||||
uses: codecov/codecov-action@v1.2.1
|
uses: codecov/codecov-action@v1.2.1
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.CODECOV_TOKEN }}
|
token: ${{ secrets.CODECOV_TOKEN }}
|
||||||
file: ./coverage/test.sh/cov.xml
|
file: ./coverage/test.sh/cov.xml
|
||||||
|
shellcheck:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: 'recursive'
|
||||||
|
- name: Install shellcheck
|
||||||
|
run: sudo apt-get install -y shellcheck
|
||||||
- name: shellcheck
|
- name: shellcheck
|
||||||
run: shellcheck backup.sh
|
run: shellcheck backup.sh
|
||||||
|
|
65
.github/workflows/release.yml
vendored
65
.github/workflows/release.yml
vendored
|
@ -1,62 +1,43 @@
|
||||||
# This is a basic workflow to help you get started with Actions
|
# This is a basic workflow to help you get started with Actions
|
||||||
|
|
||||||
name: Docker
|
name: Release
|
||||||
|
|
||||||
# Controls when the action will run.
|
# Controls when the action will run.
|
||||||
on:
|
on:
|
||||||
push:
|
workflow_run:
|
||||||
tags:
|
workflows: ["CI"]
|
||||||
- 'v*'
|
branches: [master]
|
||||||
|
types: [completed]
|
||||||
|
tags: ['v*']
|
||||||
# Allows you to run this workflow manually from the Actions tab
|
# Allows you to run this workflow manually from the Actions tab
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
|
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
release:
|
||||||
# The type of runner that the job will run on
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
if: ${{ github.event.workflow_run.conclusion == 'success' }}
|
||||||
# Steps represent a sequence of tasks that will be executed as part of the job
|
|
||||||
steps:
|
steps:
|
||||||
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
|
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
with:
|
with:
|
||||||
submodules: 'recursive'
|
submodules: 'recursive'
|
||||||
|
|
||||||
- name: Install kcov and shellcheck
|
|
||||||
run: sudo apt-get install -y kcov shellcheck
|
|
||||||
|
|
||||||
- name: Install restic
|
|
||||||
run: |
|
|
||||||
wget https://github.com/restic/restic/releases/download/v0.12.0/restic_0.12.0_linux_amd64.bz2
|
|
||||||
bzip2 -d restic_0.12.0_linux_amd64.bz2
|
|
||||||
sudo cp restic_0.12.0_linux_amd64 /usr/local/bin/restic
|
|
||||||
sudo chmod +x /usr/local/bin/restic
|
|
||||||
|
|
||||||
- name: Run tests
|
|
||||||
run: test/test.sh
|
|
||||||
|
|
||||||
- name: Run coverage
|
|
||||||
run: kcov --include-pattern=backup.sh "$(pwd)"/coverage test/test.sh
|
|
||||||
|
|
||||||
- name: Codecov
|
|
||||||
uses: codecov/codecov-action@v1.2.1
|
|
||||||
with:
|
|
||||||
token: ${{ secrets.CODECOV_TOKEN }}
|
|
||||||
file: ./coverage/test.sh/cov.xml
|
|
||||||
|
|
||||||
- name: shellcheck
|
|
||||||
run: shellcheck backup.sh
|
|
||||||
|
|
||||||
- name: Build the Docker image
|
|
||||||
run: |
|
|
||||||
echo ${{ secrets.CR_PAT }} | docker login ghcr.io -u $GITHUB_ACTOR --password-stdin
|
|
||||||
docker build . --file Dockerfile --tag ghcr.io/nicolaschan/minecraft-backup:${GITHUB_REF#refs/*/} --tag ghcr.io/nicolaschan/minecraft-backup:latest
|
|
||||||
docker push ghcr.io/nicolaschan/minecraft-backup:${GITHUB_REF#refs/*/}
|
|
||||||
docker push ghcr.io/nicolaschan/minecraft-backup:latest
|
|
||||||
|
|
||||||
- name: Create Release
|
- name: Create Release
|
||||||
uses: ncipollo/release-action@v1.8.6
|
uses: ncipollo/release-action@v1.8.6
|
||||||
with:
|
with:
|
||||||
artifacts: "backup.sh"
|
artifacts: "backup.sh"
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
docker:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
if: ${{ github.event.workflow_run.conclusion == 'success' }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: 'recursive'
|
||||||
|
- name: Build Docker image
|
||||||
|
run: |
|
||||||
|
docker build . --file Dockerfile --tag ghcr.io/nicolaschan/minecraft-backup:${GITHUB_REF#refs/*/} --tag ghcr.io/nicolaschan/minecraft-backup:latest
|
||||||
|
- name: Publish Docker image
|
||||||
|
run: |
|
||||||
|
echo ${{ secrets.CR_PAT }} | docker login ghcr.io -u $GITHUB_ACTOR --password-stdin
|
||||||
|
docker push ghcr.io/nicolaschan/minecraft-backup:${GITHUB_REF#refs/*/}
|
||||||
|
docker push ghcr.io/nicolaschan/minecraft-backup:latest
|
||||||
|
|
Loading…
Add table
Reference in a new issue