Skip to content

Commit

Permalink
chore(ci): build using github actions
Browse files Browse the repository at this point in the history
  • Loading branch information
richard-ramos committed Nov 16, 2023
1 parent b02a663 commit d901619
Show file tree
Hide file tree
Showing 6 changed files with 171 additions and 13 deletions.
6 changes: 6 additions & 0 deletions .github/docker-compose/ganache.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
services:
ganache:
image: "trufflesuite/ganache:latest"
command: ["-m='swim relax risk shy chimney please usual search industry board music segment'"]
ports:
- "8545:8545"
6 changes: 6 additions & 0 deletions .github/docker-compose/postgres.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
services:
postgres:
image: "postgres:9.6-alpine"
command: ["--env=POSTGRES_HOST_AUTH_METHOD=trust"]
ports:
- "5432:5432"
158 changes: 158 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,158 @@
name: ci

on:
pull_request:
push:
branches:
- master

env:
GO_VERSION: '1.20'

concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
cancel-in-progress: true

jobs:
changes: # changes detection
runs-on: ubuntu-latest
permissions:
pull-requests: read
steps:
- uses: actions/checkout@v3
name: Checkout code
id: checkout
- uses: dorny/paths-filter@v2
id: filter
with:
filters: |
common:
- '.github/workflows/**'
- 'Makefile'
- 'libs/**'
v2:
- 'waku/**'
- 'cmd/**'
- 'library/**'
- 'tests/**'
docker:
- 'docker/**'
outputs:
common: ${{ steps.filter.outputs.common }}
v2: ${{ steps.filter.outputs.v2 }}
docker: ${{ steps.filter.outputs.docker }}

golangci:
name: lint
needs: changes
if: ${{ needs.changes.outputs.v2 == 'true' || needs.changes.outputs.common == 'true' }}
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3

- name: Install Go
uses: actions/setup-go@v4
with:
go-version: ${{ env.GO_VERSION }}
cache: false

- name: Execute golangci-lint
uses: golangci/golangci-lint-action@v3
with:
version: v1.55.2
args: --deadline=5m

build:
needs: changes
if: ${{ needs.changes.outputs.v2 == 'true' || needs.changes.outputs.common == 'true' }}
strategy:
matrix:
os: [ubuntu-latest, macos-latest]
runs-on: ${{ matrix.os }}
timeout-minutes: 60

name: build-${{ matrix.os }}
steps:
- name: Checkout code
uses: actions/checkout@v3

- name: Get submodules hash
id: submodules
run: |
echo "hash=$(git submodule status | awk '{print $1}' | sort | shasum -a 256 | sed 's/[ -]*//g')" >> $GITHUB_OUTPUT
- name: Cache submodules
uses: actions/cache@v3
with:
path: |
vendor/
.git/modules
key: ${{ runner.os }}-vendor-modules-${{ steps.submodules.outputs.hash }}

- name: Install Go
uses: actions/setup-go@v4
with:
go-version: ${{ env.GO_VERSION }}
cache: false

- name: Build binary
run: make

- name: Build library
run: make static-library dynamic-library

- name: Build examples
run: make build-example

test:
needs: changes
if: ${{ needs.changes.outputs.v2 == 'true' || needs.changes.outputs.common == 'true' }}
strategy:
matrix:
os: [ubuntu-latest, macos-latest]
tests: [test-ci, test-with-race]
runs-on: ${{ matrix.os }}
timeout-minutes: 60

name: ${{ matrix.tests }}-${{ matrix.os }}
steps:
- name: Checkout code
uses: actions/checkout@v3

- name: Get submodules hash
id: submodules
run: |
echo "hash=$(git submodule status | awk '{print $1}' | sort | shasum -a 256 | sed 's/[ -]*//g')" >> $GITHUB_OUTPUT
- name: Cache submodules
uses: actions/cache@v3
with:
path: |
vendor/
.git/modules
key: ${{ runner.os }}-vendor-modules-${{ steps.submodules.outputs.hash }}

- name: Install Go
uses: actions/setup-go@v4
with:
go-version: ${{ env.GO_VERSION }}
cache: false

#- name: "Run tests"
# run: make ${{ matrix.tests }}

- name: "Run onchain-tests"
if: ${{ runner.os == 'ubuntu-latest' }}
run: |
docker compose -f .github/docker-compose/ganache.yml up -d
make test-onchain${{ matrix.tests == 'test-with-race' && '-with-race' || '' }}
- name: "Run tests with postgres"
if: ${{ runner.os == 'ubuntu-latest' }}
run: |
docker compose -f .github/docker-compose/postgres.yml up -d
make test-postgres${{ matrix.tests == 'test-with-race' && '-with-race' || '' }}
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ lint-install:

lint:
@echo "lint"
@golangci-lint run ./... --deadline=5m
@$(shell ${GOBIN} env GOPATH)/bin/golangci-lint run ./... --deadline=5m

lint-full:
@echo "lint"
Expand Down
6 changes: 0 additions & 6 deletions ci/Jenkinsfile.linux
Original file line number Diff line number Diff line change
Expand Up @@ -48,12 +48,6 @@ pipeline {
} } }
}

stage('Build examples') {
steps { script { dir(env.REPO) {
nix.develop('make build-example')
} } }
}

stage('Package') {
steps { script { dir(env.REPO) {
dir('./scripts/linux') {
Expand Down
6 changes: 0 additions & 6 deletions ci/Jenkinsfile.tests
Original file line number Diff line number Diff line change
Expand Up @@ -44,12 +44,6 @@ pipeline {
}

stages {
stage('Lint') {
steps { script { dir(env.REPO) {
nix.develop('make lint', pure: false)
} } }
}

stage('Test') {
steps { script { dir(env.REPO) {
if (params.RACE) {
Expand Down

0 comments on commit d901619

Please sign in to comment.