67 lines
1.4 KiB
YAML
67 lines
1.4 KiB
YAML
name: Continuous Integration
|
|
|
|
on:
|
|
push:
|
|
branches: [ master ]
|
|
|
|
pull_request:
|
|
branches: [ master ]
|
|
|
|
env:
|
|
CARGO_TERM_COLOR: always
|
|
|
|
jobs:
|
|
build:
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- uses: actions/checkout@v2
|
|
|
|
- name: 🔧 Set up Node
|
|
uses: actions/setup-node@v1
|
|
with:
|
|
node-version: '14.x'
|
|
|
|
- name: 🚧 Install Node dependencies
|
|
run: cd frontend && npm install
|
|
|
|
- name: 🌐 Build Graphite web code
|
|
run: cd frontend && npm run build
|
|
|
|
- name: 👕 Lint Graphite web formatting
|
|
run: export NODE_ENV=production && cd frontend && npm run lint
|
|
|
|
- name: 🔬 Check Rust formatting
|
|
run: cargo fmt --all -- --check
|
|
|
|
- name: 🦀 Build Rust code
|
|
run: cargo build --verbose
|
|
|
|
- name: 🧪 Run Rust tests
|
|
run: cargo test --verbose
|
|
|
|
cargo-deny:
|
|
runs-on: ubuntu-latest
|
|
|
|
strategy:
|
|
matrix:
|
|
checks:
|
|
- 'security advisories'
|
|
- 'banned licenses and crates'
|
|
|
|
# Prevent sudden announcement of a new advisory from failing ci:
|
|
continue-on-error: ${{ matrix.checks == 'security advisories' }}
|
|
|
|
steps:
|
|
- uses: actions/checkout@v2
|
|
|
|
- uses: EmbarkStudios/cargo-deny-action@v1
|
|
if: matrix.checks == 'security advisories'
|
|
with:
|
|
command: check advisories
|
|
|
|
- uses: EmbarkStudios/cargo-deny-action@v1
|
|
if: matrix.checks == 'banned licenses and crates'
|
|
with:
|
|
command: check bans licenses sources
|