Files
openide/python/setup-test-environment/build.gradle
2018-07-17 14:04:58 +03:00

166 lines
6.4 KiB
Groovy

import org.apache.tools.ant.taskdefs.condition.Os
import java.nio.file.Files
import java.nio.file.Paths
plugins {
id "com.jetbrains.python.envs" version "0.0.25"
}
/**
* Installs python interpreters for env. tests using conda or CPython.
* Utilizes following env variables:
*
* PYCHARM_PYTHONS -- path to install cPythons
* PYCHARM_PYTHON_VIRTUAL_ENVS -- path to install condas
*
* PYCHARM_USE_CONDA -- use conda (cPython will be used if not set)
*
* PYCHARM_ZIP_REPOSITORY -- to download unpacked pythons for Windows (default cpython does not support unattended installation)
* Recommended value: http://repo.labs.intellij.net/pycharm/python-archives-windows/
*
* Pitfall: TMP var on windows points to very long path inside of user local dir and may lead to errors.
* It is recommended to create "c:\temp\" with full write access and set TMP="c:\temp\" on Windows.
*
* ``PyEnvTestSettings`` class uses these vars also.
*
*/
envs {
bootstrapDirectory = new File(System.getenv().getOrDefault("PYCHARM_PYTHONS", new File(buildDir, 'pythons').path))
envsDirectory = new File(System.getenv().getOrDefault("PYCHARM_PYTHON_VIRTUAL_ENVS", new File(buildDir, 'envs').path))
if (System.getenv().containsKey("PYCHARM_ZIP_REPOSITORY")) {
zipRepository = new URL(System.getenv().get("PYCHARM_ZIP_REPOSITORY"))
shouldUseZipsFromRepository = Os.isFamily(Os.FAMILY_WINDOWS)
}
Boolean shouldUseCondaInterpreters = System.getenv().getOrDefault("PYCHARM_USE_CONDA", false)
Closure createPython = { String pythonName,
String version,
List<String> packages = null,
String tags = null,
Boolean createLink = false,
Boolean forceConda = false ->
File pythonDirectory
if (shouldUseCondaInterpreters || forceConda) {
condaenv pythonName, version, packages
pythonDirectory = new File(envsDirectory, pythonName)
} else {
python pythonName, version, packages
pythonDirectory = new File(bootstrapDirectory, pythonName)
}
project.tasks.create("Misc for $pythonName") {
shouldRunAfter 'build_envs'
doLast {
if (tags) new File(pythonDirectory, "tags.txt").write(tags)
if (createLink) {
String linkName = "python${version.split(/\./)[0..1].join(".")}"
Closure createLinkClosure = { java.nio.file.Path link, java.nio.file.Path existing ->
if (!link.toFile().exists()) Files.createLink(link, existing)
}
if (Os.isFamily(Os.FAMILY_UNIX) && !shouldUseCondaInterpreters) {
createLinkClosure(Paths.get(pythonDirectory.toString(), linkName),
Paths.get(pythonDirectory.toString(), "bin/$linkName"))
} else if (Os.isFamily(Os.FAMILY_WINDOWS)) {
createLinkClosure(Paths.get(pythonDirectory.toString(), "${linkName}.exe"),
Paths.get(pythonDirectory.toString(), "python.exe"))
}
}
}
}
}
createPython("py2_django18_full",
"2.7.15",
["django==1.8", "tox", "nose", "pytest", "Twisted", "behave", "lettuce>=0.2.22", "unittest2", "teamcity-messages", "django-nose"]
+ ( Os.isFamily(Os.FAMILY_WINDOWS) ? ['pypiwin32'] : [] ) //win32api is required for pypiwin32
,
"python2.7\ndjango\nnose\npytest\nbehave\nlettuce\npackaging\ntox\nunittest2\ntwisted\ndjango-nose",
true)
createPython("py35_django20_full",
"3.5.4",
["ipython==2.1", "django==2.0", "behave", "jinja2", "tox>=2.0", "nose", "pytest", "django-nose", "behave-django"],
"python3.4\npython3\nipython\nipython200\nskeletons\ndjango\nbehave\ntox\njinja2\npython34\npackaging\npytest\nnose\ndjango-nose\nbehave-django\ndjango20",
true)
// Mostly for tox
createPython("py34",
"3.4.4",
[],
"python3.4",
true)
createPython("py36_django1_11",
"3.6.6",
["django==1.11", "jinja2", "pandas"],
"python3.6\npython3\ndjango\njinja2\npython34\npython36\npandas",
true)
if (Os.isFamily(Os.FAMILY_UNIX)) {
createPython("pyqt_env", "3.5.4", ["pyqt5==5.10.1"], "pyqt5", true)
}
createPython("django_latest", "3.5.4", ["django", "behave-django", "behave"], "python3.5\ndjango\ndjango20\nbehave\nbehave-django\ndjango20", true)
if (Os.isFamily(Os.FAMILY_WINDOWS)) { // Only windows needs ironPython
ironpython "ironpython", "32" // For some reason x64 is buggy and leads to StackOverflow when called with ensurepip
project.tasks.create("Misc for ironpython") { //"Misc" will be launched by "build"
shouldRunAfter 'build_envs'
doLast {
def file = Paths.get(bootstrapDirectory.toString(), "ironpython", "tags.txt").toFile()
file.createNewFile()
file.write("iron")
}
}
}
}
/**
* Kills any process named "python" using windows powershell.
* Works on Win7+.
*/
task killPythonWindows(type: Exec) {
onlyIf { Os.isFamily(Os.FAMILY_WINDOWS) }
commandLine 'powershell', '"Get-Process | where {$_.Name -ieq \\"python\\"} | Stop-Process"'
}
task prepare(type: Delete) {
// Python leaked from previous test may prevent this script from
// deleting folder because you can't delete file opened by process on Windows
dependsOn killPythonWindows
doFirst {
new File(envs.bootstrapDirectory, "django_latest").with { djangoLatestFolder ->
if (djangoLatestFolder.exists() && djangoLatestFolder.lastModified() < System.currentTimeMillis() - 24 * 60 * 60 * 1000) {
// older then a day
println "Cleaning django_latest at" + djangoLatestFolder
delete djangoLatestFolder
}
}
if (!envs.bootstrapDirectory.exists() || (System.getenv("NO_CLEAN") == null && envs.envsDirectory.exists() &&
envs.envsDirectory.lastModified() < project.buildscript.sourceFile.lastModified())) {
// clean the cache if the build script was modified later
println "Cleaning cached environments at " + envs.envsDirectory
delete envs.envsDirectory
println "Cleaning cached pythons at " + envs.bootstrapDirectory
delete envs.bootstrapDirectory
}
}
}
task build {
mustRunAfter prepare
dependsOn prepare, 'build_envs', tasks.findAll { it.name.startsWith("Misc") }
}