122 lines
4.0 KiB
YAML
122 lines
4.0 KiB
YAML
name: Code coverage
|
|
|
|
on:
|
|
push:
|
|
branches: [main]
|
|
pull_request:
|
|
branches: [main]
|
|
types:
|
|
- opened
|
|
- reopened
|
|
- synchronize
|
|
- ready_for_review
|
|
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
env:
|
|
CARGO_TERM_COLOR: always
|
|
# without matrix_sdk=trace, expressions in `trace!` fields are not evaluated
|
|
# when the `trace!` statement is hit, and thus not covered
|
|
RUST_LOG: info,matrix_sdk=trace
|
|
|
|
jobs:
|
|
code_coverage:
|
|
name: Code Coverage
|
|
runs-on: "ubuntu-latest"
|
|
if: github.event_name == 'push' || !github.event.pull_request.draft
|
|
|
|
# run several docker containers with the same networking stack so the hostname 'postgres'
|
|
# maps to the postgres container, etc.
|
|
services:
|
|
# sliding sync needs a postgres container
|
|
postgres:
|
|
# Docker Hub image
|
|
image: postgres
|
|
# Provide the password for postgres
|
|
env:
|
|
POSTGRES_PASSWORD: postgres
|
|
POSTGRES_USER: postgres
|
|
POSTGRES_DB: syncv3
|
|
# Set health checks to wait until postgres has started
|
|
options: >-
|
|
--health-cmd pg_isready
|
|
--health-interval 10s
|
|
--health-timeout 5s
|
|
--health-retries 5
|
|
ports:
|
|
# Maps tcp port 5432 on service container to the host
|
|
- 5432:5432
|
|
# run sliding sync and point it at the postgres container and synapse container.
|
|
# the postgres container needs to be above this to make sure it has started prior to this service.
|
|
slidingsync:
|
|
image: "ghcr.io/matrix-org/sliding-sync:v0.99.11" # keep in sync with ./ci.yml
|
|
env:
|
|
SYNCV3_SERVER: "http://synapse:8008"
|
|
SYNCV3_SECRET: "SUPER_CI_SECRET"
|
|
SYNCV3_BINDADDR: ":8118"
|
|
SYNCV3_DB: "user=postgres password=postgres dbname=syncv3 sslmode=disable host=postgres"
|
|
ports:
|
|
- 8118:8118
|
|
# tests need a synapse: this is a service and not michaelkaye/setup-matrix-synapse@main as the
|
|
# latter does not provide networking for services to communicate with it.
|
|
synapse:
|
|
image: ghcr.io/matrix-org/synapse-service:v1.94.0 # keep in sync with ./ci.yml
|
|
env:
|
|
SYNAPSE_COMPLEMENT_DATABASE: sqlite
|
|
SERVER_NAME: synapse
|
|
ports:
|
|
- 8008:8008
|
|
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v4
|
|
with:
|
|
ref: ${{ github.event.pull_request.head.sha }}
|
|
|
|
- name: Install Rust
|
|
uses: dtolnay/rust-toolchain@stable
|
|
|
|
# Cargo config can screw with caching and is only used for alias config
|
|
# and extra lints, which we don't care about here
|
|
- name: Delete cargo config
|
|
run: rm .cargo/config.toml
|
|
|
|
- name: Load cache
|
|
uses: Swatinem/rust-cache@v2
|
|
with:
|
|
save-if: ${{ github.ref == 'refs/heads/main' }}
|
|
|
|
- name: Install tarpaulin
|
|
uses: taiki-e/install-action@v2
|
|
with:
|
|
tool: cargo-tarpaulin
|
|
|
|
# set up backend for integration tests
|
|
- uses: actions/setup-python@v5
|
|
with:
|
|
python-version: 3.8
|
|
|
|
- name: Run tarpaulin
|
|
run: |
|
|
rustup run stable cargo tarpaulin \
|
|
--skip-clean --profile cov --out xml \
|
|
--features experimental-widgets,testing
|
|
env:
|
|
CARGO_PROFILE_COV_INHERITS: 'dev'
|
|
CARGO_PROFILE_COV_DEBUG: 1
|
|
HOMESERVER_URL: "http://localhost:8008"
|
|
HOMESERVER_DOMAIN: "synapse"
|
|
SLIDING_SYNC_PROXY_URL: "http://localhost:8118"
|
|
|
|
- name: Upload to codecov.io
|
|
uses: codecov/codecov-action@v4
|
|
with:
|
|
# Work around frequent upload errors, for runs inside the main repo (not PRs from forks).
|
|
# Otherwise not required for public repos.
|
|
token: ${{ secrets.CODECOV_UPLOAD_TOKEN }}
|
|
# The upload sometimes fails due to https://github.com/codecov/codecov-action/issues/837.
|
|
# To make sure that the failure gets flagged clearly in the UI, fail the action.
|
|
fail_ci_if_error: true
|