forked from pyinstaller/pyinstaller
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathappveyor.yml
138 lines (117 loc) · 5.38 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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
# As config was originally based on an example by Olivier Grisel. Thanks!
# https://github.com/ogrisel/python-appveyor-demo/blob/master/appveyor.yml
clone_depth: 50
branches:
except:
- /pyup\/.*/
environment:
PYTEST: py.test -n3 --maxfail 5 --durations=10 --junitxml=junit-results.xml
APPVEYOR_SAVE_CACHE_ON_ERROR: true
matrix:
- PYTHON: C:\Python36-x64
PYTHON_VERSION: 3.6
PYTHON_ARCH: 64
- PYTHON: C:\Python36
PYTHON_VERSION: 3.6
PYTHON_ARCH: 32
- PYTHON: C:\Python35
PYTHON_VERSION: 3.5
PYTHON_ARCH: 32
- PYTHON: C:\Python34
PYTHON_VERSION: 3.4
PYTHON_ARCH: 32
- PYTHON: C:\Python27
PYTHON_VERSION: 2.7
PYTHON_ARCH: 32
init:
# Uncomment the line below to enable Remote Desktop access to the build worker
# VM. See https://www.appveyor.com/docs/how-to/rdp-to-build-worker/.
#- ps: iex ((new-object net.webclient).DownloadString('https://raw.githubusercontent.com/appveyor/ci/master/scripts/enable-rdp.ps1'))
- "ECHO %PYTHON% %PYTHON_VERSION% %PYTHON_ARCH%"
- "ECHO \"%APPVEYOR_SCHEDULED_BUILD%\""
# 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." }
# Free up some disk space; exceeding the limit of 90 GB results in a
# locked-out account. The Qt directory takes over 30 GB. Do this in the
# background.
- ps: 'Start-Process -FilePath "$env:comspec" -ArgumentList "/c rmdir tmp /s /q"'
cache:
# Cache downloaded pip packages and built wheels.
- '%LOCALAPPDATA%\pip\Cache\http'
- '%LOCALAPPDATA%\pip\Cache\wheels'
install:
- C:\cygwin\bin\du -hs "%LOCALAPPDATA%\pip\Cache"
# Prepend newly installed 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).
- SET PATH=%PYTHON%;%PYTHON%\Scripts;%PATH%
# Check that we have the expected version and architecture for Python
- python --version
- >-
%CMD_IN_ENV%
python -c "import sys,platform,struct;
print(sys.platform, platform.machine(), struct.calcsize('P') * 8, )"
# Compile bootloader.
- cd bootloader
- python waf all --target-arch=%PYTHON_ARCH%bit
# Verify the bootloaders have the expected arch
- python ../tests/scripts/check-pefile-arch.py %PYTHON_ARCH% build/*/*.exe
- cd ..
### Install the PyInstaller dependencies.
# If some dependencies contain
# compiled extensions and are not provided as pre-built wheel packages, pip
# will build them from source using the MSVC compiler matching the target
# Python version and architecture. To achieve this, all commands are run
# under control of '%CMD_IN_ENV%' (see above).
# Upgrade to the latest pip.
- 'python -m pip install -U pip setuptools wheel'
# Install the PyInstaller test dependencies.
- 'pip install -U -r tests/requirements-tools.txt -r tests/requirements-libraries.txt'
# Install PyInstaller
- 'pip install -e .'
# Make sure the help options print.
- 'python -m pyinstaller -h'
build: none
test_script:
# Run the tests appropriate for this entry in the test matrix. Skip tests
# if we're just updating the cache.
#
# On Windows, the ``noarchive`` test re-compiles all ``.pyc`` or ``.pyo``
# files. If run in parallel, one test will be trying to read a compiled file
# while the other is writing it, producing a ``PermissionError: [Errno 13]
# Permission denied`` exception. To avoid this, run these two tests in
# separate ``pytest`` invokations.
- >-
if not "%APPVEYOR_SCHEDULED_BUILD%" == "True" (
%PYTEST% -k "test_noarchive[onefile]" &&
%PYTEST% -k "not test_noarchive[onefile]"
)
on_finish:
# Remove old or huge cache files to hopefully not exceed the 1GB cache limit.
#
# If the cache limit is reached, the cache will not be updated (of not even
# created in the first run). So this is a trade of between keeping the cache
# current and having a cache at all.
# NB: This is done only `on_success` since the cache in uploaded only on
# success anyway.
- C:\cygwin\bin\find "%LOCALAPPDATA%\pip" -type f -mtime +360 -delete
- C:\cygwin\bin\find "%LOCALAPPDATA%\pip" -type f -size +10M -delete
- C:\cygwin\bin\find "%LOCALAPPDATA%\pip" -empty -delete
# Show size of cache
- C:\cygwin\bin\du -hs "%LOCALAPPDATA%\pip\Cache"
- ps: |
(new-object net.webclient).UploadFile(
"https://ci.appveyor.com/api/testresults/junit/$($env:APPVEYOR_JOB_ID)",
(Resolve-Path .\junit-results.xml)
)
$LastExitCode = 0
# Uncomment to pause the build until a special "lock" file on the VM desktop
# is deleted. See https://www.appveyor.com/docs/how-to/rdp-to-build-worker/.
#- ps: $blockRdp = $true; iex ((new-object net.webclient).DownloadString('https://raw.githubusercontent.com/appveyor/ci/master/scripts/enable-rdp.ps1'))