2022-04-20 12:48:44 +01:00
|
|
|
# People who are freshly `pip install`ing from PyPI will pull in the latest versions of
|
|
|
|
# dependencies which match the broad requirements. Since most CI runs are against
|
|
|
|
# the locked poetry environment, run specifically against the latest dependencies to
|
|
|
|
# know if there's an upcoming breaking change.
|
|
|
|
#
|
|
|
|
# As an overview this workflow:
|
|
|
|
# - checks out develop,
|
2022-09-07 15:07:06 +01:00
|
|
|
# - installs from source, pulling in the dependencies like a fresh `pip install` would, and
|
2022-04-20 12:48:44 +01:00
|
|
|
# - runs mypy and test suites in that checkout.
|
|
|
|
#
|
|
|
|
# Based on the twisted trunk CI job.
|
|
|
|
|
|
|
|
name: Latest dependencies
|
|
|
|
|
|
|
|
on:
|
|
|
|
schedule:
|
|
|
|
- cron: 0 7 * * *
|
|
|
|
workflow_dispatch:
|
|
|
|
|
|
|
|
concurrency:
|
|
|
|
group: ${{ github.workflow }}-${{ github.ref }}
|
|
|
|
cancel-in-progress: true
|
|
|
|
|
|
|
|
jobs:
|
|
|
|
mypy:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
2022-10-03 14:20:32 +01:00
|
|
|
- uses: actions/checkout@v3
|
2022-09-07 15:07:06 +01:00
|
|
|
- name: Install Rust
|
2022-11-28 11:08:15 +00:00
|
|
|
uses: dtolnay/rust-toolchain@e645b0cf01249a964ec099494d38d2da0f0b349f
|
2022-09-07 15:07:06 +01:00
|
|
|
with:
|
2022-11-02 23:19:57 +00:00
|
|
|
toolchain: stable
|
2022-09-07 15:07:06 +01:00
|
|
|
- uses: Swatinem/rust-cache@v2
|
|
|
|
|
2022-04-20 12:48:44 +01:00
|
|
|
# The dev dependencies aren't exposed in the wheel metadata (at least with current
|
|
|
|
# poetry-core versions), so we install with poetry.
|
|
|
|
- uses: matrix-org/setup-python-poetry@v1
|
|
|
|
with:
|
|
|
|
python-version: "3.x"
|
2022-09-07 15:07:06 +01:00
|
|
|
poetry-version: "1.2.0"
|
2022-04-29 17:57:23 +01:00
|
|
|
extras: "all"
|
2022-04-20 12:48:44 +01:00
|
|
|
# Dump installed versions for debugging.
|
|
|
|
- run: poetry run pip list > before.txt
|
|
|
|
# Upgrade all runtime dependencies only. This is intended to mimic a fresh
|
|
|
|
# `pip install matrix-synapse[all]` as closely as possible.
|
|
|
|
- run: poetry update --no-dev
|
|
|
|
- run: poetry run pip list > after.txt && (diff -u before.txt after.txt || true)
|
2022-04-29 17:57:23 +01:00
|
|
|
- name: Remove warn_unused_ignores from mypy config
|
|
|
|
run: sed '/warn_unused_ignores = True/d' -i mypy.ini
|
2022-04-20 12:48:44 +01:00
|
|
|
- run: poetry run mypy
|
|
|
|
trial:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
strategy:
|
|
|
|
matrix:
|
|
|
|
include:
|
|
|
|
- database: "sqlite"
|
|
|
|
- database: "postgres"
|
|
|
|
postgres-version: "14"
|
|
|
|
|
|
|
|
steps:
|
2022-10-03 14:20:32 +01:00
|
|
|
- uses: actions/checkout@v3
|
2022-09-07 15:07:06 +01:00
|
|
|
|
|
|
|
- name: Install Rust
|
2022-11-28 11:08:15 +00:00
|
|
|
uses: dtolnay/rust-toolchain@e645b0cf01249a964ec099494d38d2da0f0b349f
|
2022-09-07 15:07:06 +01:00
|
|
|
with:
|
2022-11-02 23:19:57 +00:00
|
|
|
toolchain: stable
|
2022-09-07 15:07:06 +01:00
|
|
|
- uses: Swatinem/rust-cache@v2
|
|
|
|
|
2022-04-20 12:48:44 +01:00
|
|
|
- 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-10-04 12:24:36 +01:00
|
|
|
- uses: actions/setup-python@v4
|
2022-04-20 12:48:44 +01:00
|
|
|
with:
|
|
|
|
python-version: "3.x"
|
|
|
|
- run: pip install .[all,test]
|
|
|
|
- name: Await PostgreSQL
|
|
|
|
if: ${{ matrix.postgres-version }}
|
|
|
|
timeout-minutes: 2
|
|
|
|
run: until pg_isready -h localhost; do sleep 1; done
|
2022-09-08 13:58:31 +01:00
|
|
|
|
|
|
|
# We nuke the local copy, as we've installed synapse into the virtualenv
|
|
|
|
# (rather than use an editable install, which we no longer support). If we
|
|
|
|
# don't do this then python can't find the native lib.
|
|
|
|
- run: rm -rf synapse/
|
|
|
|
|
2022-04-20 12:48:44 +01:00
|
|
|
- run: python -m twisted.trial --jobs=2 tests
|
|
|
|
env:
|
|
|
|
SYNAPSE_POSTGRES: ${{ matrix.database == 'postgres' || '' }}
|
|
|
|
SYNAPSE_POSTGRES_HOST: localhost
|
|
|
|
SYNAPSE_POSTGRES_USER: postgres
|
|
|
|
SYNAPSE_POSTGRES_PASSWORD: postgres
|
|
|
|
- name: Dump logs
|
|
|
|
# Logs are most useful when the command fails, always include them.
|
|
|
|
if: ${{ always() }}
|
|
|
|
# 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:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
container:
|
|
|
|
image: matrixdotorg/sytest-synapse:testing
|
|
|
|
volumes:
|
|
|
|
- ${{ github.workspace }}:/src
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
include:
|
|
|
|
- sytest-tag: focal
|
|
|
|
|
|
|
|
- sytest-tag: focal
|
|
|
|
postgres: postgres
|
|
|
|
workers: workers
|
|
|
|
redis: redis
|
|
|
|
env:
|
|
|
|
POSTGRES: ${{ matrix.postgres && 1}}
|
|
|
|
WORKERS: ${{ matrix.workers && 1 }}
|
|
|
|
REDIS: ${{ matrix.redis && 1 }}
|
|
|
|
BLACKLIST: ${{ matrix.workers && 'synapse-blacklist-with-workers' }}
|
|
|
|
|
|
|
|
steps:
|
2022-10-03 14:20:32 +01:00
|
|
|
- uses: actions/checkout@v3
|
2022-09-08 13:58:31 +01:00
|
|
|
|
|
|
|
- name: Install Rust
|
2022-11-28 11:08:15 +00:00
|
|
|
uses: dtolnay/rust-toolchain@e645b0cf01249a964ec099494d38d2da0f0b349f
|
2022-09-08 13:58:31 +01:00
|
|
|
with:
|
2022-11-02 23:19:57 +00:00
|
|
|
toolchain: stable
|
2022-09-08 13:58:31 +01:00
|
|
|
- uses: Swatinem/rust-cache@v2
|
|
|
|
|
2022-04-20 12:48:44 +01:00
|
|
|
- name: Ensure sytest runs `pip install`
|
|
|
|
# Delete the lockfile so sytest will `pip install` rather than `poetry install`
|
|
|
|
run: rm /src/poetry.lock
|
|
|
|
working-directory: /src
|
|
|
|
- name: Prepare test blacklist
|
|
|
|
run: cat sytest-blacklist .ci/worker-blacklist > synapse-blacklist-with-workers
|
|
|
|
- name: Run SyTest
|
|
|
|
run: /bootstrap.sh synapse
|
|
|
|
working-directory: /src
|
|
|
|
- name: Summarise results.tap
|
|
|
|
if: ${{ always() }}
|
|
|
|
run: /sytest/scripts/tap_to_gha.pl /logs/results.tap
|
|
|
|
- name: Upload SyTest logs
|
2022-10-03 19:11:22 +01:00
|
|
|
uses: actions/upload-artifact@v3
|
2022-04-20 12:48:44 +01:00
|
|
|
if: ${{ always() }}
|
|
|
|
with:
|
|
|
|
name: Sytest Logs - ${{ job.status }} - (${{ join(matrix.*, ', ') }})
|
|
|
|
path: |
|
|
|
|
/logs/results.tap
|
|
|
|
/logs/**/*.log*
|
|
|
|
|
|
|
|
|
2022-08-01 10:55:31 +00:00
|
|
|
complement:
|
|
|
|
if: "${{ !failure() && !cancelled() }}"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
include:
|
|
|
|
- arrangement: monolith
|
|
|
|
database: SQLite
|
|
|
|
|
|
|
|
- arrangement: monolith
|
|
|
|
database: Postgres
|
|
|
|
|
|
|
|
- arrangement: workers
|
|
|
|
database: Postgres
|
|
|
|
|
|
|
|
steps:
|
2022-10-03 14:20:32 +01:00
|
|
|
- name: Run actions/checkout@v3 for synapse
|
|
|
|
uses: actions/checkout@v3
|
2022-08-01 10:55:31 +00:00
|
|
|
with:
|
|
|
|
path: synapse
|
|
|
|
|
|
|
|
- name: Prepare Complement's Prerequisites
|
|
|
|
run: synapse/.ci/scripts/setup_complement_prerequisites.sh
|
|
|
|
|
|
|
|
- run: |
|
|
|
|
set -o pipefail
|
2022-08-28 21:05:30 +01:00
|
|
|
TEST_ONLY_IGNORE_POETRY_LOCKFILE=1 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-08-01 10:55:31 +00:00
|
|
|
shell: bash
|
|
|
|
name: Run Complement Tests
|
2022-04-20 12:48:44 +01:00
|
|
|
|
2022-08-01 10:55:31 +00:00
|
|
|
# Open an issue if the build fails, so we know about it.
|
|
|
|
# Only do this if we're not experimenting with this action in a PR.
|
2022-04-20 12:48:44 +01:00
|
|
|
open-issue:
|
2022-08-01 10:55:31 +00:00
|
|
|
if: "failure() && github.event_name != 'push' && github.event_name != 'pull_request'"
|
2022-04-20 12:48:44 +01:00
|
|
|
needs:
|
2022-09-22 17:33:37 +01:00
|
|
|
# TODO: should mypy be included here? It feels more brittle than the others.
|
2022-04-20 12:48:44 +01:00
|
|
|
- mypy
|
|
|
|
- trial
|
|
|
|
- sytest
|
2022-09-22 17:33:37 +01:00
|
|
|
- complement
|
2022-04-20 12:48:44 +01:00
|
|
|
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
|
|
|
steps:
|
2022-10-03 14:20:32 +01:00
|
|
|
- uses: actions/checkout@v3
|
2022-12-19 14:10:29 +00:00
|
|
|
- uses: JasonEtco/create-an-issue@3a8ba796516b57db8cb2ee6dfc65bc76cd39d56d # v2.8.2
|
2022-04-20 12:48:44 +01:00
|
|
|
env:
|
|
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
with:
|
|
|
|
update_existing: true
|
|
|
|
filename: .ci/latest_deps_build_failed_issue_template.md
|