2021-04-09 11:54:30 +02:00
|
|
|
name: Tests
|
|
|
|
|
|
|
|
on:
|
|
|
|
push:
|
|
|
|
branches: ["develop", "release-*"]
|
|
|
|
pull_request:
|
|
|
|
|
2021-07-22 12:35:06 +02:00
|
|
|
concurrency:
|
|
|
|
group: ${{ github.workflow }}-${{ github.ref }}
|
|
|
|
cancel-in-progress: true
|
2021-08-05 12:22:27 +02:00
|
|
|
|
2021-04-09 11:54:30 +02:00
|
|
|
jobs:
|
2022-03-01 20:47:02 +01:00
|
|
|
check-sampleconfig:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
- uses: actions/setup-python@v2
|
2022-04-20 18:33:20 +02:00
|
|
|
- run: pip install .
|
2022-03-02 19:00:26 +01:00
|
|
|
- run: scripts-dev/generate_sample_config.sh --check
|
2022-03-04 13:01:51 +01:00
|
|
|
- run: scripts-dev/config-lint.sh
|
2022-03-01 20:47:02 +01:00
|
|
|
|
2022-06-15 17:27:18 +02:00
|
|
|
check-schema-delta:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
- uses: actions/setup-python@v2
|
|
|
|
- run: "pip install 'click==8.1.1' 'GitPython>=3.1.20'"
|
|
|
|
- run: scripts-dev/check_schema_delta.py --force-colors
|
|
|
|
|
2021-04-09 11:54:30 +02:00
|
|
|
lint:
|
2022-04-12 18:35:48 +02:00
|
|
|
uses: "matrix-org/backend-meta/.github/workflows/python-poetry-ci.yml@v1"
|
2022-04-27 15:03:44 +02:00
|
|
|
with:
|
|
|
|
typechecking-extras: "all"
|
2021-04-09 11:54:30 +02:00
|
|
|
|
|
|
|
lint-crlf:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
- name: Check line endings
|
|
|
|
run: scripts-dev/check_line_terminators.sh
|
|
|
|
|
|
|
|
lint-newsfile:
|
|
|
|
if: ${{ github.base_ref == 'develop' || contains(github.base_ref, 'release-') }}
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
2021-05-26 15:14:43 +02:00
|
|
|
with:
|
|
|
|
ref: ${{ github.event.pull_request.head.sha }}
|
|
|
|
fetch-depth: 0
|
2021-04-09 11:54:30 +02:00
|
|
|
- uses: actions/setup-python@v2
|
2022-03-01 20:47:02 +01:00
|
|
|
- run: "pip install 'towncrier>=18.6.0rc1'"
|
2022-03-02 19:00:26 +01:00
|
|
|
- run: scripts-dev/check-newsfragment.sh
|
2021-08-10 13:15:10 +02:00
|
|
|
env:
|
|
|
|
PULL_REQUEST_NUMBER: ${{ github.event.number }}
|
2021-04-09 11:54:30 +02:00
|
|
|
|
2022-08-17 12:17:04 +02:00
|
|
|
lint-pydantic:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
with:
|
|
|
|
ref: ${{ github.event.pull_request.head.sha }}
|
|
|
|
fetch-depth: 0
|
|
|
|
- uses: matrix-org/setup-python-poetry@v1
|
|
|
|
with:
|
|
|
|
extras: "all"
|
|
|
|
- run: poetry run scripts-dev/check_pydantic_models.py
|
|
|
|
|
2021-04-09 11:54:30 +02:00
|
|
|
# Dummy step to gate other tests on without repeating the whole list
|
|
|
|
linting-done:
|
2021-07-14 15:41:23 +02:00
|
|
|
if: ${{ !cancelled() }} # Run this even if prior jobs were skipped
|
2022-08-17 12:17:04 +02:00
|
|
|
needs: [lint, lint-crlf, lint-newsfile, lint-pydantic, check-sampleconfig, check-schema-delta]
|
2021-04-09 11:54:30 +02:00
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- run: "true"
|
|
|
|
|
|
|
|
trial:
|
2021-07-14 15:41:23 +02:00
|
|
|
if: ${{ !cancelled() && !failure() }} # Allow previous steps to be skipped, but not fail
|
2021-04-09 11:54:30 +02:00
|
|
|
needs: linting-done
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
strategy:
|
|
|
|
matrix:
|
2021-12-21 20:37:04 +01:00
|
|
|
python-version: ["3.7", "3.8", "3.9", "3.10"]
|
2021-04-09 11:54:30 +02:00
|
|
|
database: ["sqlite"]
|
2022-04-12 18:41:21 +02:00
|
|
|
extras: ["all"]
|
2022-09-02 14:12:47 +02:00
|
|
|
is_pr:
|
|
|
|
- ${{ startsWith(github.ref, 'refs/pull/') }}
|
|
|
|
|
|
|
|
# If we're a PR then we only test min and max python.
|
|
|
|
exclude:
|
|
|
|
- is_pr: true
|
|
|
|
python-version: 3.8
|
|
|
|
- is_pr: true
|
|
|
|
python-version: 3.9
|
|
|
|
|
2021-04-09 11:54:30 +02:00
|
|
|
include:
|
|
|
|
# Newest Python without optional deps
|
2021-10-05 13:43:04 +02:00
|
|
|
- python-version: "3.10"
|
2022-04-12 18:41:21 +02:00
|
|
|
extras: ""
|
2021-04-09 11:54:30 +02:00
|
|
|
|
|
|
|
# Oldest Python with PostgreSQL
|
2021-12-21 20:37:04 +01:00
|
|
|
- python-version: "3.7"
|
2021-04-09 11:54:30 +02:00
|
|
|
database: "postgres"
|
2021-12-21 20:37:04 +01:00
|
|
|
postgres-version: "10"
|
2022-04-12 18:41:21 +02:00
|
|
|
extras: "all"
|
2021-04-09 11:54:30 +02:00
|
|
|
|
2021-10-05 13:43:04 +02:00
|
|
|
# Newest Python with newest PostgreSQL
|
|
|
|
- python-version: "3.10"
|
2021-04-09 11:54:30 +02:00
|
|
|
database: "postgres"
|
2021-10-05 13:43:04 +02:00
|
|
|
postgres-version: "14"
|
2022-04-12 18:41:21 +02:00
|
|
|
extras: "all"
|
2021-04-09 11:54:30 +02:00
|
|
|
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
- run: sudo apt-get -qq install xmlsec1
|
|
|
|
- name: Set up PostgreSQL ${{ matrix.postgres-version }}
|
|
|
|
if: ${{ matrix.postgres-version }}
|
|
|
|
run: |
|
|
|
|
docker run -d -p 5432:5432 \
|
|
|
|
-e POSTGRES_PASSWORD=postgres \
|
|
|
|
-e POSTGRES_INITDB_ARGS="--lc-collate C --lc-ctype C --encoding UTF8" \
|
|
|
|
postgres:${{ matrix.postgres-version }}
|
2022-04-12 18:41:21 +02:00
|
|
|
- uses: matrix-org/setup-python-poetry@v1
|
2021-04-09 11:54:30 +02:00
|
|
|
with:
|
|
|
|
python-version: ${{ matrix.python-version }}
|
2022-04-12 18:41:21 +02:00
|
|
|
extras: ${{ matrix.extras }}
|
2021-04-09 11:54:30 +02:00
|
|
|
- name: Await PostgreSQL
|
|
|
|
if: ${{ matrix.postgres-version }}
|
|
|
|
timeout-minutes: 2
|
|
|
|
run: until pg_isready -h localhost; do sleep 1; done
|
2022-04-12 18:41:21 +02:00
|
|
|
- run: poetry run trial --jobs=2 tests
|
2021-04-09 11:54:30 +02:00
|
|
|
env:
|
|
|
|
SYNAPSE_POSTGRES: ${{ matrix.database == 'postgres' || '' }}
|
|
|
|
SYNAPSE_POSTGRES_HOST: localhost
|
|
|
|
SYNAPSE_POSTGRES_USER: postgres
|
|
|
|
SYNAPSE_POSTGRES_PASSWORD: postgres
|
|
|
|
- name: Dump logs
|
2021-10-12 22:09:49 +02:00
|
|
|
# Logs are most useful when the command fails, always include them.
|
|
|
|
if: ${{ always() }}
|
2021-04-09 11:54:30 +02:00
|
|
|
# Note: Dumps to workflow logs instead of using actions/upload-artifact
|
|
|
|
# This keeps logs colocated with failing jobs
|
|
|
|
# It also ignores find's exit code; this is a best effort affair
|
|
|
|
run: >-
|
|
|
|
find _trial_temp -name '*.log'
|
|
|
|
-exec echo "::group::{}" \;
|
|
|
|
-exec cat {} \;
|
|
|
|
-exec echo "::endgroup::" \;
|
|
|
|
|| true
|
|
|
|
|
|
|
|
trial-olddeps:
|
2022-04-12 12:50:11 +02:00
|
|
|
# Note: sqlite only; no postgres
|
2021-07-14 15:41:23 +02:00
|
|
|
if: ${{ !cancelled() && !failure() }} # Allow previous steps to be skipped, but not fail
|
2021-04-09 11:54:30 +02:00
|
|
|
needs: linting-done
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
- name: Test with old deps
|
2022-01-21 23:23:26 +01:00
|
|
|
uses: docker://ubuntu:focal # For old python and sqlite
|
2022-04-12 12:50:11 +02:00
|
|
|
# Note: focal seems to be using 3.8, but the oldest is 3.7?
|
|
|
|
# See https://github.com/matrix-org/synapse/issues/12343
|
2021-04-09 11:54:30 +02:00
|
|
|
with:
|
|
|
|
workdir: /github/workspace
|
2021-08-11 20:59:57 +02:00
|
|
|
entrypoint: .ci/scripts/test_old_deps.sh
|
2021-04-09 11:54:30 +02:00
|
|
|
- name: Dump logs
|
2021-10-12 22:09:49 +02:00
|
|
|
# Logs are most useful when the command fails, always include them.
|
|
|
|
if: ${{ always() }}
|
2021-04-09 11:54:30 +02:00
|
|
|
# Note: Dumps to workflow logs instead of using actions/upload-artifact
|
|
|
|
# This keeps logs colocated with failing jobs
|
|
|
|
# It also ignores find's exit code; this is a best effort affair
|
|
|
|
run: >-
|
|
|
|
find _trial_temp -name '*.log'
|
|
|
|
-exec echo "::group::{}" \;
|
|
|
|
-exec cat {} \;
|
|
|
|
-exec echo "::endgroup::" \;
|
|
|
|
|| true
|
|
|
|
|
|
|
|
trial-pypy:
|
|
|
|
# Very slow; only run if the branch name includes 'pypy'
|
2022-04-12 18:41:21 +02:00
|
|
|
# Note: sqlite only; no postgres. Completely untested since poetry move.
|
2021-07-14 15:41:23 +02:00
|
|
|
if: ${{ contains(github.ref, 'pypy') && !failure() && !cancelled() }}
|
2021-04-09 11:54:30 +02:00
|
|
|
needs: linting-done
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
strategy:
|
|
|
|
matrix:
|
2021-12-21 20:37:04 +01:00
|
|
|
python-version: ["pypy-3.7"]
|
2022-04-12 18:41:21 +02:00
|
|
|
extras: ["all"]
|
2021-04-09 11:54:30 +02:00
|
|
|
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
2022-04-12 18:41:21 +02:00
|
|
|
# Install libs necessary for PyPy to build binary wheels for dependencies
|
2021-04-09 11:54:30 +02:00
|
|
|
- run: sudo apt-get -qq install xmlsec1 libxml2-dev libxslt-dev
|
2022-04-12 18:41:21 +02:00
|
|
|
- uses: matrix-org/setup-python-poetry@v1
|
2021-04-09 11:54:30 +02:00
|
|
|
with:
|
|
|
|
python-version: ${{ matrix.python-version }}
|
2022-04-12 18:41:21 +02:00
|
|
|
extras: ${{ matrix.extras }}
|
|
|
|
- run: poetry run trial --jobs=2 tests
|
2021-04-09 11:54:30 +02:00
|
|
|
- name: Dump logs
|
2021-10-12 22:09:49 +02:00
|
|
|
# Logs are most useful when the command fails, always include them.
|
|
|
|
if: ${{ always() }}
|
2021-04-09 11:54:30 +02:00
|
|
|
# Note: Dumps to workflow logs instead of using actions/upload-artifact
|
|
|
|
# This keeps logs colocated with failing jobs
|
|
|
|
# It also ignores find's exit code; this is a best effort affair
|
|
|
|
run: >-
|
|
|
|
find _trial_temp -name '*.log'
|
|
|
|
-exec echo "::group::{}" \;
|
|
|
|
-exec cat {} \;
|
|
|
|
-exec echo "::endgroup::" \;
|
|
|
|
|| true
|
|
|
|
|
|
|
|
sytest:
|
2021-07-14 15:41:23 +02:00
|
|
|
if: ${{ !failure() && !cancelled() }}
|
2021-04-09 11:54:30 +02:00
|
|
|
needs: linting-done
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
container:
|
|
|
|
image: matrixdotorg/sytest-synapse:${{ matrix.sytest-tag }}
|
|
|
|
volumes:
|
|
|
|
- ${{ github.workspace }}:/src
|
|
|
|
env:
|
2021-09-20 18:35:16 +02:00
|
|
|
SYTEST_BRANCH: ${{ github.head_ref }}
|
2021-04-09 11:54:30 +02:00
|
|
|
POSTGRES: ${{ matrix.postgres && 1}}
|
|
|
|
MULTI_POSTGRES: ${{ (matrix.postgres == 'multi-postgres') && 1}}
|
|
|
|
WORKERS: ${{ matrix.workers && 1 }}
|
|
|
|
REDIS: ${{ matrix.redis && 1 }}
|
|
|
|
BLACKLIST: ${{ matrix.workers && 'synapse-blacklist-with-workers' }}
|
2021-08-11 21:08:48 +02:00
|
|
|
TOP: ${{ github.workspace }}
|
2021-04-09 11:54:30 +02:00
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
include:
|
2022-01-21 23:23:26 +01:00
|
|
|
- sytest-tag: focal
|
2021-04-09 11:54:30 +02:00
|
|
|
|
2022-01-21 23:23:26 +01:00
|
|
|
- sytest-tag: focal
|
2021-04-09 11:54:30 +02:00
|
|
|
postgres: postgres
|
|
|
|
|
|
|
|
- sytest-tag: testing
|
|
|
|
postgres: postgres
|
|
|
|
|
2022-01-21 23:23:26 +01:00
|
|
|
- sytest-tag: focal
|
2021-04-09 11:54:30 +02:00
|
|
|
postgres: multi-postgres
|
|
|
|
workers: workers
|
|
|
|
|
|
|
|
- sytest-tag: buster
|
|
|
|
postgres: multi-postgres
|
|
|
|
workers: workers
|
|
|
|
|
|
|
|
- sytest-tag: buster
|
|
|
|
postgres: postgres
|
|
|
|
workers: workers
|
|
|
|
redis: redis
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
- name: Prepare test blacklist
|
2021-08-11 20:59:57 +02:00
|
|
|
run: cat sytest-blacklist .ci/worker-blacklist > synapse-blacklist-with-workers
|
2021-04-09 11:54:30 +02:00
|
|
|
- name: Run SyTest
|
|
|
|
run: /bootstrap.sh synapse
|
|
|
|
working-directory: /src
|
2021-06-02 18:10:37 +02:00
|
|
|
- name: Summarise results.tap
|
2021-04-09 11:54:30 +02:00
|
|
|
if: ${{ always() }}
|
2021-06-02 18:10:37 +02:00
|
|
|
run: /sytest/scripts/tap_to_gha.pl /logs/results.tap
|
2021-04-09 11:54:30 +02:00
|
|
|
- name: Upload SyTest logs
|
|
|
|
uses: actions/upload-artifact@v2
|
|
|
|
if: ${{ always() }}
|
|
|
|
with:
|
|
|
|
name: Sytest Logs - ${{ job.status }} - (${{ join(matrix.*, ', ') }})
|
|
|
|
path: |
|
|
|
|
/logs/results.tap
|
|
|
|
/logs/**/*.log*
|
|
|
|
|
2021-10-18 17:14:12 +02:00
|
|
|
export-data:
|
|
|
|
if: ${{ !failure() && !cancelled() }} # Allow previous steps to be skipped, but not fail
|
|
|
|
needs: [linting-done, portdb]
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
env:
|
|
|
|
TOP: ${{ github.workspace }}
|
|
|
|
|
|
|
|
services:
|
|
|
|
postgres:
|
|
|
|
image: postgres
|
|
|
|
ports:
|
|
|
|
- 5432:5432
|
|
|
|
env:
|
|
|
|
POSTGRES_PASSWORD: "postgres"
|
|
|
|
POSTGRES_INITDB_ARGS: "--lc-collate C --lc-ctype C --encoding UTF8"
|
|
|
|
options: >-
|
|
|
|
--health-cmd pg_isready
|
|
|
|
--health-interval 10s
|
|
|
|
--health-timeout 5s
|
|
|
|
--health-retries 5
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
- run: sudo apt-get -qq install xmlsec1
|
2022-04-08 21:18:54 +02:00
|
|
|
- uses: matrix-org/setup-python-poetry@v1
|
2021-10-18 17:14:12 +02:00
|
|
|
with:
|
2022-04-08 21:18:54 +02:00
|
|
|
extras: "postgres"
|
2021-10-18 17:14:12 +02:00
|
|
|
- run: .ci/scripts/test_export_data_command.sh
|
|
|
|
|
2021-04-09 11:54:30 +02:00
|
|
|
portdb:
|
2021-07-14 15:41:23 +02:00
|
|
|
if: ${{ !failure() && !cancelled() }} # Allow previous steps to be skipped, but not fail
|
2021-04-09 11:54:30 +02:00
|
|
|
needs: linting-done
|
|
|
|
runs-on: ubuntu-latest
|
2021-08-12 11:41:01 +02:00
|
|
|
env:
|
|
|
|
TOP: ${{ github.workspace }}
|
2021-04-09 11:54:30 +02:00
|
|
|
strategy:
|
|
|
|
matrix:
|
|
|
|
include:
|
2021-12-21 20:37:04 +01:00
|
|
|
- python-version: "3.7"
|
|
|
|
postgres-version: "10"
|
2021-04-09 11:54:30 +02:00
|
|
|
|
2021-10-05 13:43:04 +02:00
|
|
|
- python-version: "3.10"
|
|
|
|
postgres-version: "14"
|
2021-04-09 11:54:30 +02:00
|
|
|
|
|
|
|
services:
|
|
|
|
postgres:
|
|
|
|
image: postgres:${{ matrix.postgres-version }}
|
|
|
|
ports:
|
|
|
|
- 5432:5432
|
|
|
|
env:
|
|
|
|
POSTGRES_PASSWORD: "postgres"
|
|
|
|
POSTGRES_INITDB_ARGS: "--lc-collate C --lc-ctype C --encoding UTF8"
|
|
|
|
options: >-
|
|
|
|
--health-cmd pg_isready
|
|
|
|
--health-interval 10s
|
|
|
|
--health-timeout 5s
|
|
|
|
--health-retries 5
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
- run: sudo apt-get -qq install xmlsec1
|
2022-04-08 13:00:05 +02:00
|
|
|
- uses: matrix-org/setup-python-poetry@v1
|
2021-04-09 11:54:30 +02:00
|
|
|
with:
|
|
|
|
python-version: ${{ matrix.python-version }}
|
2022-04-08 13:00:05 +02:00
|
|
|
extras: "postgres"
|
2021-08-11 20:59:57 +02:00
|
|
|
- run: .ci/scripts/test_synapse_port_db.sh
|
2021-04-09 11:54:30 +02:00
|
|
|
|
|
|
|
complement:
|
2022-05-31 15:02:00 +02:00
|
|
|
if: "${{ !failure() && !cancelled() }}"
|
2021-04-09 11:54:30 +02:00
|
|
|
needs: linting-done
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
2022-06-09 15:16:34 +02:00
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
include:
|
|
|
|
- arrangement: monolith
|
|
|
|
database: SQLite
|
|
|
|
|
|
|
|
- arrangement: monolith
|
|
|
|
database: Postgres
|
|
|
|
|
2022-08-01 12:51:44 +02:00
|
|
|
- arrangement: workers
|
|
|
|
database: Postgres
|
2022-07-13 14:30:42 +02:00
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Run actions/checkout@v2 for synapse
|
|
|
|
uses: actions/checkout@v2
|
|
|
|
with:
|
|
|
|
path: synapse
|
|
|
|
|
|
|
|
- name: Prepare Complement's Prerequisites
|
|
|
|
run: synapse/.ci/scripts/setup_complement_prerequisites.sh
|
|
|
|
|
|
|
|
- run: |
|
|
|
|
set -o pipefail
|
2022-08-28 22:05:30 +02:00
|
|
|
POSTGRES=${{ (matrix.database == 'Postgres') && 1 || '' }} WORKERS=${{ (matrix.arrangement == 'workers') && 1 || '' }} COMPLEMENT_DIR=`pwd`/complement synapse/scripts-dev/complement.sh -json 2>&1 | synapse/.ci/scripts/gotestfmt
|
2022-07-13 14:30:42 +02:00
|
|
|
shell: bash
|
|
|
|
name: Run Complement Tests
|
|
|
|
|
2021-07-20 12:41:19 +02:00
|
|
|
# a job which marks all the other jobs as complete, thus allowing PRs to be merged.
|
|
|
|
tests-done:
|
2021-07-22 12:10:30 +02:00
|
|
|
if: ${{ always() }}
|
2021-07-20 12:41:19 +02:00
|
|
|
needs:
|
2022-03-07 13:24:06 +01:00
|
|
|
- check-sampleconfig
|
2021-07-22 12:10:30 +02:00
|
|
|
- lint
|
|
|
|
- lint-crlf
|
|
|
|
- lint-newsfile
|
2021-07-20 12:41:19 +02:00
|
|
|
- trial
|
|
|
|
- trial-olddeps
|
|
|
|
- sytest
|
2022-03-07 13:24:06 +01:00
|
|
|
- export-data
|
2021-07-20 12:41:19 +02:00
|
|
|
- portdb
|
|
|
|
- complement
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
2022-03-07 13:24:06 +01:00
|
|
|
- uses: matrix-org/done-action@v2
|
|
|
|
with:
|
|
|
|
needs: ${{ toJSON(needs) }}
|
|
|
|
|
|
|
|
# The newsfile lint may be skipped on non PR builds
|
|
|
|
skippable:
|
|
|
|
lint-newsfile
|