-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathappveyor.yml
123 lines (102 loc) · 5.07 KB
/
appveyor.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
environment:
matrix:
# Version Restrictions
# Enaml supports Python 2.7 and also 3.4 onwards.
# PyQt4 only available for Python <3.6, tested only on Python 2
# PyQt5 only available for Python >=3.5.
# PyQt5 version 5.11.2 doesn't run on Python 3.5.
# PySide1 only available for 2.6 <= Python <=3.4. Wheels only for 32-bit.
# Strategy:
# Run all tests using only pip (Travis uses conda)
# Test each 64-bit Python version, but only the latest known patch.
# Test the oldest and the latest 32-bit Python versions release.
# Test with PyQt4 where available, otherwise PyQt5 in each version.
# Test QScintilla on latest Python version available.
# Test PySide1 in latest Python version it runs on.
# - Failure is allowed and won't block PRs.
# Test PySide2 in latest Python version available
# - Failure is allowed and won't block PRs.
# Only test single toolkit installs (e.g. not QT4 and QT5 on same install)
# VARIABLES
# NAME: just a comment for distinguishing builds in Appveyor.
# PYQT_VERSION: Determines PyQt versions installation
# PY_QT: Determines Pyside version installation (if present), and is used by
# Enaml.
# PYTEST_QT_API: In Python 3.4, pytest-qt needs a hint about the right interface.
# QSCINTILLA: Set to "Yes" to install it.
# 64-bit versions, PyQT, latest to oldest. Test QScintilla support on
# latest.
- NAME: "Py 3.8"
PYTHON: "C:\\Python38-x64"
PYTHON_VERSION: "3.7.4"
PYTHON_ARCH: "64"
PYQT_VERSION: "5"
QSCINTILLA: "Yes"
branches:
only:
- master
install:
# If there is a newer build queued for the same PR, cancel this one.
# The AppVeyor 'rollout builds' option is supposed to serve the same
# purpose but it is problematic because it tends to cancel builds pushed
# directly to master instead of just PR builds (or the converse).
# credits: JuliaLang developers.
- ps: if ($env:APPVEYOR_PULL_REQUEST_NUMBER -and $env:APPVEYOR_BUILD_NUMBER -ne ((Invoke-RestMethod `
https://ci.appveyor.com/api/projects/$env:APPVEYOR_ACCOUNT_NAME/$env:APPVEYOR_PROJECT_SLUG/history?recordsNumber=50).builds | `
Where-Object pullRequestId -eq $env:APPVEYOR_PULL_REQUEST_NUMBER)[0].buildNumber) { `
throw "There are newer queued builds for this pull request, failing early." }
# Dump some debugging information about the machine.
- ECHO "Filesystem root:"
- ps: "ls \"C:/\""
- ECHO "Build Folder:"
- ps: ls $env:APPVEYOR_BUILD_FOLDER
- ECHO "Environment Variables"
- set
# Python 2
# Prepare Miniconda
# - Avoid warning from conda info.
# - Dump the setup for debugging.
# - Upgrade to the latest version of pip to avoid it displaying warnings
# about it being out of date.
- "if %PYTHON_VERSION%==2.7.15 set PATH=%MINICONDA%;%MINICONDA%\\Scripts;%PATH%"
- if %PYTHON_VERSION%==2.7.15 conda config --set always_yes yes --set changeps1 no
- if %PYTHON_VERSION%==2.7.15 conda update -q conda
- if %PYTHON_VERSION%==2.7.15 conda install -q -n root _license
- if %PYTHON_VERSION%==2.7.15 conda info -a
- if %PYTHON_VERSION%==2.7.15 conda upgrade -q pip setuptools
# Python 3
# Prepend desired Python to the PATH of this build (this cannot be
# done from inside the powershell script as it would require to restart
# the parent CMD process).
# Upgrade to the latest version of pip to avoid it displaying warnings
# about it being out of date.
- "if not %PYTHON_VERSION%==2.7.15SET PATH=%PYTHON%;%PYTHON%\\Scripts;%PATH%"
- if not %PYTHON_VERSION%==2.7.15 python -m pip install -U pip
# Allow the building of wheels.
- pip install wheel
# Check that we have the expected set-up.
- ECHO "We specified %PYTHON_VERSION% win%PYTHON_ARCH%"
- "python --version"
- "python -c \"import struct; print('Architecture is win'+str(struct.calcsize('P') * 8))\""
- pip --version
# At the time of writing, the setup.py says Enaml depends on a dev version
# of Atom which is not on PyPI. Install straight from GitHub.
- pip install https://github.com/nucleic/atom/tarball/master
# We need a library for Qt.
# PyQT4 won't pip install, so resort to conda.
- if %PYQT_VERSION%==4 conda install -q pyqt=4
# Pyqt5 5.11.2 doesn't work on Python 3.5 (although it does on other versions)
# Avoid using it for now, but optimistically assume that they will fix in next release.
- if %PYQT_VERSION%==5 pip install pyqt5!=5.11.2
- ps: if ($env:QT_API -eq "pyside") {pip install PySide}
- ps: if ($env:QT_API -eq "pyside2") {pip install pyside2}
- if "%QSCINTILLA%"=="Yes" pip install QScintilla
# We should be able to install the test dependencies via setup.py, but in the meantime, do it manually:
#- pip install pytest pytest-cov pytest-qt
- pip install -r requirements.txt
build_script:
- cd %APPVEYOR_BUILD_DIR%
test_script:
# Run the project tests
- cd %APPVEYOR_BUILD_DIR%
- python -m unittest