update ci to new workflow

This commit is contained in:
mpostma 2020-07-21 14:39:12 +02:00
parent 0583cd8e5d
commit 7e00bf4bfa
4 changed files with 60 additions and 9 deletions

View File

@ -1,9 +1,8 @@
name: Publish binaries to GitHub release
on: on:
push: release:
tags: types: [published]
- '*'
name: Publish binaries to release
jobs: jobs:
publish: publish:

View File

@ -2,7 +2,7 @@ name: Publish deb pkg to GitHub release & APT repository & Homebrew
on: on:
release: release:
types: [published] types: [released]
jobs: jobs:
debian: debian:

View File

@ -1,7 +1,7 @@
--- ---
on: on:
release: release:
types: [published] types: [released]
name: Publish latest image to Docker Hub name: Publish latest image to Docker Hub

View File

@ -2,8 +2,11 @@
on: on:
push: push:
branches: branches:
- staging - release-v*
- trying - trying
- staging
tags:
- 'v[0-9]+.[0-9]+.[0-9]+' # this only concerns tags on stable
name: Test binaries with cargo test name: Test binaries with cargo test
@ -14,7 +17,6 @@ jobs:
strategy: strategy:
matrix: matrix:
os: [ubuntu-latest, macos-latest] os: [ubuntu-latest, macos-latest]
steps: steps:
- uses: actions/checkout@v1 - uses: actions/checkout@v1
- uses: actions-rs/toolchain@v1 - uses: actions-rs/toolchain@v1
@ -32,6 +34,7 @@ jobs:
uses: actions-rs/cargo@v1 uses: actions-rs/cargo@v1
with: with:
command: clippy command: clippy
build-image: build-image:
name: Test the build of Docker image name: Test the build of Docker image
runs-on: ubuntu-latest runs-on: ubuntu-latest
@ -39,3 +42,52 @@ jobs:
- uses: actions/checkout@v1 - uses: actions/checkout@v1
- run: docker build . --file Dockerfile -t meilisearch - run: docker build . --file Dockerfile -t meilisearch
name: Docker build name: Docker build
## A push occurred on a release branch, a prerelease is created and assets are generated
prerelease:
name: create prerelease
needs: [check, build-image]
if: ${{ contains(github.ref, 'release-') && github.event_name == 'push' }}
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Get version number
id: version-number
run: echo "##[set-output name=number;]$(echo ${{ github.ref }} | sed 's/.*\(v.*\)/\1/')"
- name: Get commit count
id: commit-count
run: echo "##[set-output name=count;]$(git rev-list remotes/origin/master..remotes/origin/release-${{ steps.version-number.outputs.number }} --count)"
- name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.PUBLISH_TOKEN }} # Personal Access Token
with:
tag_name: ${{ steps.version-number.outputs.number }}rc${{ steps.commit-count.outputs.count }}
release_name: Pre-release ${{ steps.version-number.outputs.number }}-rc${{ steps.commit-count.outputs.count }}
prerelease: true
## If a tag is pushed, a release is created for this tag, and assets will be generated
release:
name: create release
needs: [check, build-image]
if: ${{ contains(github.ref, 'tags/v') }}
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Get version number
id: version-number
run: echo "##[set-output name=number;]$(echo ${{ github.ref }} | sed 's/.*\(v.*\)/\1/')"
- name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.PUBLISH_TOKEN }} # PAT
with:
tag_name: ${{ steps.version-number.outputs.number }}
release_name: Meilisearch ${{ steps.version-number.outputs.number }}
prerelease: false