environment: global: # SDK v7.0 MSVC Express 2008's SetEnv.cmd script will fail if the # /E:ON and /V:ON options are not enabled in the batch script interpreter # See: http://stackoverflow.com/a/13751649/163740 CMD_IN_ENV: "cmd /E:ON /V:ON /C .\\.appveyor\\run_with_env.cmd" # The pip version upgrade message on stderr causes appveyor to fail steps. PIP_DISABLE_PIP_VERSION_CHECK: "1" matrix: - PYTHON: "C:\\Python35" PYTHON_VERSION: "3.5.x" # currently 3.5.3 PYTHON_ARCH: "32" - PYTHON: "C:\\Python35-x64" PYTHON_VERSION: "3.5.x" # currently 3.5.3 PYTHON_ARCH: "64" - PYTHON: "C:\\Python36" PYTHON_VERSION: "3.6.x" # currently 3.6.5 PYTHON_ARCH: "32" - PYTHON: "C:\\Python36-x64" PYTHON_VERSION: "3.6.x" # currently 3.6.5 PYTHON_ARCH: "64" - PYTHON: "C:\\Python37" PYTHON_VERSION: "3.7.x" PYTHON_ARCH: "32" - PYTHON: "C:\\Python37-x64" PYTHON_VERSION: "3.7.x" PYTHON_ARCH: "64" - PYTHON: "C:\\Python38" PYTHON_VERSION: "3.8.x" PYTHON_ARCH: "32" - PYTHON: "C:\\Python38-x64" PYTHON_VERSION: "3.8.x" PYTHON_ARCH: "64" - PYTHON: "C:\\Python39" PYTHON_VERSION: "3.9.1" PYTHON_ARCH: "32" - PYTHON: "C:\\Python39-x64" PYTHON_VERSION: "3.9.1" PYTHON_ARCH: "64" install: #- "%CMD_IN_ENV% set" # 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." } #- ECHO "Filesystem root:" #- ps: "ls \"C:/\"" #- ECHO "Installed SDKs:" #- ps: "ls \"C:/Program Files/Microsoft SDKs/Windows\"" # Install Python (from the official .msi of http://python.org) and pip when # not already installed. - ps: if (-not(Test-Path($env:PYTHON))) { & .appveyor\install.ps1 } # 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" - "python -c \"import struct; print(struct.calcsize('P') * 8)\"" # Install the build dependencies of the project. 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 - "%CMD_IN_ENV% python -m pip install --upgrade setuptools" - "%CMD_IN_ENV% pip install -r requirements-dev.txt" - "%CMD_IN_ENV% pip install wheel" # Build the compiled extension - "%CMD_IN_ENV% python winbuild.py getdeps" build_script: #- call "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\vcvarsall.bat" x86 # Build the compiled extension - "%CMD_IN_ENV% python setup.py docstrings" - "%CMD_IN_ENV% python setup.py --with-openssl --libcurl-lib-name=libcurl_a.lib --openssl-lib-name=\"\" --curl-dir=deps bdist_wheel bdist_wininst bdist_msi bdist_egg --link-arg=/LIBPATH:deps/lib --link-arg=zlib.lib --link-arg=libcrypto.lib --link-arg=libssl.lib --link-arg=crypt32.lib --link-arg=advapi32.lib --link-arg=libcares.lib --link-arg=libssh2.lib --link-arg=nghttp2_static.lib --link-arg=normaliz.lib --link-arg=user32.lib" test_script: # Run the project tests - ps: $whl = get-childitem dist\*.whl; pip install $whl - pytest after_test: # If tests are successful, create binary packages for the project. #- "%CMD_IN_ENV% python setup.py bdist_wheel" #- "%CMD_IN_ENV% python setup.py bdist_wininst" #- "%CMD_IN_ENV% python setup.py bdist_msi" - ps: "ls dist" artifacts: # Archive the generated packages in the ci.appveyor.com build report. - path: dist\* on_success: # below are 4 environment variables that you can set to allow twine to upload # these should be set from the appveyor web gui and not in the script. and # only set them when you are doing a release # TWINE_USERNAME # TWINE_PASSWORD # TWINE_REPOSITORY_URL # TWINE_CERT - ps: >- if (Test-Path 'ENV:TWINE_PASSWORD') { pip install twine python -m twine upload dist/* } else { "Skipping twine upload." }