Changes build to only grab cpp zip if it was built
Original commit: elastic/x-pack-elasticsearch@24fc48fe86
This commit is contained in:
parent
53adc100ad
commit
e5e039973e
25
build.gradle
25
build.gradle
|
@ -13,6 +13,9 @@ boolean isWindows = OperatingSystem.current().isWindows()
|
||||||
boolean isLinux = OperatingSystem.current().isLinux()
|
boolean isLinux = OperatingSystem.current().isLinux()
|
||||||
boolean isMacOsX = OperatingSystem.current().isMacOsX()
|
boolean isMacOsX = OperatingSystem.current().isMacOsX()
|
||||||
|
|
||||||
|
project.ext.bash = isWindows ? "C:\\Program Files\\Git\\bin\\bash" : "/bin/bash"
|
||||||
|
|
||||||
|
// norelease: replace with something else when we become part of x-plugins
|
||||||
project.ext.nasDirectory = isWindows ? "\\\\prelert-nas\\builds\\6.5.0\\" :
|
project.ext.nasDirectory = isWindows ? "\\\\prelert-nas\\builds\\6.5.0\\" :
|
||||||
(isMacOsX ? "/Volumes/builds/6.5.0/" : "/export/builds/6.5.0/")
|
(isMacOsX ? "/Volumes/builds/6.5.0/" : "/export/builds/6.5.0/")
|
||||||
// norelease: replace with something else when we become part of x-plugins
|
// norelease: replace with something else when we become part of x-plugins
|
||||||
|
@ -20,6 +23,28 @@ project.ext.nasExtension = '_' + (System.getenv()['GIT_COMMIT'] ?: 'xxxxxxxxxxxx
|
||||||
(isWindows ? "_windows-x86_64.zip" : (isMacOsX ? "_darwin-x86_64.zip" :
|
(isWindows ? "_windows-x86_64.zip" : (isMacOsX ? "_darwin-x86_64.zip" :
|
||||||
(isLinux ? "_linux-x86_64.zip" : "_sunos-x86_64.zip")))
|
(isLinux ? "_linux-x86_64.zip" : "_sunos-x86_64.zip")))
|
||||||
|
|
||||||
|
// C++ build can be explicitly enabled or disabled, or if neither is chosen
|
||||||
|
// it will be enabled if the necessary 3rd party dependencies are present
|
||||||
|
String cppEnabledStr = properties.get('xpack.cpp.build', 'auto')
|
||||||
|
if (['true', 'false', 'auto'].contains(cppEnabledStr) == false) {
|
||||||
|
throw new GradleException("xpack.cpp.build must be true or false, got ${cppEnabledStr}")
|
||||||
|
}
|
||||||
|
project.ext.cppEnabled = cppEnabledStr == 'true'
|
||||||
|
if (cppEnabledStr == 'auto') {
|
||||||
|
// Disable the C++ build if the 3rd party tools/libraries aren't available
|
||||||
|
String[] cmdArray = [ project.ext.bash, '-c', 'source cpp/set_env.sh && 3rd_party/3rd_party.sh --check' ]
|
||||||
|
Process checkProcess = Runtime.getRuntime().exec(cmdArray, null, rootDir)
|
||||||
|
StringBuffer checkOutput = new StringBuffer()
|
||||||
|
checkProcess.consumeProcessOutputStream(checkOutput)
|
||||||
|
if (checkProcess.waitFor() == 0) {
|
||||||
|
project.ext.cppEnabled = true
|
||||||
|
} else {
|
||||||
|
println 'C++ dependencies not available - disabling C++ build'
|
||||||
|
println checkOutput
|
||||||
|
project.ext.cppEnabled = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
configurations.all {
|
configurations.all {
|
||||||
// check for updates every build
|
// check for updates every build
|
||||||
resolutionStrategy.cacheChangingModulesFor 0, 'seconds'
|
resolutionStrategy.cacheChangingModulesFor 0, 'seconds'
|
||||||
|
|
|
@ -40,7 +40,18 @@ integTest {
|
||||||
integTest.mustRunAfter noBootstrapTest
|
integTest.mustRunAfter noBootstrapTest
|
||||||
|
|
||||||
bundlePlugin {
|
bundlePlugin {
|
||||||
|
if (project.cppEnabled) {
|
||||||
from { zipTree(project(':cpp').buildZip.outputs.files.singleFile) }
|
from { zipTree(project(':cpp').buildZip.outputs.files.singleFile) }
|
||||||
|
} else {
|
||||||
|
from("${rootDir}/cppdistribution") {
|
||||||
|
into '.'
|
||||||
|
// Don't copy Windows import libraries
|
||||||
|
exclude "**/*.lib"
|
||||||
|
// Don't copy the test support library
|
||||||
|
exclude "**/libPreTest.*"
|
||||||
|
includeEmptyDirs = false
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bundlePlugin.dependsOn(':cpp:buildZip')
|
bundlePlugin.dependsOn(':cpp:buildZip')
|
||||||
|
|
Loading…
Reference in New Issue