summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2020-01-06 08:47:06 -0800
committerSteve Dower <steve.dower@python.org>2020-01-06 08:47:06 -0800
commitacf5e5f3f42a3d2985499df82331705edbe717be (patch)
tree92f532d9b3ecaa3c5f479a27736838e1767c398d
parent54bcd656a2d2b7559423d75443a086730b46da42 (diff)
downloadcpython-git-acf5e5f3f42a3d2985499df82331705edbe717be.tar.gz
bpo-39041: Add GitHub Actions support (GH-17594)
(cherry picked from commit a76ba362c4d86adf5e7f8254398135d12d7afd25) Co-authored-by: Steve Dower <steve.dower@python.org>
-rw-r--r--.github/workflows/build.yml85
-rw-r--r--.github/workflows/coverage.yml89
-rw-r--r--.github/workflows/doc.yml40
-rwxr-xr-x.github/workflows/posix-deps-apt.sh21
-rw-r--r--Doc/make.bat6
5 files changed, 238 insertions, 3 deletions
diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml
new file mode 100644
index 0000000000..16d6f0db8c
--- /dev/null
+++ b/.github/workflows/build.yml
@@ -0,0 +1,85 @@
+name: Tests
+
+on:
+ #push:
+ # branches:
+ # - master
+ # - 3.8
+ # - 3.7
+ # paths-ignore:
+ # - 'Doc/**'
+ # - 'Misc/**'
+ pull_request:
+ branches:
+ - master
+ - 3.8
+ - 3.7
+ paths-ignore:
+ - 'Doc/**'
+ - 'Misc/**'
+
+jobs:
+ build_win32:
+ name: 'Windows (x86)'
+ runs-on: windows-latest
+ steps:
+ - uses: actions/checkout@v1
+ - name: Build CPython
+ run: .\PCbuild\build.bat -e -p Win32
+ - name: Display build info
+ run: .\python.bat -m test.pythoninfo
+ - name: Tests
+ run: .\PCbuild\rt.bat -q -uall -u-cpu -rwW --slowest --timeout=1200 -j0
+
+ build_win_amd64:
+ name: 'Windows (x64)'
+ runs-on: windows-latest
+ steps:
+ - uses: actions/checkout@v1
+ - name: Build CPython
+ run: .\PCbuild\build.bat -e -p x64
+ - name: Display build info
+ run: .\python.bat -m test.pythoninfo
+ - name: Tests
+ run: .\PCbuild\rt.bat -x64 -q -uall -u-cpu -rwW --slowest --timeout=1200 -j0
+
+ build_macos:
+ name: 'macOS'
+ runs-on: macos-latest
+ steps:
+ - uses: actions/checkout@v1
+ - name: Configure CPython
+ run: ./configure --with-pydebug --with-openssl=/usr/local/opt/openssl --prefix=/opt/python-dev
+ - name: Build CPython
+ run: make -s -j4
+ - name: Display build info
+ run: make pythoninfo
+ - name: Tests
+ run: make buildbottest TESTOPTS="-j4 -uall,-cpu"
+
+ build_ubuntu:
+ name: 'Ubuntu'
+ runs-on: ubuntu-latest
+ env:
+ OPENSSL_VER: 1.1.1d
+ steps:
+ - uses: actions/checkout@v1
+ - name: Install Dependencies
+ run: sudo ./.github/workflows/posix-deps-apt.sh
+ - name: 'Restore OpenSSL build'
+ id: cache-openssl
+ uses: actions/cache@v1
+ with:
+ path: ./multissl/openssl/${{ env.OPENSSL_VER }}
+ key: ${{ runner.os }}-multissl-openssl-${{ env.OPENSSL_VER }}
+ - name: Install OpenSSL
+ if: steps.cache-openssl.outputs.cache-hit != 'true'
+ run: python3 Tools/ssl/multissltests.py --steps=library --base-directory $PWD/multissl --openssl $OPENSSL_VER --system Linux
+ - name: Configure CPython
+ run: ./configure --with-pydebug --with-openssl=$PWD/multissl/openssl/$OPENSSL_VER
+ - name: Build CPython
+ run: make -s -j4
+ - name: Display build info
+ run: make pythoninfo
+ - name: Tests
+ run: xvfb-run make buildbottest TESTOPTS="-j4 -uall,-cpu"
diff --git a/.github/workflows/coverage.yml b/.github/workflows/coverage.yml
new file mode 100644
index 0000000000..cb05e8e2f7
--- /dev/null
+++ b/.github/workflows/coverage.yml
@@ -0,0 +1,89 @@
+name: Coverage
+
+on:
+ push:
+ branches:
+ - master
+ - 3.8
+ - 3.7
+ paths-ignore:
+ - 'Doc/**'
+ - 'Misc/**'
+ #pull_request:
+ # branches:
+ # - master
+ # - 3.8
+ # - 3.7
+ # paths-ignore:
+ # - 'Doc/**'
+ # - 'Misc/**'
+
+jobs:
+ coverage_ubuntu:
+ name: 'Ubuntu (Coverage)'
+ runs-on: ubuntu-latest
+ env:
+ OPENSSL_VER: 1.1.1d
+ steps:
+ - uses: actions/checkout@v1
+ - name: Install Dependencies
+ run: sudo ./.github/workflows/posix-deps-apt.sh
+ - name: 'Restore OpenSSL build'
+ id: cache-openssl
+ uses: actions/cache@v1
+ with:
+ path: ./multissl/openssl/${{ env.OPENSSL_VER }}
+ key: ${{ runner.os }}-multissl-openssl-${{ env.OPENSSL_VER }}
+ - name: Install OpenSSL
+ if: steps.cache-openssl.outputs.cache-hit != 'true'
+ run: python3 Tools/ssl/multissltests.py --steps=library --base-directory $PWD/multissl --openssl $OPENSSL_VER --system Linux
+ - name: Configure CPython
+ run: ./configure --with-openssl=$PWD/multissl/openssl/$OPENSSL_VER
+ - name: Build CPython
+ run: make -s -j4
+ - name: Display build info
+ run: make pythoninfo
+ - name: 'Coverage Preparation'
+ run: |
+ ./python -m venv .venv
+ source ./.venv/bin/activate
+ python -m pip install -U coverage
+ python -m test.pythoninfo
+ - name: 'Tests with coverage'
+ run: >
+ source ./.venv/bin/activate &&
+ xvfb-run python -m coverage
+ run --branch --pylib
+ -m test
+ --fail-env-changed
+ -uall,-cpu
+ -x test_multiprocessing_fork
+ -x test_multiprocessing_forkserver
+ -x test_multiprocessing_spawn
+ -x test_concurrent_futures
+ || true
+ - name: 'Publish code coverage results'
+ run: |
+ ./.venv/bin/python -m coverage xml
+ bash <(curl -s https://codecov.io/bash)
+ env:
+ CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
+
+ c_coverage_ubuntu:
+ name: 'Ubuntu (C Coverage)'
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/checkout@v1
+ - name: Install Dependencies
+ run: sudo ./.github/workflows/posix-deps-apt.sh
+ - name: Configure CPython
+ run: ./configure
+ - name: 'Build CPython and measure coverage'
+ run: xvfb-run make -j4 coverage-report
+ - name: 'Publish code coverage results'
+ if: always()
+ run: |
+ make pythoninfo
+ bash <(curl -s https://codecov.io/bash)
+ env:
+ CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
diff --git a/.github/workflows/doc.yml b/.github/workflows/doc.yml
new file mode 100644
index 0000000000..405b12e3d2
--- /dev/null
+++ b/.github/workflows/doc.yml
@@ -0,0 +1,40 @@
+name: Docs
+
+on:
+ #push:
+ # branches:
+ # - master
+ # - 3.8
+ # - 3.7
+ # paths:
+ # - 'Doc/**'
+ pull_request:
+ branches:
+ - master
+ - 3.8
+ - 3.7
+ paths:
+ - 'Doc/**'
+ - 'Misc/**'
+
+jobs:
+ build_doc:
+ name: 'Docs'
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/checkout@v1
+ - uses: actions/setup-python@v1
+ with:
+ python-version: '3.7'
+ architecture: 'x64'
+ - name: 'Install build dependencies'
+ run: python -m pip install sphinx==2.2.0 blurb python-docs-theme
+ - name: 'Build documentation'
+ run: |
+ cd Doc
+ make check suspicious html PYTHON=python
+ - name: Upload
+ uses: actions/upload-artifact@v1
+ with:
+ name: doc-html
+ path: Doc/build/html
diff --git a/.github/workflows/posix-deps-apt.sh b/.github/workflows/posix-deps-apt.sh
new file mode 100755
index 0000000000..2b879d32f8
--- /dev/null
+++ b/.github/workflows/posix-deps-apt.sh
@@ -0,0 +1,21 @@
+#!/bin/sh
+apt-get update
+
+apt-get -yq install \
+ build-essential \
+ zlib1g-dev \
+ libbz2-dev \
+ liblzma-dev \
+ libncurses5-dev \
+ libreadline6-dev \
+ libsqlite3-dev \
+ libssl-dev \
+ libgdbm-dev \
+ tk-dev \
+ lzma \
+ lzma-dev \
+ liblzma-dev \
+ libffi-dev \
+ uuid-dev \
+ xvfb \
+ lcov
diff --git a/Doc/make.bat b/Doc/make.bat
index e6604956ea..2f21e6d52e 100644
--- a/Doc/make.bat
+++ b/Doc/make.bat
@@ -54,9 +54,9 @@ if not exist "%HTMLHELP%" (
)
:skiphhcsearch
-if "%DISTVERSION%" EQU "" for /f "usebackq" %%v in (`%PYTHON% tools/extensions/patchlevel.py`) do set DISTVERSION=%%v
+if not defined DISTVERSION for /f "usebackq" %%v in (`%PYTHON% tools/extensions/patchlevel.py`) do set DISTVERSION=%%v
-if "%BUILDDIR%" EQU "" set BUILDDIR=build
+if not defined BUILDDIR set BUILDDIR=build
rem Targets that don't require sphinx-build
if "%1" EQU "" goto help
@@ -131,7 +131,7 @@ if exist ..\Misc\NEWS (
)
)
-if NOT "%PAPER%" == "" (
+if defined PAPER (
set SPHINXOPTS=-D latex_elements.papersize=%PAPER% %SPHINXOPTS%
)
if "%1" EQU "htmlhelp" (