kivy/.ci/windows_ci.ps1

143 lines
5.4 KiB
PowerShell

function raise-only-error{
Param([scriptblock]$Func)
# powershell interprets writing to stderr as an error, so only raise error if the return code is none-zero
try {
$Func.Invoke()
} catch {
if ($LastExitCode -ne 0) {
throw $_
} else {
echo $_
}
}
}
function Handle-NonZero-ExitCode {
param (
[int]$ExitCode
)
Write-Host "Exit code is: $ExitCode"
if ($ExitCode -ne 0) {
throw "Exiting due to non-zero exit code"
}
}
function Update-version-metadata {
$current_time = python -c "from time import time; from os import environ; print(int(environ.get('SOURCE_DATE_EPOCH', time())))"
$date = python -c "from datetime import datetime; print(datetime.utcfromtimestamp($current_time).strftime('%Y%m%d'))"
echo "Version date is: $date"
$git_tag = git rev-parse HEAD
echo "Git tag is: $git_tag"
(Get-Content .\kivy\_version.py -Raw) -replace "_kivy_git_hash = ''","_kivy_git_hash = '$git_tag'" `
-replace "_kivy_build_date = ''","_kivy_build_date = '$date'" | Out-File -filepath .\kivy\_version.py
}
function Generate-sdist {
python -m pip install -U build
python -m build --sdist .
$env:KIVY_BUILD_EXAMPLES = '1'
python -m build --wheel .
}
function Generate-windows-wheels {
pip wheel --no-deps . -w dist/
}
function Rename-windows-wheels {
# Set new wheel name, keep default if release (tag)
# release: Kivy-X.Y.Z-cpAB-cpABm-ARCH.whl (Kivy_examples-X.Y.Z-py2.py3-none-any.whl)
# nightly: Kivy-X.Y.Z.dev0-cpAB-cpABm-ARCH.whl (Kivy_examples-X.Y.Z.dev0-py2.py3-none-any.whl)
# archive: Kivy-X.Y.Z.dev0.YYYYMMDD.githash-cpAB-cpABm-ARCH.whl (Kivy_examples-X.Y.Z.dev0.YYYYMMDD.githash-py2.py3-none-any.whl)
$WHEEL_DATE = python -c "from datetime import datetime;print(datetime.utcnow().strftime('%Y%m%d'))"
echo "Wheel date is: $WHEEL_DATE"
$GIT_TAG = git rev-parse --short HEAD
echo "Git tag is: $GIT_TAG"
raise-only-error -Func {python -c "import kivy" --config "kivy:log_level:error"}
$WHEEL_VERSION = python -c "import kivy;print(kivy.__version__)" --config "kivy:log_level:error"
echo "Kivy version is: $WHEEL_VERSION"
$TAG_NAME = python -c "import kivy; _, tag, n = kivy.parse_kivy_version(kivy.__version__); print(tag + n) if n is not None else print(tag or 'something')" --config "kivy:log_level:error"
echo "Tag is: $TAG_NAME"
$WHEEL_NAME = "$TAG_NAME.$WHEEL_DATE`.$GIT_TAG-"
echo "New wheel name is: $WHEEL_NAME"
$files = Get-ChildItem dist *.whl -Name
foreach ($WHEEL_DEFAULT in $files){
$WHEEL_NIGHTLY = $WHEEL_DEFAULT.Replace("$TAG_NAME-", $WHEEL_NAME)
echo "Copying from default $WHEEL_DEFAULT to nightly $WHEEL_NIGHTLY"
Copy-Item "dist\$WHEEL_DEFAULT" "dist\$WHEEL_NIGHTLY"
}
}
function Upload-windows-wheels-to-server($ip) {
echo "Uploading Kivy*:"
dir dist
C:\tools\msys64\usr\bin\bash --login -c ".ci/windows-server-upload.sh $ip dist 'Kivy*' ci/win/kivy/"
}
function Install-kivy {
python -m pip install -e .[dev,full]
}
function Install-kivy-wheel {
$root=(pwd).Path
ls $root
ls $root/dist
cd "$HOME"
$version=python -c "import sys; print('{}{}'.format(sys.version_info.major, sys.version_info.minor))"
$bitness=python -c "import sys; print('win_amd64' if sys.maxsize > 2**32 else 'win32')"
$kivy_fname=(ls $root/dist/Kivy-*$version*$bitness*.whl | Sort-Object -property @{Expression={$_.name.tostring().Length}} | Select-Object -First 1).name
$kivy_examples_fname=(ls $root/dist/Kivy_examples-*.whl | Sort-Object -property @{Expression={$_.name.tostring().Length}} | Select-Object -First 1).name
echo "kivy_fname = $kivy_fname, kivy_examples_fname = $kivy_examples_fname"
python -m pip install "$root/dist/$kivy_fname[full,dev]" "$root/dist/$kivy_examples_fname"
}
function Install-kivy-sdist {
$root=(pwd).Path
cd "$HOME"
$kivy_fname=(ls $root/dist/Kivy-*.tar.gz).name
python -m pip install "$root/dist/$kivy_fname[full,dev]"
}
function Test-kivy {
# Tests with default environment variables.
python -m pytest --timeout=400 --cov=kivy --cov-branch --cov-report= "$(pwd)/kivy/tests"
# Check the exit code.
# For some reason, if we get a Windows Fatal Error during the tests, pytest
# stops the tests, but does not fail.
# Since we do not have an option like -e for bash, we need to check the exit
# code manually, so the CI job fails if something goes wrong.
# See issue https://github.com/kivy/kivy/issues/8484 for more details.
Handle-NonZero-ExitCode -ExitCode $LastExitCode
# Logging tests, with non-default log modes
$env:KIVY_LOG_MODE = 'PYTHON'
python -m pytest -m logmodepython --timeout=400 --cov=kivy --cov-append --cov-report= --cov-branch "$(pwd)/kivy/tests"
$env:KIVY_LOG_MODE = 'MIXED'
python -m pytest -m logmodemixed --timeout=400 --cov=kivy --cov-append --cov-report=term --cov-branch "$(pwd)/kivy/tests"
}
function Test-kivy-benchmark {
pytest --pyargs kivy.tests --benchmark-only
}
function Test-kivy-installed {
cd "$HOME"
python -c 'import kivy'
$test_path=python -c 'import kivy.tests as tests; print(tests.__path__[0])' --config "kivy:log_level:error"
cd "$test_path"
echo "[run]`nplugins = kivy.tools.coverage`n" > .coveragerc
raise-only-error -Func {python -m pytest --timeout=400 .}
}
function Upload-artifacts-to-pypi {
python -m pip install twine
twine upload dist/*
}