Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ci: Start using github actions for CI #235

Merged
merged 53 commits into from
Oct 5, 2020
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
7d274cc
maint(ci): Start using github actions for CI
Jun 10, 2020
307e226
Enable workspaces, all features and locked Cargo.lock file
Jun 10, 2020
ec5cfa8
Add newline at end of file...
Jun 10, 2020
5c2de66
Use our clippy flags
Jun 12, 2020
28ec04f
Limit push build to only build for pushes to master
Jun 15, 2020
b8987e1
Start testing caching
Jun 15, 2020
62aeebe
fix typo
Jun 15, 2020
45f5b8f
Same typo
Jun 15, 2020
42b372f
Also cache build stuff
Jun 15, 2020
6bf746b
Try passing caches between jobs using artifacts
Jun 15, 2020
c7a85a4
typo
Jun 15, 2020
f4246c7
Attempt to find where rust actually lives
Jun 15, 2020
f094376
Abandon artifacts, might as well wait for Godot
Jun 15, 2020
ffbce5f
Remove unused dependency
Jun 15, 2020
35c8161
run check, not build
Jun 15, 2020
b39509b
Maybe we don't need to cache the downloaded stuff
Jun 15, 2020
2e82d0c
Change for change's sake, I need to see caches working
Jun 15, 2020
461a70c
We do need to cache downloads
Jun 15, 2020
78f0f7e
Also cache git downloads
Jun 15, 2020
e7633be
Attempt to run the integration tests as well
Aug 3, 2020
8d42e5b
Add python linting
Aug 3, 2020
5b75aa2
Fix cargo fmt invocation
Aug 3, 2020
1c31851
Split tests in unit and integration tests for more parallelisation
Aug 3, 2020
c3ecc44
Rename to ci, no longer just rust-specific
Aug 3, 2020
a9abbf7
Also rename the workfolow instead of only the file
Aug 3, 2020
c2c818f
Use unique cache keys for both tests suites
Aug 3, 2020
cc75a77
Build the docs
Aug 3, 2020
a2da557
Spell ubuntu correctly...
Aug 3, 2020
6383459
Do not allow skipping tests with credentials on CI
Aug 10, 2020
a31286d
Configure the secrets as env vars
Aug 11, 2020
d4b4681
Update some stuff for the sake of it
Oct 1, 2020
e20f55b
Give things names again
Oct 1, 2020
d5056bc
Put some upload stuff in there
Oct 1, 2020
bd33e88
Merge branch 'master' into maint/github-actions
Oct 1, 2020
1f428b9
Update .github/workflows/ci.yml
Oct 2, 2020
4295645
Update .github/workflows/ci.yml
Oct 2, 2020
cba53cc
Add release workflow to upload docs
Oct 2, 2020
ce0e9e6
Use the job_id for cache key
Oct 2, 2020
50f1135
Correct syntax
Oct 2, 2020
82b7b14
Less confusing name
Oct 2, 2020
561bb8b
Use zeus directly
Oct 2, 2020
b3d10bb
Use npx instead of yarn
Oct 2, 2020
52dbb17
Do not name the upload
Oct 2, 2020
2eb130e
Actually zip up the docs
Oct 2, 2020
9ede8d1
Remove travis config
Oct 2, 2020
eafab8a
Remove test setup
Oct 2, 2020
a090f8c
More suitable name
Oct 2, 2020
6045095
Do not require binaries for releases
Oct 2, 2020
75c176f
Build binaries again
Oct 5, 2020
49dc5ef
Do not use makefile for docs building
Oct 5, 2020
60088f3
Correct release binary location
Oct 5, 2020
bc5771b
Quotes are hard
Oct 5, 2020
f11e867
Remove temp test config
Oct 5, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
41 changes: 41 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
name: Binary release build

on:
push:
branches:
- release/**

# DO NOT MERGE WITH THIS IN IT
pull_request:

jobs:
linux:
name: Linux
flub marked this conversation as resolved.
Show resolved Hide resolved
runs-on: ubuntu-latest

steps:
- name: Checkout sources
uses: actions/checkout@v2

- name: Setup Python
uses: actions/setup-python@v2
with:
python-version: 3.8

- name: Setup Virtualenv
run: pip install virtualenv

- name: Build Docs
run: make docs

- name: Setup node
uses: actions/setup-node@v1

- name: Upload to Zeus
env:
ZEUS_HOOK_BASE: ${{ secrets.ZEUS_HOOK_BASE }}
run: |
yarn global add @zeus-ci/cli
npx zeus job update -b ${{ github.run_id }} -j ${{ github.job }} -r ${{ github.sha }}
npx zeus upload -b ${{ github.run_id }} -j ${{ github.job }} -t "application/zip+docs" -n site/gh-pages.zip
npx zeus job update --status=passed -b ${{ github.run_id }} -j ${{ github.job }} -r ${{ github.sha }}
81 changes: 13 additions & 68 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,9 +39,9 @@ jobs:
override: true

- name: Cache rust cargo artifacts
uses: Swatinem/rust-cache@v1
uses: swatinem/rust-cache@v1
with:
key: lints
key: {{ github.job }}

- name: Run cargo fmt
uses: actions-rs/cargo@v1
Expand All @@ -55,31 +55,6 @@ jobs:
token: ${{ secrets.GITHUB_TOKEN }}
args: --all-features --workspace --tests --examples -- -D clippy::all

check:
name: Rust Check
runs-on: ubuntu-latest
steps:
- name: Checkout sources
uses: actions/checkout@v2

- name: Install rust stable toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: stable
profile: minimal
override: true

- name: Cache rust cargo artifacts
uses: Swatinem/rust-cache@v1
with:
key: check

- name: Run cargo check
uses: actions-rs/cargo@v1
with:
command: check
args: --workspace --all-features --locked

unit-test:
name: Unit Tests
runs-on: ubuntu-latest
Expand All @@ -95,9 +70,9 @@ jobs:
override: true

- name: Cache rust cargo artifacts
uses: Swatinem/rust-cache@v1
uses: swatinem/rust-cache@v1
with:
key: unit-test
key: {{ github.job }}

- name: Run cargo test
uses: actions-rs/cargo@v1
Expand All @@ -120,29 +95,31 @@ jobs:
override: true

- name: Cache rust cargo artifacts
uses: Swatinem/rust-cache@v1
uses: swatinem/rust-cache@v1
with:
key: integration-test
key: {{ github.job }}

- name: Build rust
run: cargo build --locked

- name: Install python
uses: actions/setup-python@v2
with:
python-version: 3.8

- name: Setup Virtualenv
run: pip install virtualenv
- name: Setup python environment
run: pip install --upgrade pytest pytest-localserver requests pytest-xdist pytest-icdiff boto3

- name: Integration tests
env:
SENTRY_SYMBOLICATOR_GCS_CLIENT_EMAIL: ${{ secrets.SENTRY_SYMBOLICATOR_GCS_CLIENT_EMAIL }}
SENTRY_SYMBOLICATOR_GCS_PRIVATE_KEY: ${{ secrets.SENTRY_SYMBOLICATOR_GCS_PRIVATE_KEY }}
SENTRY_SYMBOLICATOR_TEST_AWS_ACCESS_KEY_ID: ${{ secrets.SENTRY_SYMBOLICATOR_TEST_AWS_ACCESS_KEY_ID }}
SENTRY_SYMBOLICATOR_TEST_AWS_SECRET_ACCESS_KEY: ${{ secrets.SENTRY_SYMBOLICATOR_TEST_AWS_SECRET_ACCESS_KEY }}
run: make test-integration CI_ARGS="--ci"

run: pytest --ci -n12 -vv tests/integration

docs:
name: Docs
name: Build docs
runs-on: ubuntu-latest
steps:
- name: Checkout sources
Expand All @@ -158,35 +135,3 @@ jobs:

- name: Build Docs
run: make docs
flub marked this conversation as resolved.
Show resolved Hide resolved

upload-docs:
name: Upload Docs
runs-on: ubuntu-latest
if: "startsWith(github.ref, 'release/')"
needs: docs
steps:

- uses: actions/setup-node@v1

- uses: actions/cache@v2
with:
path: |
${{ github.workspace }}/node_modules
${{ github.workspace }}/packages/**/node_modules
${{ github.workspace }}/packages/**/build
${{ github.workspace }}/packages/**/dist
${{ github.workspace }}/packages/**/esm
key: ${{ runner.os }}-${{ github.sha }}

- name: Install Zeus
run: |
yarn global add @zeus-ci/cli
echo "::add-path::$(yarn global bin)"

- name: Upload docs
env:
ZEUS_API_TOKEN: ${{ secrets.ZEUS_API_TOKEN }}
ZEUS_HOOK_BASE: ${{ secrets.ZEUS_HOOK_BASE }}
run: |
cd site && zip -r gh-pages .
zeus upload -t "application/zip+docs" site/gh-pages.zip