Skip to content

Optimize CI (#1204) #143

Optimize CI (#1204)

Optimize CI (#1204) #143

Workflow file for this run

name: Staging
on:
push:
branches: [main]
workflow_dispatch:
env:
CARGO_TERM_COLOR: always
DOCKER_REGISTRY: ghcr.io
jobs:
build-package:
name: Build package [linux]
runs-on: ubuntu-latest
container:
image: ubuntu:20.04
steps:
- name: Install dependencies
run: |
apt update -y
apt install --no-install-recommends -y \
ca-certificates curl git python3-pip \
clang make gcc g++ libssl-dev pkg-config protobuf-compiler
pip3 install --upgrade pip
pip3 install cmake --upgrade
- name: Install Rust toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: nightly
- name: Fetch latest code
uses: actions/checkout@v3
- name: Cache target
uses: actions/cache@v2
with:
path: target
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
- name: Build
run: cargo build --release --locked -p darwinia --features all-natives
- name: Collect shared
run: |
mkdir -p shared
tar cjSf \
shared/darwinia2-x86_64-linux-gnu.tar.bz2 \
-C \
target/release \
darwinia
- name: Optimize cache
run: .github/shrink-cache.sh || exit 0
- name: Upload shared
uses: actions/upload-artifact@v2
with:
name: darwinia-artifact
path: shared
build-docker-image:
name: Build image
runs-on: ubuntu-latest
needs: [build-package]
steps:
- name: Fetch latest code
uses: actions/checkout@v3
- name: Sha
uses: benjlevesque/[email protected]
- name: Docker login
uses: docker/login-action@v1
with:
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
registry: ${{ env.DOCKER_REGISTRY }}
- name: Download shared
uses: actions/download-artifact@v2
with:
name: darwinia-artifact
path: shared
- name: Extract shared
run: |
mkdir -p dist
tar -xvf shared/darwinia2-x86_64-linux-gnu.tar.bz2 -C dist/
- name: Publish docker image
uses: docker/build-push-action@v3
with:
push: true
context: .
file: .maintain/docker/Dockerfile
tags: ${{ env.DOCKER_REGISTRY }}/${{ github.repository }}:sha-${{ env.SHA }}