From f96763826c7d2832b2d141f8114e72cf1b24518c Mon Sep 17 00:00:00 2001 From: Hugo Date: Sat, 4 Jan 2020 23:07:59 +0200 Subject: [PATCH 1/5] Test on new Travis CPUs https://blog.travis-ci.com/2019-11-12-multi-cpu-architecture-ibm-power-ibm-z --- .travis.yml | 27 +++++++++++++++++++++++++++ .travis/install.sh | 4 ++++ .travis/test.sh | 4 +++- Tests/helper.py | 5 +++++ Tests/test_file_jpeg2k.py | 5 ++++- Tests/test_file_png.py | 11 ++++++++++- Tests/test_file_webp_animated.py | 5 ++++- Tests/test_image_getextrema.py | 5 ++++- 8 files changed, 61 insertions(+), 5 deletions(-) diff --git a/.travis.yml b/.travis.yml index bd780ad15..732f00d6d 100644 --- a/.travis.yml +++ b/.travis.yml @@ -13,6 +13,33 @@ notifications: matrix: fast_finish: true include: + - python: "3.8" + arch: arm64 + - python: "3.7" + arch: arm64 + - python: "3.6" + arch: arm64 + - python: "3.5" + arch: arm64 + + - python: "3.8" + arch: ppc64le + - python: "3.7" + arch: ppc64le + - python: "3.6" + arch: ppc64le + - python: "3.5" + arch: ppc64le + + - python: "3.8" + arch: s390x + - python: "3.7" + arch: s390x + - python: "3.6" + arch: s390x + - python: "3.5" + arch: s390x + - python: "3.6" name: "Lint" env: LINT="true" diff --git a/.travis/install.sh b/.travis/install.sh index 0878bba3b..8e819631a 100755 --- a/.travis/install.sh +++ b/.travis/install.sh @@ -16,8 +16,12 @@ pip install pyroma pip install test-image-results pip install numpy if [[ $TRAVIS_PYTHON_VERSION == 3.* ]]; then + # arm64, ppc64le, s390x CPUs: + # "ERROR: Could not find a version that satisfies the requirement pyqt5" + if [[ $TRAVIS_CPU_ARCH == "amd64" ]]; then sudo apt-get -qq install pyqt5-dev-tools pip install pyqt5!=5.14.1 + fi fi # docs only on Python 3.8 diff --git a/.travis/test.sh b/.travis/test.sh index 832d90433..7507c83ff 100755 --- a/.travis/test.sh +++ b/.travis/test.sh @@ -5,4 +5,6 @@ set -e python -m pytest -v -x --cov PIL --cov Tests --cov-report term Tests # Docs -if [ "$TRAVIS_PYTHON_VERSION" == "3.8" ]; then make doccheck; fi +if [ "$TRAVIS_PYTHON_VERSION" == "3.8" ] && [ "$TRAVIS_CPU_ARCH" == "amd64" ]; then + make doccheck +fi diff --git a/Tests/helper.py b/Tests/helper.py index 0f8e05c19..e52446c03 100644 --- a/Tests/helper.py +++ b/Tests/helper.py @@ -4,6 +4,7 @@ Helper functions. import logging import os +import platform import subprocess import sys import tempfile @@ -348,6 +349,10 @@ def on_ci(): ) +def is_big_endian(): + return platform.processor() == "s390x" + + def is_win32(): return sys.platform.startswith("win32") diff --git a/Tests/test_file_jpeg2k.py b/Tests/test_file_jpeg2k.py index 37ce726db..3639077ac 100644 --- a/Tests/test_file_jpeg2k.py +++ b/Tests/test_file_jpeg2k.py @@ -1,8 +1,9 @@ from io import BytesIO +import pytest from PIL import Image, Jpeg2KImagePlugin -from .helper import PillowTestCase +from .helper import PillowTestCase, is_big_endian, on_ci codecs = dir(Image.core) @@ -165,11 +166,13 @@ class TestFileJpeg2k(PillowTestCase): jp2.load() self.assertEqual(jp2.mode, "I;16") + @pytest.mark.xfail(is_big_endian() and on_ci(), reason="Fails on big-endian") def test_16bit_monochrome_jp2_like_tiff(self): with Image.open("Tests/images/16bit.cropped.tif") as tiff_16bit: with Image.open("Tests/images/16bit.cropped.jp2") as jp2: self.assert_image_similar(jp2, tiff_16bit, 1e-3) + @pytest.mark.xfail(is_big_endian() and on_ci(), reason="Fails on big-endian") def test_16bit_monochrome_j2k_like_tiff(self): with Image.open("Tests/images/16bit.cropped.tif") as tiff_16bit: with Image.open("Tests/images/16bit.cropped.j2k") as j2k: diff --git a/Tests/test_file_png.py b/Tests/test_file_png.py index 4cd613785..e925dfbbe 100644 --- a/Tests/test_file_png.py +++ b/Tests/test_file_png.py @@ -2,9 +2,17 @@ import unittest import zlib from io import BytesIO +import pytest from PIL import Image, ImageFile, PngImagePlugin -from .helper import PillowLeakTestCase, PillowTestCase, hopper, is_win32 +from .helper import ( + PillowLeakTestCase, + PillowTestCase, + hopper, + is_big_endian, + is_win32, + on_ci, +) try: from PIL import _webp @@ -72,6 +80,7 @@ class TestFilePng(PillowTestCase): png.crc(cid, s) return chunks + @pytest.mark.xfail(is_big_endian() and on_ci(), reason="Fails on big-endian") def test_sanity(self): # internal version number diff --git a/Tests/test_file_webp_animated.py b/Tests/test_file_webp_animated.py index bf425d079..a7c4b671e 100644 --- a/Tests/test_file_webp_animated.py +++ b/Tests/test_file_webp_animated.py @@ -1,6 +1,7 @@ +import pytest from PIL import Image -from .helper import PillowTestCase +from .helper import PillowTestCase, is_big_endian, on_ci try: from PIL import _webp @@ -36,6 +37,7 @@ class TestFileWebpAnimation(PillowTestCase): self.assertEqual(im.n_frames, 42) self.assertTrue(im.is_animated) + @pytest.mark.xfail(is_big_endian() and on_ci(), reason="Fails on big-endian") def test_write_animation_L(self): """ Convert an animated GIF to animated WebP, then compare the @@ -61,6 +63,7 @@ class TestFileWebpAnimation(PillowTestCase): im.load() self.assert_image_similar(im, orig.convert("RGBA"), 25.0) + @pytest.mark.xfail(is_big_endian() and on_ci(), reason="Fails on big-endian") def test_write_animation_RGB(self): """ Write an animated WebP from RGB frames, and ensure the frames diff --git a/Tests/test_image_getextrema.py b/Tests/test_image_getextrema.py index 78695c06b..6713d4380 100644 --- a/Tests/test_image_getextrema.py +++ b/Tests/test_image_getextrema.py @@ -1,9 +1,11 @@ +import pytest from PIL import Image -from .helper import PillowTestCase, hopper +from .helper import PillowTestCase, hopper, is_big_endian, on_ci class TestImageGetExtrema(PillowTestCase): + @pytest.mark.xfail(is_big_endian() and on_ci(), reason="Fails on big-endian") def test_extrema(self): def extrema(mode): return hopper(mode).getextrema() @@ -18,6 +20,7 @@ class TestImageGetExtrema(PillowTestCase): self.assertEqual(extrema("CMYK"), ((0, 255), (0, 255), (0, 255), (0, 0))) self.assertEqual(extrema("I;16"), (1, 255)) + @pytest.mark.xfail(is_big_endian() and on_ci(), reason="Fails on big-endian") def test_true_16(self): with Image.open("Tests/images/16_bit_noise.tif") as im: self.assertEqual(im.mode, "I;16") From c10928bc3bfa51929299bfe2057c9729c3948945 Mon Sep 17 00:00:00 2001 From: Hugo Date: Mon, 6 Jan 2020 23:26:51 +0200 Subject: [PATCH 2/5] Test new Travis CPUs on a single Python version each --- .travis.yml | 40 ++++++++++------------------------------ 1 file changed, 10 insertions(+), 30 deletions(-) diff --git a/.travis.yml b/.travis.yml index 732f00d6d..84ade9c8e 100644 --- a/.travis.yml +++ b/.travis.yml @@ -6,43 +6,23 @@ notifications: irc: "chat.freenode.net#pil" # Run fast lint first to get fast feedback. -# Run slow PyPy next, to give it a headstart and reduce waiting time. -# Run latest 3.x next, to get quick compatibility results. -# Then run the remainder. +# Run slower CPUs next, to give them a headstart and reduce waiting time. +# Then run the remainder, with fastest Docker jobs last. matrix: fast_finish: true include: - - python: "3.8" - arch: arm64 - - python: "3.7" - arch: arm64 - - python: "3.6" - arch: arm64 - - python: "3.5" - arch: arm64 - - - python: "3.8" - arch: ppc64le - - python: "3.7" - arch: ppc64le - - python: "3.6" - arch: ppc64le - - python: "3.5" - arch: ppc64le - - - python: "3.8" - arch: s390x - - python: "3.7" - arch: s390x - - python: "3.6" - arch: s390x - - python: "3.5" - arch: s390x - - python: "3.6" name: "Lint" env: LINT="true" + + - python: "3.6" + arch: arm64 + - python: "3.7" + arch: ppc64le + - python: "3.5" + arch: s390x + - python: "pypy3" name: "PyPy3 Xenial" - python: "3.8" From 9ef46159ba21f87f213a9f23586b5c5efe590d16 Mon Sep 17 00:00:00 2001 From: Hugo van Kemenade Date: Tue, 7 Jan 2020 12:39:32 +0200 Subject: [PATCH 3/5] After #4335, there are no longer any Docker jobs on Travis CI Co-Authored-By: Andrew Murray <3112309+radarhere@users.noreply.github.com> --- .travis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 84ade9c8e..8d145b405 100644 --- a/.travis.yml +++ b/.travis.yml @@ -7,7 +7,7 @@ notifications: # Run fast lint first to get fast feedback. # Run slower CPUs next, to give them a headstart and reduce waiting time. -# Then run the remainder, with fastest Docker jobs last. +# Then run the remainder. matrix: fast_finish: true From 5e9336af4c3b87e6abf3be70450d735bba5b163b Mon Sep 17 00:00:00 2001 From: Hugo Date: Wed, 8 Jan 2020 15:22:53 +0200 Subject: [PATCH 4/5] Use sys.byteorder == "big" --- Tests/helper.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/Tests/helper.py b/Tests/helper.py index e52446c03..cdca0ca31 100644 --- a/Tests/helper.py +++ b/Tests/helper.py @@ -4,7 +4,6 @@ Helper functions. import logging import os -import platform import subprocess import sys import tempfile @@ -350,7 +349,7 @@ def on_ci(): def is_big_endian(): - return platform.processor() == "s390x" + return sys.byteorder == "big" def is_win32(): From 428b06365e3dcf773c52db498a6ab7fefc355812 Mon Sep 17 00:00:00 2001 From: Hugo Date: Wed, 8 Jan 2020 15:41:48 +0200 Subject: [PATCH 5/5] Move scripts from .travis to .ci because they're also used by GitHub Actions --- {.travis => .ci}/after_success.sh | 0 {.travis => .ci}/build.sh | 0 {.travis => .ci}/install.sh | 0 {.travis => .ci}/test.sh | 0 .github/workflows/test-docker.yml | 2 +- .github/workflows/test.yml | 12 ++++++------ .travis.yml | 8 ++++---- MANIFEST.in | 2 +- 8 files changed, 12 insertions(+), 12 deletions(-) rename {.travis => .ci}/after_success.sh (100%) rename {.travis => .ci}/build.sh (100%) rename {.travis => .ci}/install.sh (100%) rename {.travis => .ci}/test.sh (100%) diff --git a/.travis/after_success.sh b/.ci/after_success.sh similarity index 100% rename from .travis/after_success.sh rename to .ci/after_success.sh diff --git a/.travis/build.sh b/.ci/build.sh similarity index 100% rename from .travis/build.sh rename to .ci/build.sh diff --git a/.travis/install.sh b/.ci/install.sh similarity index 100% rename from .travis/install.sh rename to .ci/install.sh diff --git a/.travis/test.sh b/.ci/test.sh similarity index 100% rename from .travis/test.sh rename to .ci/test.sh diff --git a/.github/workflows/test-docker.yml b/.github/workflows/test-docker.yml index 1a6eaac69..503d26283 100644 --- a/.github/workflows/test-docker.yml +++ b/.github/workflows/test-docker.yml @@ -50,7 +50,7 @@ jobs: pip install wheel sudo apt-get install -qq ruby-dev PATH="$PATH:~/.local/bin" - .travis/after_success.sh + .ci/after_success.sh env: COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }} diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 8c80bcd71..fa98e2847 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -36,7 +36,7 @@ jobs: with: path: ~/.cache/pip key: - ${{ matrix.os }}-${{ matrix.python-version }}-${{ hashFiles('**/.travis/*.sh') }} + ${{ matrix.os }}-${{ matrix.python-version }}-${{ hashFiles('**/.ci/*.sh') }} restore-keys: | ${{ matrix.os }}-${{ matrix.python-version }}- @@ -46,7 +46,7 @@ jobs: with: path: ~/Library/Caches/pip key: - ${{ matrix.os }}-${{ matrix.python-version }}-${{ hashFiles('**/.travis/*.sh') }} + ${{ matrix.os }}-${{ matrix.python-version }}-${{ hashFiles('**/.ci/*.sh') }} restore-keys: | ${{ matrix.os }}-${{ matrix.python-version }}- @@ -61,7 +61,7 @@ jobs: - name: Install Linux dependencies if: startsWith(matrix.os, 'ubuntu') run: | - .travis/install.sh + .ci/install.sh - name: Install macOS dependencies if: startsWith(matrix.os, 'macOS') @@ -70,11 +70,11 @@ jobs: - name: Build run: | - .travis/build.sh + .ci/build.sh - name: Test run: | - .travis/test.sh + .ci/test.sh - name: Upload errors uses: actions/upload-artifact@v1 @@ -86,7 +86,7 @@ jobs: - name: After success if: success() run: | - .travis/after_success.sh + .ci/after_success.sh env: MATRIX_OS: ${{ matrix.os }} COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }} diff --git a/.travis.yml b/.travis.yml index 8d145b405..038bf0b76 100644 --- a/.travis.yml +++ b/.travis.yml @@ -45,7 +45,7 @@ install: if [ "$LINT" == "true" ]; then pip install tox else - .travis/install.sh; + .ci/install.sh; fi script: @@ -53,12 +53,12 @@ script: if [ "$LINT" == "true" ]; then tox -e lint else - .travis/build.sh - .travis/test.sh + .ci/build.sh + .ci/test.sh fi after_success: - | if [ "$LINT" == "" ]; then - .travis/after_success.sh + .ci/after_success.sh fi diff --git a/MANIFEST.in b/MANIFEST.in index 79f4e2adb..178bf477e 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -26,4 +26,4 @@ global-exclude .git* global-exclude *.pyc global-exclude *.so prune .azure-pipelines -prune .travis +prune .ci