From 8dc12d0f8871725012d708078b659e0c35f7f13f Mon Sep 17 00:00:00 2001 From: Colin Goodheart-Smithe Date: Thu, 1 Dec 2016 15:48:51 +0000 Subject: [PATCH] Gets ES plugin to download the cpp code if not built locally Original commit: elastic/x-pack-elasticsearch@64cc4aeb38bbf2d43b56d3c76d6b083dfeb74f11 --- build.gradle | 27 ++++++++++++++++++++++----- elasticsearch/build.gradle | 18 ++++++++---------- 2 files changed, 30 insertions(+), 15 deletions(-) diff --git a/build.gradle b/build.gradle index 8d13b2a34cd..5a80ad7c313 100644 --- a/build.gradle +++ b/build.gradle @@ -4,6 +4,7 @@ import org.gradle.internal.os.OperatingSystem import org.gradle.plugins.ide.eclipse.model.SourceFolder import org.elasticsearch.gradle.precommit.LicenseHeadersTask import org.elasticsearch.gradle.VersionProperties +import org.elastic.gradle.UploadS3Task import java.nio.file.Files import java.nio.file.Paths @@ -32,6 +33,12 @@ project.ext.nasExtension = '_' + (System.getenv()['GIT_COMMIT'] ?: 'xxxxxxxxxxxx (isWindows ? "_windows-x86_64.zip" : (isMacOsX ? "_darwin-x86_64.zip" : (isLinux ? "_linux-x86_64.zip" : "_sunos-x86_64.zip"))) +String uploadEnabledStr = properties.get('upload', 'false') +if (['true', 'false'].contains(uploadEnabledStr) == false) { + throw new GradleException("upload must be true or false, got ${uploadEnabledStr}") +} +project.ext.uploadEnabled = uploadEnabledStr == 'true' + // 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') @@ -88,7 +95,7 @@ subprojects { } task bundlePack(type: Zip) { - onlyIf { project('kibana').bundlePlugin.enabled && project('cpp').strip.enabled } + onlyIf { project('kibana').bundlePlugin.enabled } dependsOn 'elasticsearch:bundlePlugin' dependsOn 'kibana:bundlePlugin' from { zipTree(project('elasticsearch').bundlePlugin.outputs.files.singleFile) } @@ -103,7 +110,12 @@ task assemble(dependsOn: bundlePack) { description = 'Assembles the outputs of this project.' } -task build(dependsOn: assemble) { +task test(dependsOn: [':elasticsearch:test', ':cpp:test', ':kibana:test']) { + group = 'Build' + description = 'Assembles and tests this project.' +} + +task build(dependsOn: [assemble, test]) { group = 'Build' description = 'Assembles and tests this project.' } @@ -126,16 +138,21 @@ class SimpleCopy extends DefaultTask { } // norelease: by the time we move to x-plugins we cannot use the Prelert NAS at all -task uploadPack(type: SimpleCopy) { +task uploadPack(type: SimpleCopy, dependsOn: [build]) { // This doesn't use a Copy task because that builds hashes for a huge number of files on the NAS String zipFile = "prelert-${elasticsearchVersion}.zip" sourceFile = "${projectDir}/build/distributions/" + zipFile destFile = project.ext.nasDirectory + zipFile.replace('.zip', project.ext.nasExtension) } -uploadPack.dependsOn build +task uploadPackToS3(type: UploadS3Task, dependsOn: [build]) { + enabled project.uploadEnabled + description = 'upload pack zip to S3 Bucket' + bucket 'prelert-artifacts' + upload bundlePack.outputs.files.singleFile, "maven/org.elasticsearch.prelert/prelert/${elasticsearchVersion}/${bundlePack.outputs.files.singleFile.name}" +} -task deploy(dependsOn: uploadPack) { +task deploy(dependsOn: [uploadPackToS3, ':cpp:upload']) { } diff --git a/elasticsearch/build.gradle b/elasticsearch/build.gradle index 8c9769b3c44..3896c5e40c1 100644 --- a/elasticsearch/build.gradle +++ b/elasticsearch/build.gradle @@ -46,22 +46,20 @@ task downloadCppDist(type: DownloadS3Task) { bucket 'prelert-artifacts' destDir file("${buildDir}/cppDist") flatten true - download "maven/${project.group}/prelert_cpp_darwin-x86_64/${elasticsearchVersion}/prelert_cpp_darwin-x86_64.zip" + download "maven/${project.group}/prelert-cpp/${elasticsearchVersion}/prelert-cpp-darwin-x86_64-${elasticsearchVersion}.zip" + outputs.file(file("${buildDir}/cppDist/prelert-cpp-darwin-x86_64-${elasticsearchVersion}.zip")) } bundlePlugin { if (project.cppEnabled) { from { zipTree(project(':cpp').buildZip.outputs.files.singleFile) } + dependsOn ':cpp:buildZip' } else { - from("${rootDir}/cppdistribution") { - into '.' - // Don't copy Windows import libraries - exclude "**/*.lib" - // Don't copy the test support library - exclude "**/libPreTest.*" - includeEmptyDirs = false + print "READ ME ::::::::: " + downloadCppDist.outputs + "\n" + for (file in downloadCppDist.outputs.files) { + print "READ ME ::::::::: " + file + "\n" + from{ zipTree(file) } } + dependsOn 'downloadCppDist' } } - -bundlePlugin.dependsOn([':cpp:buildZip', 'downloadCppDist'])