name: Coverage on: pull_request: types: [opened, synchronize, reopened] push: branches: - master - "*" - '!gh-pages' jobs: build_and_test: strategy: fail-fast: false matrix: version: - stable name: ${{ matrix.version }} - x86_64-unknown-linux-gnu runs-on: ubuntu-latest services: postgres: image: postgres env: POSTGRES_PASSWORD: password POSTGRES_USER: postgres POSTGRES_DB: postgres options: >- --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 ports: - 5432:5432 steps: - uses: actions/checkout@v2 - name: ⚡ Cache uses: actions/cache@v2 with: path: | ~/.cargo/registry ~/.cargo/git target key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }} - name: Install ${{ matrix.version }} uses: actions-rs/toolchain@v1 with: toolchain: ${{ matrix.version }}-x86_64-unknown-linux-gnu profile: minimal override: true - name: Apply migrations run: make migrate env: DATABASE_URL: "postgres://postgres:password@localhost:5432/postgres" - name: Generate coverage file if: matrix.version == 'stable' && (github.ref == 'refs/heads/master' || github.event_name == 'pull_request') uses: actions-rs/tarpaulin@v0.1 with: args: '-t 1200' env: DATABASE_URL: "postgres://postgres:password@localhost:5432/postgres" # GIT_HASH is dummy value. I guess build.rs is skipped in tarpaulin # execution so this value is required for preventing meta tests from # panicking GIT_HASH: 8e77345f1597e40c2e266cb4e6dee74888918a61 - name: Upload to Codecov if: matrix.version == 'stable' && (github.ref == 'refs/heads/master' || github.event_name == 'pull_request') uses: codecov/codecov-action@v1