martin/.github/workflows/ci.yml

232 lines
6.8 KiB
YAML
Raw Normal View History

2019-09-30 12:42:49 +03:00
name: CI
2019-09-29 21:47:24 +03:00
on:
push:
branches:
- master
pull_request:
branches:
- master
2019-09-29 21:47:24 +03:00
jobs:
check:
name: Check
runs-on: ubuntu-latest
steps:
- name: Checkout sources
uses: actions/checkout@v2
2019-09-29 21:47:24 +03:00
- name: Install stable toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: true
- name: Run cargo check
uses: actions-rs/cargo@v1
with:
command: check
clippy:
name: Clippy
runs-on: ubuntu-latest
steps:
- name: Checkout sources
uses: actions/checkout@v2
2019-09-29 21:47:24 +03:00
- name: Install stable toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: true
- name: Install clippy
run: rustup component add clippy
- name: Run cargo clippy
uses: actions-rs/cargo@v1
with:
command: clippy
args: -- -D warnings
fmt:
name: Rustfmt
runs-on: ubuntu-latest
steps:
- name: Checkout sources
uses: actions/checkout@v2
2019-09-29 21:47:24 +03:00
- name: Install stable toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: true
- name: Install rustfmt
run: rustup component add rustfmt
- name: Run cargo fmt
uses: actions-rs/cargo@v1
with:
command: fmt
args: --all -- --check
test:
name: Test Suite
runs-on: ubuntu-latest
services:
postgres:
image: postgis/postgis:13-3.1-alpine
2019-09-29 21:47:24 +03:00
env:
POSTGRES_DB: test
POSTGRES_USER: postgres
POSTGRES_HOST_AUTH_METHOD: trust
2019-09-29 21:47:24 +03:00
ports:
# will assign a random free host port
- 5432/tcp
# needed because the postgres container does not provide a healthcheck
options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5
steps:
- name: Checkout sources
uses: actions/checkout@v2
2019-09-29 21:47:24 +03:00
- name: Setup database
run: |
sudo apt-get install postgresql-client
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U postgres -d test -f tests/fixtures/TileBBox.sql
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U postgres -d test -f tests/fixtures/table_source.sql
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U postgres -d test -f tests/fixtures/points1_source.sql
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U postgres -d test -f tests/fixtures/points2_source.sql
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U postgres -d test -f tests/fixtures/points3857_source.sql
2019-09-29 21:47:24 +03:00
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U postgres -d test -f tests/fixtures/function_source.sql
psql -h $POSTGRES_HOST -p $POSTGRES_PORT -U postgres -d test -f tests/fixtures/function_source_query_params.sql
2019-09-29 21:47:24 +03:00
env:
POSTGRES_HOST: localhost
POSTGRES_PORT: ${{ job.services.postgres.ports[5432] }}
- name: Install stable toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: true
- name: Run tests
2019-09-29 21:47:24 +03:00
uses: actions-rs/cargo@v1
with:
command: test
args: --all
2019-09-29 21:47:24 +03:00
env:
DATABASE_URL: postgres://postgres@localhost:${{ job.services.postgres.ports[5432] }}/test
- name: Run build
uses: actions-rs/cargo@v1
with:
command: build
- name: Run server
2019-09-30 08:43:16 +03:00
run: ./target/debug/martin &
env:
DATABASE_URL: postgres://postgres@localhost:${{ job.services.postgres.ports[5432] }}/test
- name: Test server response
2019-09-29 21:47:24 +03:00
run: |
curl "localhost:3000/public.table_source/0/0/0.pbf" > table_source.pbf
curl "localhost:3000/public.points1,public.points2/0/0/0.pbf" > composite_source.pbf
curl "localhost:3000/rpc/public.function_source/0/0/0.pbf" > function_source.pbf
2019-09-29 21:47:24 +03:00
./tests/vtzero-check table_source.pbf
./tests/vtzero-check composite_source.pbf
2019-09-29 21:47:24 +03:00
./tests/vtzero-check function_source.pbf
./tests/vtzero-show table_source.pbf
./tests/vtzero-show composite_source.pbf
2019-09-29 21:47:24 +03:00
./tests/vtzero-show function_source.pbf
docker:
needs: [test]
runs-on: ubuntu-latest
steps:
- name: Checkout sources
uses: actions/checkout@v2
- name: Docker meta
id: docker_meta
uses: crazy-max/ghaction-docker-meta@v1
with:
images: urbica/martin
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v1
- name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Build and push the Docker image
uses: docker/build-push-action@v2
with:
push: true
tags: ${{ steps.docker_meta.outputs.tags }}
labels: ${{ steps.docker_meta.outputs.labels }}
2019-09-29 21:47:24 +03:00
release:
if: startsWith(github.ref, 'refs/tags/')
2019-09-29 21:47:24 +03:00
needs: [test]
strategy:
matrix:
os: [ubuntu-latest, macOS-latest, windows-latest]
include:
- os: ubuntu-latest
rust: stable
target: x86_64-unknown-linux-gnu
2019-09-29 21:47:24 +03:00
bin: martin
name: martin-Linux-x86_64.tar.gz
- os: windows-latest
rust: stable
target: x86_64-pc-windows-msvc
bin: martin.exe
name: martin-Windows-x86_64.zip
- os: macOS-latest
rust: stable
target: x86_64-apple-darwin
bin: martin
name: martin-Darwin-x86_64.tar.gz
runs-on: ${{ matrix.os }}
steps:
- name: Install stable toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: ${{ matrix.rust }}
override: true
target: ${{ matrix.target }}
- name: Checkout
uses: actions/checkout@v2
2019-09-29 21:47:24 +03:00
- name: Run build
uses: actions-rs/cargo@v1
with:
command: build
args: --release --target ${{ matrix.target }}
- name: Package
shell: bash
run: |
strip target/${{ matrix.target }}/release/${{ matrix.bin }}
cd target/${{ matrix.target }}/release
if [[ "${{ matrix.os }}" == "windows-latest" ]]
then
7z a ../../../${{ matrix.name }} ${{ matrix.bin }}
else
tar czvf ../../../${{ matrix.name }} ${{ matrix.bin }}
fi
cd -
2019-09-30 16:24:15 +03:00
- name: Generate SHA-256
if: matrix.os == 'macOS-latest'
run: shasum -a 256 ${{ matrix.name }}
2019-09-29 21:47:24 +03:00
- name: Publish
uses: softprops/action-gh-release@v1
with:
2019-09-30 12:42:49 +03:00
draft: true
files: "martin*"
2019-09-30 13:33:42 +03:00
body_path: CHANGELOG.md
2019-09-29 21:47:24 +03:00
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}