2022-04-20 14:48:44 +03: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 17:07:06 +03:00
|
|
|
# - installs from source, pulling in the dependencies like a fresh `pip install` would, and
|
2022-04-20 14:48:44 +03: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:
|
2023-06-06 21:29:54 +03:00
|
|
|
check_repo:
|
2023-12-13 18:24:37 +03:00
|
|
|
# Prevent this workflow from running on any fork of Synapse other than element-hq/synapse, as it is
|
2023-06-06 21:29:54 +03:00
|
|
|
# only useful to the Synapse core team.
|
|
|
|
# All other workflow steps depend on this one, thus if 'should_run_workflow' is not 'true', the rest
|
|
|
|
# of the workflow will be skipped as well.
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
outputs:
|
|
|
|
should_run_workflow: ${{ steps.check_condition.outputs.should_run_workflow }}
|
|
|
|
steps:
|
|
|
|
- id: check_condition
|
2023-12-13 18:24:37 +03:00
|
|
|
run: echo "should_run_workflow=${{ github.repository == 'element-hq/synapse' }}" >> "$GITHUB_OUTPUT"
|
2023-06-06 21:29:54 +03:00
|
|
|
|
2022-04-20 14:48:44 +03:00
|
|
|
mypy:
|
2023-06-06 21:29:54 +03:00
|
|
|
needs: check_repo
|
|
|
|
if: needs.check_repo.outputs.should_run_workflow == 'true'
|
2022-04-20 14:48:44 +03:00
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
2023-09-25 18:39:54 +03:00
|
|
|
- uses: actions/checkout@v4
|
2022-09-07 17:07:06 +03:00
|
|
|
- name: Install Rust
|
2023-04-06 21:41:29 +03:00
|
|
|
uses: dtolnay/rust-toolchain@stable
|
2022-09-07 17:07:06 +03:00
|
|
|
- uses: Swatinem/rust-cache@v2
|
|
|
|
|
2022-04-20 14:48:44 +03: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"
|
2023-01-17 21:04:44 +03:00
|
|
|
poetry-version: "1.3.2"
|
2022-04-29 19:57:23 +03:00
|
|
|
extras: "all"
|
2022-04-20 14:48:44 +03: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)
|
2023-08-31 00:55:47 +03:00
|
|
|
- name: Remove unhelpful options from mypy config
|
|
|
|
run: sed -e '/warn_unused_ignores = True/d' -e '/warn_redundant_casts = True/d' -i mypy.ini
|
2022-04-20 14:48:44 +03:00
|
|
|
- run: poetry run mypy
|
|
|
|
trial:
|
2023-06-06 21:29:54 +03:00
|
|
|
needs: check_repo
|
|
|
|
if: needs.check_repo.outputs.should_run_workflow == 'true'
|
2022-04-20 14:48:44 +03:00
|
|
|
runs-on: ubuntu-latest
|
|
|
|
strategy:
|
|
|
|
matrix:
|
|
|
|
include:
|
|
|
|
- database: "sqlite"
|
|
|
|
- database: "postgres"
|
|
|
|
postgres-version: "14"
|
|
|
|
|
|
|
|
steps:
|
2023-09-25 18:39:54 +03:00
|
|
|
- uses: actions/checkout@v4
|
2022-09-07 17:07:06 +03:00
|
|
|
|
|
|
|
- name: Install Rust
|
2023-04-06 21:41:29 +03:00
|
|
|
uses: dtolnay/rust-toolchain@stable
|
2022-09-07 17:07:06 +03:00
|
|
|
- uses: Swatinem/rust-cache@v2
|
|
|
|
|
2022-04-20 14:48:44 +03: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 }}
|
2023-12-12 12:59:10 +03:00
|
|
|
- uses: actions/setup-python@v5
|
2022-04-20 14:48:44 +03: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 15:58:31 +03: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 14:48:44 +03: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:
|
2023-06-06 21:29:54 +03:00
|
|
|
needs: check_repo
|
|
|
|
if: needs.check_repo.outputs.should_run_workflow == 'true'
|
2022-04-20 14:48:44 +03:00
|
|
|
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:
|
2023-09-25 18:39:54 +03:00
|
|
|
- uses: actions/checkout@v4
|
2022-09-08 15:58:31 +03:00
|
|
|
|
|
|
|
- name: Install Rust
|
2023-04-06 21:41:29 +03:00
|
|
|
uses: dtolnay/rust-toolchain@stable
|
2022-09-08 15:58:31 +03:00
|
|
|
- uses: Swatinem/rust-cache@v2
|
|
|
|
|
2022-04-20 14:48:44 +03: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
|
2024-01-11 13:16:49 +03:00
|
|
|
uses: actions/upload-artifact@v4
|
2022-04-20 14:48:44 +03:00
|
|
|
if: ${{ always() }}
|
|
|
|
with:
|
|
|
|
name: Sytest Logs - ${{ job.status }} - (${{ join(matrix.*, ', ') }})
|
|
|
|
path: |
|
|
|
|
/logs/results.tap
|
|
|
|
/logs/**/*.log*
|
|
|
|
|
|
|
|
|
2022-08-01 13:55:31 +03:00
|
|
|
complement:
|
2023-06-06 21:29:54 +03:00
|
|
|
needs: check_repo
|
|
|
|
if: "!failure() && !cancelled() && needs.check_repo.outputs.should_run_workflow == 'true'"
|
2022-08-01 13:55:31 +03:00
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
include:
|
|
|
|
- arrangement: monolith
|
|
|
|
database: SQLite
|
|
|
|
|
|
|
|
- arrangement: monolith
|
|
|
|
database: Postgres
|
|
|
|
|
|
|
|
- arrangement: workers
|
|
|
|
database: Postgres
|
|
|
|
|
|
|
|
steps:
|
2023-09-25 18:39:54 +03:00
|
|
|
- name: Run actions/checkout@v4 for synapse
|
|
|
|
uses: actions/checkout@v4
|
2022-08-01 13:55:31 +03:00
|
|
|
with:
|
|
|
|
path: synapse
|
|
|
|
|
|
|
|
- name: Prepare Complement's Prerequisites
|
|
|
|
run: synapse/.ci/scripts/setup_complement_prerequisites.sh
|
|
|
|
|
2023-12-12 12:59:31 +03:00
|
|
|
- uses: actions/setup-go@v5
|
2023-10-30 16:07:08 +03:00
|
|
|
with:
|
|
|
|
cache-dependency-path: complement/go.sum
|
|
|
|
go-version-file: complement/go.mod
|
|
|
|
|
2022-08-01 13:55:31 +03:00
|
|
|
- run: |
|
|
|
|
set -o pipefail
|
2022-08-28 23:05:30 +03: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 13:55:31 +03:00
|
|
|
shell: bash
|
|
|
|
name: Run Complement Tests
|
2022-04-20 14:48:44 +03:00
|
|
|
|
2022-08-01 13:55:31 +03: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 14:48:44 +03:00
|
|
|
open-issue:
|
2023-06-06 21:29:54 +03:00
|
|
|
if: "failure() && github.event_name != 'push' && github.event_name != 'pull_request' && needs.check_repo.outputs.should_run_workflow == 'true'"
|
2022-04-20 14:48:44 +03:00
|
|
|
needs:
|
2022-09-22 19:33:37 +03:00
|
|
|
# TODO: should mypy be included here? It feels more brittle than the others.
|
2022-04-20 14:48:44 +03:00
|
|
|
- mypy
|
|
|
|
- trial
|
|
|
|
- sytest
|
2022-09-22 19:33:37 +03:00
|
|
|
- complement
|
2022-04-20 14:48:44 +03:00
|
|
|
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
|
|
|
steps:
|
2023-09-25 18:39:54 +03:00
|
|
|
- uses: actions/checkout@v4
|
2024-02-21 13:37:32 +03:00
|
|
|
- uses: JasonEtco/create-an-issue@1b14a70e4d8dc185e5cc76d3bec9eab20257b2c5 # v2.9.2
|
2022-04-20 14:48:44 +03:00
|
|
|
env:
|
|
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
with:
|
|
|
|
update_existing: true
|
|
|
|
filename: .ci/latest_deps_build_failed_issue_template.md
|