Skip to content

Commit

Permalink
Merge branch 'trunk' into release-22.8.0-11620
Browse files Browse the repository at this point in the history
  • Loading branch information
adiroiban committed Sep 7, 2022
2 parents 6ed0c93 + 2cb047b commit 919e13c
Show file tree
Hide file tree
Showing 23 changed files with 690 additions and 316 deletions.
174 changes: 138 additions & 36 deletions .github/workflows/test.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
# Try to get a short workflow name and a job name that start with Python
# version to make it easier to check the status inside GitHub UI.
#
# When using external actions check that the external repos are permitted via
# the GitHub configuration at https://github.com/twisted/twisted/settings/actions
#
name: CI

on:
Expand All @@ -10,6 +14,16 @@ on:
pull_request:
branches: [ trunk ]

workflow_dispatch:
inputs:
debug_enabled:
type: boolean
description: 'Run the build with tmate debugging enabled (https://github.com/marketplace/actions/debugging-with-tmate)'
required: false
default: false

permissions:
contents: read

# Only have a run a single parallel for each branch.
# Runs for trunk are queues.
Expand All @@ -24,22 +38,48 @@ defaults:
run:
shell: bash

env:
# Set to 'yes' to open a tunnel to GitHub's VMs through tmate on failures.
# You can also trigger it via manual workflow trigger.
# https://github.com/mxschmitt/action-tmate#manually-triggered-debug
TMATE_DEBUG: 'no'
# The default values in the job generated by the matrix.
DEFAULT_PYTHON_VERSION: '3.10'

jobs:
testing:
runs-on: ubuntu-20.04
# We can't use `env.*` in the job name, only in the steps.
name: ${{ matrix.python-version }}-${{ matrix.job-name || 'default-tests' }}
# We have Ubuntu as the base for running agains multiple Python versions.
runs-on: "${{ matrix.runs-on || 'ubuntu-20.04' }}"
env:
TOXENV: "${{ matrix.tox-env }}"
# By default we run all tests with all deps with coverage.
TOXENV: "${{ matrix.tox-env || 'alldeps-withcov-posix' }}"
# As of April 2021 GHA VM have 2 CPUs - Azure Standard_DS2_v2
# Trial distributed jobs enabled to speed up the CI jobs.
TRIAL_ARGS: "-j 4"
name: ${{ matrix.python-version }}${{ matrix.noipv6 }}-${{ matrix.tox-env }}
# On Windows, we don't yet enable distributed tests as is not yet
# supported.
TRIAL_ARGS: "${{ matrix.trial-args || '-j 4' }}"
strategy:
fail-fast: false
# The matrix is designed to not expand into any job.
# It is used to document the test environement variations.
# The actual job enviroment are defined in the `include` section.
matrix:
# Run on latest minor release of each major python version.
python-version: ['3.8', '3.9', '3.10']
tox-env: ['alldeps-withcov-posix']
# The Python version on which the job is executed.
# We need at least one value here, so we go with latest Python version
# that we support..
python-version: ['3.10']
# Just use the default OS.
runs-on: ['']
# Human readable short description for this job.
job-name: ['']
# This is the main tox target.
# It is later extended with more jobs that should run in a specific
# OS + Python version configuration.
tox-env: ['']
# We just go with the default arguments.
trial-args: ['']
# By default, tests are executed without disabling IPv6.
noipv6: ['']
# By default, tests are executed without extra platform dependencies.
Expand All @@ -48,14 +88,13 @@ jobs:
tox-wrapper: ['']
# Tests are executed with the default target which is the full test suite.
trial-target: ['']
# By default the coverage is not skipped.
skip-coverage: ['']

# Here the matrix is extended with variations of the default
# value.
include:
# `noipv6` is created to make sure all is OK on an OS which doesn't
# have IPv6 available.
# Any supported Python version is OK for this job.
- python-version: '3.7'
tox-env: alldeps-withcov-posix
noipv6: -noipv6

# `nodeps` is created to make sure we don't have import errors in the
# runtime and production code.
# The minimum supported Python version should be used to maximize
Expand All @@ -65,24 +104,64 @@ jobs:
# When updating the minimum Python version here, also update the
# `python_requires` from `setup.cfg`.
- python-version: '3.7.1'
tox-env: nodeps-withcov-posix
tox-env: 'nodeps-withcov-posix'
job-name: 'nodeps-test'

# `noipv6` is created to make sure all is OK on an OS which doesn't
# have IPv6 available.
# Any supported Python version is OK for this job.
# We go with latest micro release for the smallest minor release
# that we support.
- python-version: '3.7'
noipv6: '-noipv6'
job-name: 'default-tests-noipv6'

# Just Python 3.8 with default settings.
- python-version: '3.8'

# Just Python 3.9 with default settings.
- python-version: '3.9'

# Windows, minimum Python version with select reactor.
- python-version: '3.7'
runs-on: 'windows-2022'
tox-env: 'alldeps-withcov-windows'
job-name: 'win-default-tests-select'
# Distributed trial is not yet suported on Windows so we overwrite
# the default trial-args to remove concurrent runs and to
# select a reactor.
trial-args: '--reactor=select'

# Windows, newest Python supported version with iocp reactor.
- python-version: '3.10'
runs-on: 'windows-2022'
tox-env: 'alldeps-withcov-windows'
job-name: 'win-default-tests-iocp'
# Distributed trial is not yet suported on Windows.
trial-args: '--reactor=iocp'

# On PYPY coverage is very slow (5min vs 30min) as there is no C
# extension.
# There is very little PYPY specific code so there is not much to
# gain from reporting coverage.
- python-version: pypy-3.7
tox-env: alldeps-nocov-posix
- python-version: 'pypy-3.7'
tox-env: 'alldeps-nocov-posix'
job-name: 'no-coverage'
skip-coverage: yes

# We still run some tests with coverage,
# as there are test with specific code branches for pypy.
- python-version: pypy-3.7
tox-env: alldeps-withcov-posix
trial-target: twisted.test.test_compat twisted.test.test_defer twisted.internet.test.test_socket twisted.trial.test.test_tests
- python-version: 'pypy-3.7'
trial-target: 'twisted.test.test_compat twisted.test.test_defer twisted.internet.test.test_socket twisted.trial.test.test_tests'
job-name: 'with-coverage'

# We run selected test for GTK reactor inside X virtual framebuffer.
- python-version: '3.7'
tox-env: alldeps-gtk-withcov-posix
trial-target: twisted.internet.test
tox-env: 'alldeps-gtk-withcov-posix'
trial-target: 'twisted.internet.test'
platform-deps: 'gtk_platform'
tox-wrapper: 'xvfb-run -a'
job-name: 'gtk-tests'


steps:
Expand All @@ -99,7 +178,7 @@ jobs:
echo "::set-output name=dir::$(pip cache dir)"
- name: pip cache
uses: actions/cache@v2
uses: actions/cache@v3
with:
path: ${{ steps.pip-cache.outputs.dir }}
key:
Expand All @@ -108,6 +187,8 @@ jobs:
restore-keys: |
${{ runner.os }}-pip-
# Make sure the matrix is defined in such a way that this is triggered
# only on Linux.
- name: Disable IPv6
if: matrix.noipv6
run: |
Expand All @@ -121,6 +202,8 @@ jobs:
run: |
python -m pip install --upgrade pip tox coverage
# Make sure the matrix is defined in such a way that this is triggered
# only on Linux.
- name: Install GTK system deps
if: matrix.platform-deps == 'gtk_platform'
run: |
Expand All @@ -139,8 +222,16 @@ jobs:
run: |
${{ matrix.tox-wrapper }} tox ${{ matrix.trial-target }}
# If one of the above steps fails, fire up tmate for remote debugging.
# This is fired for manual trigger or via the environment variable.
- name: Tmate debug session
if: ${{ !cancelled() && (env.TMATE_DEBUG == 'yes' || github.event_name == 'workflow_dispatch' && inputs.debug_enabled ) }}
uses: mxschmitt/action-tmate@v3
with:
limit-access-to-actor: true

- name: Prepare coverage
if: ${{ !cancelled() && contains(matrix['tox-env'], 'withcov') }}
if: ${{ !cancelled() && !matrix.skip-coverage }}
run: |
# sub-process coverage are generated in separate files so we combine them
# to get an unified coverage for the local run.
Expand All @@ -149,11 +240,11 @@ jobs:
python -m coverage xml -o coverage.xml -i
python -m coverage report --skip-covered
- uses: codecov/codecov-action@v2
if: ${{ !cancelled() && contains(matrix['tox-env'], 'withcov') }}
- uses: codecov/codecov-action@v3
if: ${{ !cancelled() && !matrix['skip-coverage'] }}
with:
files: coverage.xml
name: lnx-${{ matrix.python-version }}-${{ matrix.tox-env }}${{ matrix.noipv6 }}
name: ${{ matrix.python-version || env.DEFAULT_PYTHON_VERSION }}-${{matrix.job-name || 'default-tests' }}
fail_ci_if_error: true


Expand All @@ -172,7 +263,7 @@ jobs:
- name: Set up Python
uses: actions/setup-python@v2
with:
python-version: '3.9'
python-version: '${{ env.DEFAULT_PYTHON_VERSION }}'

- name: Install dependencies
run: |
Expand Down Expand Up @@ -218,7 +309,7 @@ jobs:
- name: Set up Python
uses: actions/setup-python@v2
with:
python-version: '3.10'
python-version: ${{ env.DEFAULT_PYTHON_VERSION }}
- name: Install dependencies
run: |
python -m pip install --upgrade pip tox
Expand All @@ -235,7 +326,7 @@ jobs:
- name: Set up Python
uses: actions/setup-python@v2
with:
python-version: '3.10'
python-version: ${{ env.DEFAULT_PYTHON_VERSION }}
- name: Install dependencies
run: |
python -m pip install --upgrade pip tox
Expand All @@ -252,14 +343,14 @@ jobs:
# The files are published only when a tag is created.
release-publish:
name: Check release and publish on twisted-* tag
runs-on: ubuntu-20.04
runs-on: 'ubuntu-20.04'
steps:
- uses: actions/checkout@v2

- name: Set up Python
uses: actions/setup-python@v2
with:
python-version: 3.9
python-version: '${{ env.DEFAULT_PYTHON_VERSION }}'

- name: Test
run: |
Expand All @@ -270,22 +361,34 @@ jobs:
- uses: twisted/python-info-action@v1

- name: Files to be pushed to PyPi
run: ls -R dist/
run: |
ls -R dist/
- name: Check matched tag version and branch version - on tag
if: startsWith(github.ref, 'refs/tags/twisted-')
run: python admin/check_tag_version_match.py "${{ github.ref }}"

- name: Publish to PyPI - on tag
if: startsWith(github.ref, 'refs/tags/twisted-')
uses: pypa/gh-action-pypi-publish@v1.3.1
uses: pypa/gh-action-pypi-publish@v1.5.1
with:
password: ${{ secrets.PYPI_UPLOAD_TOKEN }}

# Read the Docs has no support for our "twisted-1.2.3" numbering convention
# and can't detect which tag is the stable one.
# A workaournd is to manually push to a "stable" branch to inform RTD
# that this is what we want at the "/en/stable" link.
update-stable-branch:
permissions:
contents: write
name: Update stable branch for RTD - on tag
runs-on: 'ubuntu-20.04'
needs: [release-publish]
if: startsWith(github.ref, 'refs/tags/twisted-')
steps:
- name: Update stable branch - on stable tag
if: startsWith(github.ref, 'refs/tags/twisted-')
env:
STABLE_BRANCH: stable
STABLE_BRANCH: 'stable'
STABLE_REF_RE: '.*twisted-[[:digit:]]+\.[[:digit:]]+\.[[:digit:]]+$'
run: |
if [[ $GITUB_REF =~ $STABLE_REF_RE ]]; then
Expand All @@ -306,7 +409,6 @@ jobs:
echo "Branch not updated for not stable releases: $GITUB_REF"
fi
# We have this job so that the PR can be blocked on a single job.
# In this way, each time a job is modified,
# we don't have to go to GitHub UI and reconfigure branch protection.
Expand Down
2 changes: 1 addition & 1 deletion azure-pipelines/run_test_steps.yml
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ steps:
displayName: 'Run tests'
continueOnError: ${{ parameters.allowFailure }}
env:
TWISTED_REACTOR: ${{ parameters.windowsReactor }}
TRIAL_ARGS: --reactor=${{ parameters.windowsReactor }}

- bash: |
# sub-process coverage are generated in separate files so we combine them
Expand Down
14 changes: 0 additions & 14 deletions azure-pipelines/tests_pipeline.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,17 +31,3 @@ jobs:
parameters:
pythonVersions:
py39: "3.10"

# Run Windows select reactor on the oldest CPython that we support.
- template: 'windows_test_jobs.yml'
parameters:
pythonVersions:
py37: "3.7"
reactor: select

# Run Windows iocp reactor on the newest CPython that we support.
- template: 'windows_test_jobs.yml'
parameters:
pythonVersions:
py39: "3.10"
reactor: iocp
37 changes: 0 additions & 37 deletions azure-pipelines/windows_test_jobs.yml

This file was deleted.

1 change: 1 addition & 0 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ packages = find:
test =
cython-test-exception-raiser >= 1.0.2, <2
PyHamcrest >= 1.9.0
hypothesis ~= 6.0

; List of dependencies required to build the documentation and test the
; release scripts and process.
Expand Down
Loading

0 comments on commit 919e13c

Please sign in to comment.