Remove any non oss from build, package, and distribution (#102)

This commit changes the building, packaging, and testing framework to only support OSS on different distributions.

Next steps:

completely remove -oss flag dependencies in package and build tests
move 6.x bwc testing to be an explicit option
remove any references to elastic.co download site (or replace with downloads from the OSS website)

Co-authored-by: Himanshu Setia <setiah@amazon.com>
Co-authored-by: Rabi Panda <pandarab@amazon.com>
Co-authored-by: Himanshu Setia <58999915+setiah@users.noreply.github.com>
Co-authored-by: Sarat Vemulapalli <vemsarat@amazon.com>
Signed-off-by: Peter Nied <petern@amazon.com>
This commit is contained in:
Nick Knize 2021-02-22 17:08:15 -06:00 committed by Peter Nied
parent 5544bc6caa
commit 83e87f7e54
92 changed files with 324 additions and 1357 deletions

View File

@ -171,12 +171,8 @@ if (project != rootProject) {
dependencies { dependencies {
reaper project('reaper') reaper project('reaper')
distribution project(':distribution:archives:windows-zip')
distribution project(':distribution:archives:oss-windows-zip') distribution project(':distribution:archives:oss-windows-zip')
distribution project(':distribution:archives:darwin-tar')
distribution project(':distribution:archives:oss-darwin-tar') distribution project(':distribution:archives:oss-darwin-tar')
distribution project(':distribution:archives:linux-aarch64-tar')
distribution project(':distribution:archives:linux-tar')
distribution project(':distribution:archives:oss-linux-tar') distribution project(':distribution:archives:oss-linux-tar')
distribution project(':distribution:archives:oss-linux-aarch64-tar') distribution project(':distribution:archives:oss-linux-aarch64-tar')

View File

@ -108,7 +108,7 @@ class DistributionDownloadPluginFuncTest extends AbstractGradleFuncTest {
then: then:
result.tasks.size() == 3 result.tasks.size() == 3
result.output.count("Unpacking elasticsearch-${version}-linux-x86_64.tar.gz " + result.output.count("Unpacking elasticsearch-oss-${version}-linux-x86_64.tar.gz " +
"using SymbolicLinkPreservingUntarTransform.") == 1 "using SymbolicLinkPreservingUntarTransform.") == 1
} }
@ -155,4 +155,4 @@ class DistributionDownloadPluginFuncTest extends AbstractGradleFuncTest {
} }
""" """
} }
} }

View File

@ -112,6 +112,7 @@ abstract class AbstractGradleFuncTest extends Specification {
} }
void setupLocalGitRepo() { void setupLocalGitRepo() {
//TODO: cleanup
execute("git init") execute("git init")
execute('git config user.email "build-tool@elastic.co"') execute('git config user.email "build-tool@elastic.co"')
execute('git config user.name "Build tool"') execute('git config user.name "Build tool"')

View File

@ -54,7 +54,7 @@ class DistributionDownloadFixture {
private static String urlPath(String version,ElasticsearchDistribution.Platform platform) { private static String urlPath(String version,ElasticsearchDistribution.Platform platform) {
String fileType = ((platform == ElasticsearchDistribution.Platform.LINUX || String fileType = ((platform == ElasticsearchDistribution.Platform.LINUX ||
platform == ElasticsearchDistribution.Platform.DARWIN)) ? "tar.gz" : "zip" platform == ElasticsearchDistribution.Platform.DARWIN)) ? "tar.gz" : "zip"
"/downloads/elasticsearch/elasticsearch-${version}-${platform}-x86_64.$fileType" "/downloads/elasticsearch/elasticsearch-oss-${version}-${platform}-x86_64.$fileType"
} }
private static byte[] filebytes(String urlPath) throws IOException { private static byte[] filebytes(String urlPath) throws IOException {

View File

@ -33,7 +33,7 @@ class InternalDistributionArchiveSetupPluginFuncTest extends AbstractGradleFuncT
def setup() { def setup() {
buildFile << """ buildFile << """
import org.elasticsearch.gradle.tar.SymbolicLinkPreservingTar import org.elasticsearch.gradle.tar.SymbolicLinkPreservingTar
plugins { plugins {
id 'elasticsearch.internal-distribution-archive-setup' id 'elasticsearch.internal-distribution-archive-setup'
} }
@ -60,7 +60,6 @@ class InternalDistributionArchiveSetupPluginFuncTest extends AbstractGradleFuncT
where: where:
buildTaskName | expectedOutputArchivePath buildTaskName | expectedOutputArchivePath
"buildDarwinTar" | "darwin-tar/build/distributions/elasticsearch.tar.gz"
"buildOssDarwinTar" | "oss-darwin-tar/build/distributions/elasticsearch-oss.tar.gz" "buildOssDarwinTar" | "oss-darwin-tar/build/distributions/elasticsearch-oss.tar.gz"
} }
@ -82,7 +81,6 @@ class InternalDistributionArchiveSetupPluginFuncTest extends AbstractGradleFuncT
where: where:
buildTaskName | expectedOutputArchivePath buildTaskName | expectedOutputArchivePath
"buildDarwinZip" | "darwin-zip/build/distributions/elasticsearch.zip"
"buildOssDarwinZip" | "oss-darwin-zip/build/distributions/elasticsearch-oss.zip" "buildOssDarwinZip" | "oss-darwin-zip/build/distributions/elasticsearch-oss.zip"
} }
@ -111,23 +109,23 @@ class InternalDistributionArchiveSetupPluginFuncTest extends AbstractGradleFuncT
} }
} }
} }
project('consumer') { p -> project('consumer') { p ->
configurations { configurations {
consumeArchive {} consumeArchive {}
consumeDir {} consumeDir {}
} }
dependencies { dependencies {
consumeDir project(path: ':producer-tar', configuration:'extracted') consumeDir project(path: ':producer-tar', configuration:'extracted')
consumeArchive project(path: ':producer-tar', configuration:'default' ) consumeArchive project(path: ':producer-tar', configuration:'default' )
} }
tasks.register("copyDir", Copy) { tasks.register("copyDir", Copy) {
from(configurations.consumeDir) from(configurations.consumeDir)
into('build/dir') into('build/dir')
} }
tasks.register("copyArchive", Copy) { tasks.register("copyArchive", Copy) {
from(configurations.consumeArchive) from(configurations.consumeArchive)
into('build/archives') into('build/archives')
@ -140,8 +138,8 @@ class InternalDistributionArchiveSetupPluginFuncTest extends AbstractGradleFuncT
then: "tar task executed and target folder contains plain tar" then: "tar task executed and target folder contains plain tar"
result.task(':buildProducerTar').outcome == TaskOutcome.SUCCESS result.task(':buildProducerTar').outcome == TaskOutcome.SUCCESS
result.task(':consumer:copyArchive').outcome == TaskOutcome.SUCCESS result.task(':consumer:copyArchive').outcome == TaskOutcome.SUCCESS
file("producer-tar/build/distributions/elasticsearch.tar.gz").exists() file("producer-tar/build/distributions/elasticsearch-oss.tar.gz").exists()
file("consumer/build/archives/elasticsearch.tar.gz").exists() file("consumer/build/archives/elasticsearch-oss.tar.gz").exists()
when: when:
result = gradleRunner("copyDir", "-Pversion=1.0").build() result = gradleRunner("copyDir", "-Pversion=1.0").build()

View File

@ -46,32 +46,29 @@ class InternalDistributionBwcSetupPluginFuncTest extends AbstractGradleFuncTest
def "builds distribution from branches via archives assemble"() { def "builds distribution from branches via archives assemble"() {
when: when:
def result = gradleRunner(new File(testProjectDir.root, "remote"), def result = gradleRunner(new File(testProjectDir.root, "remote"),
":distribution:bwc:bugfix:buildBwcDarwinTar",
":distribution:bwc:bugfix:buildBwcOssDarwinTar", ":distribution:bwc:bugfix:buildBwcOssDarwinTar",
"-DtestRemoteRepo=" + remoteGitRepo, "-DtestRemoteRepo=" + remoteGitRepo,
"-Dbwc.remote=origin") "-Dbwc.remote=origin")
.build() .build()
then: then:
result.task(":distribution:bwc:bugfix:buildBwcDarwinTar").outcome == TaskOutcome.SUCCESS
result.task(":distribution:bwc:bugfix:buildBwcOssDarwinTar").outcome == TaskOutcome.SUCCESS result.task(":distribution:bwc:bugfix:buildBwcOssDarwinTar").outcome == TaskOutcome.SUCCESS
and: "assemble task triggered" and: "assemble task triggered"
result.output.contains("[8.0.1] > Task :distribution:archives:darwin-tar:assemble")
result.output.contains("[8.0.1] > Task :distribution:archives:oss-darwin-tar:assemble") result.output.contains("[8.0.1] > Task :distribution:archives:oss-darwin-tar:assemble")
} }
def "bwc distribution archives can be resolved as bwc project artifact"() { def "bwc distribution archives can be resolved as bwc project artifact"() {
setup: setup:
new File(testProjectDir.root, 'remote/build.gradle') << """ new File(testProjectDir.root, 'remote/build.gradle') << """
configurations { configurations {
dists dists
} }
dependencies { dependencies {
dists project(path: ":distribution:bwc:bugfix", configuration:"darwin-tar") dists project(path: ":distribution:bwc:bugfix", configuration:"oss-darwin-tar")
} }
tasks.register("resolveDistributionArchive") { tasks.register("resolveDistributionArchive") {
inputs.files(configurations.dists) inputs.files(configurations.dists)
doLast { doLast {
@ -89,27 +86,27 @@ class InternalDistributionBwcSetupPluginFuncTest extends AbstractGradleFuncTest
.build() .build()
then: then:
result.task(":resolveDistributionArchive").outcome == TaskOutcome.SUCCESS result.task(":resolveDistributionArchive").outcome == TaskOutcome.SUCCESS
result.task(":distribution:bwc:bugfix:buildBwcDarwinTar").outcome == TaskOutcome.SUCCESS result.task(":distribution:bwc:bugfix:buildBwcOssDarwinTar").outcome == TaskOutcome.SUCCESS
and: "assemble task triggered" and: "assemble task triggered"
result.output.contains("[8.0.1] > Task :distribution:archives:darwin-tar:assemble") result.output.contains("[8.0.1] > Task :distribution:archives:oss-darwin-tar:assemble")
normalizedOutput(result.output) normalizedOutput(result.output)
.contains("distfile /distribution/bwc/bugfix/build/bwc/checkout-8.0/distribution/archives/darwin-tar/" + .contains("distfile /distribution/bwc/bugfix/build/bwc/checkout-8.0/distribution/archives/oss-darwin-tar/" +
"build/distributions/elasticsearch-8.0.1-SNAPSHOT-darwin-x86_64.tar.gz") "build/distributions/elasticsearch-oss-8.0.1-SNAPSHOT-darwin-x86_64.tar.gz")
} }
def "bwc expanded distribution folder can be resolved as bwc project artifact"() { def "bwc expanded distribution folder can be resolved as bwc project artifact"() {
setup: setup:
new File(testProjectDir.root, 'remote/build.gradle') << """ new File(testProjectDir.root, 'remote/build.gradle') << """
configurations { configurations {
expandedDist expandedDist
} }
dependencies { dependencies {
expandedDist project(path: ":distribution:bwc:bugfix", configuration:"expanded-darwin-tar") expandedDist project(path: ":distribution:bwc:bugfix", configuration:"expanded-oss-darwin-tar")
} }
tasks.register("resolveExpandedDistribution") { tasks.register("resolveExpandedDistribution") {
inputs.files(configurations.expandedDist) inputs.files(configurations.expandedDist)
doLast { doLast {
@ -127,13 +124,13 @@ class InternalDistributionBwcSetupPluginFuncTest extends AbstractGradleFuncTest
.build() .build()
then: then:
result.task(":resolveExpandedDistribution").outcome == TaskOutcome.SUCCESS result.task(":resolveExpandedDistribution").outcome == TaskOutcome.SUCCESS
result.task(":distribution:bwc:bugfix:buildBwcDarwinTar").outcome == TaskOutcome.SUCCESS result.task(":distribution:bwc:bugfix:buildBwcOssDarwinTar").outcome == TaskOutcome.SUCCESS
and: "assemble task triggered" and: "assemble task triggered"
result.output.contains("[8.0.1] > Task :distribution:archives:darwin-tar:assemble") result.output.contains("[8.0.1] > Task :distribution:archives:oss-darwin-tar:assemble")
normalizedOutput(result.output) normalizedOutput(result.output)
.contains("distfile /distribution/bwc/bugfix/build/bwc/checkout-8.0/" + .contains("distfile /distribution/bwc/bugfix/build/bwc/checkout-8.0/" +
"distribution/archives/darwin-tar/build/install") "distribution/archives/oss-darwin-tar/build/install")
} }
File setupGitRemote() { File setupGitRemote() {

View File

@ -72,7 +72,7 @@ class InternalDistributionDownloadPluginFuncTest extends AbstractGradleFuncTest
def result = gradleRunner("setupDistro", '-g', testProjectDir.newFolder('GUH').path).build() def result = gradleRunner("setupDistro", '-g', testProjectDir.newFolder('GUH').path).build()
then: then:
result.task(":distribution:archives:linux-tar:buildExpanded").outcome == TaskOutcome.SUCCESS result.task(":distribution:archives:oss-linux-tar:buildExpanded").outcome == TaskOutcome.SUCCESS
result.task(":setupDistro").outcome == TaskOutcome.SUCCESS result.task(":setupDistro").outcome == TaskOutcome.SUCCESS
assertExtractedDistroIsCreated("build/distro", 'current-marker.txt') assertExtractedDistroIsCreated("build/distro", 'current-marker.txt')
} }
@ -144,24 +144,24 @@ class InternalDistributionDownloadPluginFuncTest extends AbstractGradleFuncTest
apply plugin:'base' apply plugin:'base'
// packed distro // packed distro
configurations.create("linux-tar") configurations.create("oss-linux-tar")
tasks.register("buildBwcTask", Tar) { tasks.register("buildBwcTask", Tar) {
from('bwc-marker.txt') from('bwc-marker.txt')
archiveExtension = "tar.gz" archiveExtension = "tar.gz"
compression = Compression.GZIP compression = Compression.GZIP
} }
artifacts { artifacts {
it.add("linux-tar", buildBwcTask) it.add("oss-linux-tar", buildBwcTask)
} }
// expanded distro // expanded distro
configurations.create("expanded-linux-tar") configurations.create("expanded-oss-linux-tar")
def expandedTask = tasks.register("buildBwcExpandedTask", Copy) { def expandedTask = tasks.register("buildBwcExpandedTask", Copy) {
from('bwc-marker.txt') from('bwc-marker.txt')
into('build/install/elastic-distro') into('build/install/elastic-distro')
} }
artifacts { artifacts {
it.add("expanded-linux-tar", file('build/install')) { it.add("expanded-oss-linux-tar", file('build/install')) {
builtBy expandedTask builtBy expandedTask
type = 'directory' type = 'directory'
} }
@ -171,9 +171,9 @@ class InternalDistributionDownloadPluginFuncTest extends AbstractGradleFuncTest
private void localDistroSetup() { private void localDistroSetup() {
settingsFile << """ settingsFile << """
include ":distribution:archives:linux-tar" include ":distribution:archives:oss-linux-tar"
""" """
def bwcSubProjectFolder = testProjectDir.newFolder("distribution", "archives", "linux-tar") def bwcSubProjectFolder = testProjectDir.newFolder("distribution", "archives", "oss-linux-tar")
new File(bwcSubProjectFolder, 'current-marker.txt') << "current" new File(bwcSubProjectFolder, 'current-marker.txt') << "current"
new File(bwcSubProjectFolder, 'build.gradle') << """ new File(bwcSubProjectFolder, 'build.gradle') << """
import org.gradle.api.internal.artifacts.ArtifactAttributes; import org.gradle.api.internal.artifacts.ArtifactAttributes;

View File

@ -23,7 +23,7 @@ subprojects {
tasks.register('tar', Tar) { tasks.register('tar', Tar) {
from('.') from('.')
destinationDirectory.set(file('build/distributions')) destinationDirectory.set(file('build/distributions'))
archiveBaseName.set("elasticsearch${project.name.startsWith('oss')?'-oss':''}") archiveBaseName.set("elasticsearch-oss")
archiveVersion.set("8.0.1-SNAPSHOT") archiveVersion.set("8.0.1-SNAPSHOT")
archiveClassifier.set("darwin-x86_64") archiveClassifier.set("darwin-x86_64")
archiveExtension.set('tar.gz') archiveExtension.set('tar.gz')

View File

@ -19,5 +19,4 @@
include ":distribution:bwc:bugfix" include ":distribution:bwc:bugfix"
include ":distribution:bwc:minor" include ":distribution:bwc:minor"
include ":distribution:archives:darwin-tar"
include ":distribution:archives:oss-darwin-tar" include ":distribution:archives:oss-darwin-tar"

View File

@ -23,8 +23,6 @@ import org.elasticsearch.gradle.Version
import org.elasticsearch.gradle.VersionProperties import org.elasticsearch.gradle.VersionProperties
import org.gradle.api.Plugin import org.gradle.api.Plugin
import org.gradle.api.Project import org.gradle.api.Project
import org.gradle.api.Task
import org.gradle.api.tasks.TaskProvider
/** /**
* Sets up tests for documentation. * Sets up tests for documentation.
@ -37,9 +35,6 @@ class DocsTestPlugin implements Plugin<Project> {
project.pluginManager.apply('elasticsearch.standalone-rest-test') project.pluginManager.apply('elasticsearch.standalone-rest-test')
project.pluginManager.apply('elasticsearch.rest-test') project.pluginManager.apply('elasticsearch.rest-test')
String distribution = System.getProperty('tests.distribution', 'default')
// The distribution can be configured with -Dtests.distribution on the command line
project.testClusters.integTest.testDistribution = distribution.toUpperCase()
project.testClusters.integTest.nameCustomization = { it.replace("integTest", "node") } project.testClusters.integTest.nameCustomization = { it.replace("integTest", "node") }
// Docs are published separately so no need to assemble // Docs are published separately so no need to assemble
project.tasks.assemble.enabled = false project.tasks.assemble.enabled = false
@ -51,7 +46,6 @@ class DocsTestPlugin implements Plugin<Project> {
'\\{version\\}': Version.fromString(VersionProperties.elasticsearch).toString(), '\\{version\\}': Version.fromString(VersionProperties.elasticsearch).toString(),
'\\{version_qualified\\}': VersionProperties.elasticsearch, '\\{version_qualified\\}': VersionProperties.elasticsearch,
'\\{lucene_version\\}' : VersionProperties.lucene.replaceAll('-snapshot-\\w+$', ''), '\\{lucene_version\\}' : VersionProperties.lucene.replaceAll('-snapshot-\\w+$', ''),
'\\{build_flavor\\}' : distribution,
'\\{build_type\\}' : OS.conditionalString().onWindows({"zip"}).onUnix({"tar"}).supply(), '\\{build_type\\}' : OS.conditionalString().onWindows({"zip"}).onUnix({"tar"}).supply(),
] ]
project.tasks.register('listSnippets', SnippetsTask) { project.tasks.register('listSnippets', SnippetsTask) {

View File

@ -193,35 +193,20 @@ class ClusterFormationTasks {
} }
return return
} }
// TEMP HACK distro = 'oss'
// The oss docs CI build overrides the distro on the command line. This hack handles backcompat until CI is updated.
if (distro.equals('oss-zip')) {
distro = 'oss'
}
if (distro.equals('zip')) {
distro = 'default'
}
// END TEMP HACK
if (['oss', 'default'].contains(distro) == false) {
throw new GradleException("Unknown distribution: ${distro} in project ${project.path}")
}
Version version = Version.fromString(elasticsearchVersion) Version version = Version.fromString(elasticsearchVersion)
String os = getOs() String os = getOs()
String classifier = "-${os}-x86_64" String classifier = "-${os}-x86_64"
String packaging = os.equals('windows') ? 'zip' : 'tar.gz' String packaging = os.equals('windows') ? 'zip' : 'tar.gz'
String artifactName = 'elasticsearch' String artifactName = 'elasticsearch-oss'
if (distro.equals('oss') && Version.fromString(elasticsearchVersion).onOrAfter('6.3.0')) {
artifactName += '-oss'
}
Object dependency Object dependency
String snapshotProject = "${os}-${os.equals('windows') ? 'zip' : 'tar'}" String snapshotProject = "${os}-${os.equals('windows') ? 'zip' : 'tar'}"
if (version.before("7.0.0")) { if (version.before("7.0.0")) {
snapshotProject = "zip" snapshotProject = "zip"
packaging = "zip" packaging = "zip"
} }
if (distro.equals("oss")) { snapshotProject = "oss-" + snapshotProject
snapshotProject = "oss-" + snapshotProject
}
BwcVersions.UnreleasedVersionInfo unreleasedInfo = null BwcVersions.UnreleasedVersionInfo unreleasedInfo = null

View File

@ -19,7 +19,6 @@
package org.elasticsearch.gradle; package org.elasticsearch.gradle;
import org.elasticsearch.gradle.ElasticsearchDistribution.Flavor;
import org.elasticsearch.gradle.ElasticsearchDistribution.Platform; import org.elasticsearch.gradle.ElasticsearchDistribution.Platform;
import org.elasticsearch.gradle.ElasticsearchDistribution.Type; import org.elasticsearch.gradle.ElasticsearchDistribution.Type;
import org.elasticsearch.gradle.docker.DockerSupportPlugin; import org.elasticsearch.gradle.docker.DockerSupportPlugin;
@ -38,7 +37,6 @@ import org.gradle.api.internal.artifacts.ArtifactAttributes;
import org.gradle.api.provider.Provider; import org.gradle.api.provider.Provider;
import java.util.Comparator; import java.util.Comparator;
import static org.elasticsearch.gradle.util.Util.capitalize;
/** /**
* A plugin to manage getting and extracting distributions of Elasticsearch. * A plugin to manage getting and extracting distributions of Elasticsearch.
@ -193,43 +191,8 @@ public class DistributionDownloadPlugin implements Plugin<Project> {
} else if (distribution.getType() == Type.RPM && distroVersion.before("7.0.0")) { } else if (distribution.getType() == Type.RPM && distroVersion.before("7.0.0")) {
classifier = ""; classifier = "";
} }
String flavor = "";
if (distribution.getFlavor() == Flavor.OSS && distroVersion.onOrAfter("6.3.0")) {
flavor = "-oss";
}
String group = distribution.getVersion().endsWith("-SNAPSHOT") ? FAKE_SNAPSHOT_IVY_GROUP : FAKE_IVY_GROUP; String group = distribution.getVersion().endsWith("-SNAPSHOT") ? FAKE_SNAPSHOT_IVY_GROUP : FAKE_IVY_GROUP;
return group + ":elasticsearch" + flavor + ":" + distribution.getVersion() + classifier + "@" + extension; return group + ":elasticsearch-oss" + ":" + distribution.getVersion() + classifier + "@" + extension;
}
private static String configName(String prefix, ElasticsearchDistribution distribution) {
return String.format(
"%s_%s_%s_%s%s%s",
prefix,
distribution.getVersion(),
distribution.getType(),
distribution.getPlatform() == null ? "" : distribution.getPlatform() + "_",
distribution.getFlavor(),
distribution.getBundledJdk() ? "" : "_nojdk"
);
}
private static String extractTaskName(ElasticsearchDistribution distribution) {
String taskName = "extractElasticsearch";
if (distribution.getType() != Type.INTEG_TEST_ZIP) {
if (distribution.getFlavor() == Flavor.OSS) {
taskName += "Oss";
}
if (distribution.getBundledJdk() == false) {
taskName += "NoJdk";
}
}
if (distribution.getType() == Type.ARCHIVE) {
taskName += capitalize(distribution.getPlatform().toString());
} else if (distribution.getType() != Type.INTEG_TEST_ZIP) {
taskName += capitalize(distribution.getType().toString());
}
taskName += distribution.getVersion();
return taskName;
} }
} }

View File

@ -23,9 +23,7 @@ package org.elasticsearch.gradle;
* This class models the different Docker base images that are used to build Docker distributions of Elasticsearch. * This class models the different Docker base images that are used to build Docker distributions of Elasticsearch.
*/ */
public enum DockerBase { public enum DockerBase {
CENTOS("centos:8"), CENTOS("centos:8");
// "latest" here is intentional, since the image name specifies "8"
UBI("docker.elastic.co/ubi8/ubi-minimal:latest");
private final String image; private final String image;

View File

@ -50,9 +50,7 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
ARCHIVE, ARCHIVE,
RPM, RPM,
DEB, DEB,
DOCKER, DOCKER;
// This is a different flavour of Docker image
DOCKER_UBI;
@Override @Override
public String toString() { public String toString() {
@ -63,7 +61,6 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
switch (this) { switch (this) {
case DEB: case DEB:
case DOCKER: case DOCKER:
case DOCKER_UBI:
case RPM: case RPM:
return false; return false;
@ -73,16 +70,6 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
} }
} }
public enum Flavor {
DEFAULT,
OSS;
@Override
public String toString() {
return super.toString().toLowerCase(Locale.ROOT);
}
}
// package private to tests can use // package private to tests can use
public static final Platform CURRENT_PLATFORM = OS.<Platform>conditional() public static final Platform CURRENT_PLATFORM = OS.<Platform>conditional()
.onLinux(() -> Platform.LINUX) .onLinux(() -> Platform.LINUX)
@ -99,7 +86,6 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
private final Property<String> version; private final Property<String> version;
private final Property<Type> type; private final Property<Type> type;
private final Property<Platform> platform; private final Property<Platform> platform;
private final Property<Flavor> flavor;
private final Property<Boolean> bundledJdk; private final Property<Boolean> bundledJdk;
private final Property<Boolean> failIfUnavailable; private final Property<Boolean> failIfUnavailable;
private final Configuration extracted; private final Configuration extracted;
@ -119,7 +105,6 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
this.type = objectFactory.property(Type.class); this.type = objectFactory.property(Type.class);
this.type.convention(Type.ARCHIVE); this.type.convention(Type.ARCHIVE);
this.platform = objectFactory.property(Platform.class); this.platform = objectFactory.property(Platform.class);
this.flavor = objectFactory.property(Flavor.class);
this.bundledJdk = objectFactory.property(Boolean.class); this.bundledJdk = objectFactory.property(Boolean.class);
this.failIfUnavailable = objectFactory.property(Boolean.class).convention(true); this.failIfUnavailable = objectFactory.property(Boolean.class).convention(true);
this.extracted = extractedConfiguration; this.extracted = extractedConfiguration;
@ -154,21 +139,13 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
this.type.set(type); this.type.set(type);
} }
public Flavor getFlavor() {
return flavor.getOrNull();
}
public void setFlavor(Flavor flavor) {
this.flavor.set(flavor);
}
public boolean getBundledJdk() { public boolean getBundledJdk() {
return bundledJdk.getOrElse(true); return bundledJdk.getOrElse(true);
} }
public boolean isDocker() { public boolean isDocker() {
final Type type = this.type.get(); final Type type = this.type.get();
return type == Type.DOCKER || type == Type.DOCKER_UBI; return type == Type.DOCKER;
} }
public void setBundledJdk(Boolean bundledJdk) { public void setBundledJdk(Boolean bundledJdk) {
@ -204,7 +181,6 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
switch (getType()) { switch (getType()) {
case DEB: case DEB:
case DOCKER: case DOCKER:
case DOCKER_UBI:
case RPM: case RPM:
throw new UnsupportedOperationException( throw new UnsupportedOperationException(
"distribution type [" + getType() + "] for " + "elasticsearch distribution [" + name + "] cannot be extracted" "distribution type [" + getType() + "] for " + "elasticsearch distribution [" + name + "] cannot be extracted"
@ -239,11 +215,7 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
"platform cannot be set on elasticsearch distribution [" + name + "] of type [integ_test_zip]" "platform cannot be set on elasticsearch distribution [" + name + "] of type [integ_test_zip]"
); );
} }
if (flavor.getOrNull() != null) {
throw new IllegalArgumentException(
"flavor [" + flavor.get() + "] not allowed for elasticsearch distribution [" + name + "] of type [integ_test_zip]"
);
}
if (bundledJdk.getOrNull() != null) { if (bundledJdk.getOrNull() != null) {
throw new IllegalArgumentException( throw new IllegalArgumentException(
"bundledJdk cannot be set on elasticsearch distribution [" + name + "] of type [integ_test_zip]" "bundledJdk cannot be set on elasticsearch distribution [" + name + "] of type [integ_test_zip]"
@ -275,15 +247,9 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
"bundledJdk cannot be set on elasticsearch distribution [" + name + "] of type " + "[docker]" "bundledJdk cannot be set on elasticsearch distribution [" + name + "] of type " + "[docker]"
); );
} }
if (flavor.get() == Flavor.OSS && type.get() == Type.DOCKER_UBI) {
throw new IllegalArgumentException("Cannot build a UBI docker image for the OSS distribution");
}
} }
} }
if (flavor.isPresent() == false) {
flavor.set(Flavor.DEFAULT);
}
if (bundledJdk.isPresent() == false) { if (bundledJdk.isPresent() == false) {
bundledJdk.set(true); bundledJdk.set(true);
} }
@ -291,7 +257,6 @@ public class ElasticsearchDistribution implements Buildable, Iterable<File> {
version.finalizeValue(); version.finalizeValue();
platform.finalizeValue(); platform.finalizeValue();
type.finalizeValue(); type.finalizeValue();
flavor.finalizeValue();
bundledJdk.finalizeValue(); bundledJdk.finalizeValue();
} }
} }

View File

@ -79,6 +79,7 @@ public class RepositoriesSetupPlugin implements Plugin<Project> {
throw new GradleException("Malformed lucene snapshot version: " + luceneVersion); throw new GradleException("Malformed lucene snapshot version: " + luceneVersion);
} }
String revision = matcher.group(1); String revision = matcher.group(1);
// TODO(cleanup) - Setup own lucene snapshot repo
MavenArtifactRepository luceneRepo = repos.maven(repo -> { MavenArtifactRepository luceneRepo = repos.maven(repo -> {
repo.setName("lucene-snapshots"); repo.setName("lucene-snapshots");
repo.setUrl("https://s3.amazonaws.com/download.elasticsearch.org/lucenesnapshots/" + revision); repo.setUrl("https://s3.amazonaws.com/download.elasticsearch.org/lucenesnapshots/" + revision);

View File

@ -108,7 +108,7 @@ public class InternalDistributionArchiveSetupPlugin implements Plugin<Project> {
project.getTasks().withType(AbstractArchiveTask.class).configureEach(t -> { project.getTasks().withType(AbstractArchiveTask.class).configureEach(t -> {
String subdir = archiveTaskToSubprojectName(t.getName()); String subdir = archiveTaskToSubprojectName(t.getName());
t.getDestinationDirectory().set(project.file(subdir + "/build/distributions")); t.getDestinationDirectory().set(project.file(subdir + "/build/distributions"));
t.getArchiveBaseName().set(subdir.contains("oss") ? "elasticsearch-oss" : "elasticsearch"); t.getArchiveBaseName().set("elasticsearch-oss");
}); });
} }

View File

@ -119,7 +119,7 @@ public class InternalDistributionBwcSetupPlugin implements Plugin<Project> {
private void registerDistributionArchiveArtifact(Project bwcProject, DistributionProject distributionProject, String buildBwcTask) { private void registerDistributionArchiveArtifact(Project bwcProject, DistributionProject distributionProject, String buildBwcTask) {
String artifactFileName = distributionProject.getDistFile().getName(); String artifactFileName = distributionProject.getDistFile().getName();
String artifactName = artifactFileName.contains("oss") ? "elasticsearch-oss" : "elasticsearch"; String artifactName = "elasticsearch-oss";
String suffix = artifactFileName.endsWith("tar.gz") ? "tar.gz" : artifactFileName.substring(artifactFileName.length() - 3); String suffix = artifactFileName.endsWith("tar.gz") ? "tar.gz" : artifactFileName.substring(artifactFileName.length() - 3);
int archIndex = artifactFileName.indexOf("x86_64"); int archIndex = artifactFileName.indexOf("x86_64");
@ -142,12 +142,12 @@ public class InternalDistributionBwcSetupPlugin implements Plugin<Project> {
private static List<DistributionProject> resolveArchiveProjects(File checkoutDir, Version bwcVersion) { private static List<DistributionProject> resolveArchiveProjects(File checkoutDir, Version bwcVersion) {
List<String> projects = new ArrayList<>(); List<String> projects = new ArrayList<>();
// All active BWC branches publish default and oss variants of rpm and deb packages // All active BWC branches publish default and oss variants of rpm and deb packages
projects.addAll(asList("deb", "rpm", "oss-deb", "oss-rpm")); projects.addAll(asList("oss-deb", "oss-rpm"));
if (bwcVersion.onOrAfter("7.0.0")) { // starting with 7.0 we bundle a jdk which means we have platform-specific archives if (bwcVersion.onOrAfter("7.0.0")) { // starting with 7.0 we bundle a jdk which means we have platform-specific archives
projects.addAll(asList("oss-windows-zip", "windows-zip", "oss-darwin-tar", "darwin-tar", "oss-linux-tar", "linux-tar")); projects.addAll(asList("oss-windows-zip", "oss-darwin-tar", "oss-linux-tar"));
} else { // prior to 7.0 we published only a single zip and tar archives for oss and default distributions } else { // prior to 7.0 we published only a single zip and tar archives for oss and default distributions
projects.addAll(asList("oss-zip", "zip", "tar", "oss-tar")); projects.addAll(asList("oss-zip", "oss-tar"));
} }
return projects.stream().map(name -> { return projects.stream().map(name -> {
@ -157,7 +157,7 @@ public class InternalDistributionBwcSetupPlugin implements Plugin<Project> {
if (bwcVersion.onOrAfter("7.0.0")) { if (bwcVersion.onOrAfter("7.0.0")) {
if (name.contains("zip") || name.contains("tar")) { if (name.contains("zip") || name.contains("tar")) {
int index = name.lastIndexOf('-'); int index = name.lastIndexOf('-');
String baseName = name.startsWith("oss-") ? name.substring(4, index) : name.substring(0, index); String baseName = name.substring(4, index); // oss-
classifier = "-" + baseName + "-x86_64"; classifier = "-" + baseName + "-x86_64";
extension = name.substring(index + 1); extension = name.substring(index + 1);
if (extension.equals("tar")) { if (extension.equals("tar")) {
@ -168,7 +168,7 @@ public class InternalDistributionBwcSetupPlugin implements Plugin<Project> {
} else if (name.contains("rpm")) { } else if (name.contains("rpm")) {
classifier = "-x86_64"; classifier = "-x86_64";
} }
} else if (name.contains("oss-")) { } else {
extension = name.substring(4); extension = name.substring(4);
} }
return new DistributionProject(name, baseDir, bwcVersion, classifier, extension, checkoutDir); return new DistributionProject(name, baseDir, bwcVersion, classifier, extension, checkoutDir);
@ -228,16 +228,7 @@ public class InternalDistributionBwcSetupPlugin implements Plugin<Project> {
this.projectPath = baseDir + "/" + name; this.projectPath = baseDir + "/" + name;
this.distFile = new File( this.distFile = new File(
checkoutDir, checkoutDir,
baseDir baseDir + "/" + name + "/build/distributions/elasticsearch-oss-" + version + "-SNAPSHOT" + classifier + "." + extension
+ "/"
+ name
+ "/build/distributions/elasticsearch-"
+ (name.startsWith("oss") ? "oss-" : "")
+ version
+ "-SNAPSHOT"
+ classifier
+ "."
+ extension
); );
// we only ported this down to the 7.x branch. // we only ported this down to the 7.x branch.
if (version.onOrAfter("7.10.0") && (name.endsWith("zip") || name.endsWith("tar"))) { if (version.onOrAfter("7.10.0") && (name.endsWith("zip") || name.endsWith("tar"))) {

View File

@ -127,7 +127,6 @@ public class InternalDistributionDownloadPlugin implements Plugin<Project> {
break; break;
case DOCKER: case DOCKER:
case DOCKER_UBI:
projectPath += ":docker:"; projectPath += ":docker:";
projectPath += distributionProjectName(distribution); projectPath += distributionProjectName(distribution);
break; break;
@ -155,9 +154,7 @@ public class InternalDistributionDownloadPlugin implements Plugin<Project> {
? "" ? ""
: "-" + architecture.toString().toLowerCase(); : "-" + architecture.toString().toLowerCase();
if (distribution.getFlavor() == ElasticsearchDistribution.Flavor.OSS) { projectName += "oss-";
projectName += "oss-";
}
if (distribution.getBundledJdk() == false) { if (distribution.getBundledJdk() == false) {
projectName += "no-jdk-"; projectName += "no-jdk-";
@ -169,7 +166,7 @@ public class InternalDistributionDownloadPlugin implements Plugin<Project> {
? "-zip" ? "-zip"
: "-tar"); : "-tar");
} else { } else {
projectName = distribution.getFlavor().equals(ElasticsearchDistribution.Flavor.DEFAULT) ? "zip" : "oss-zip"; projectName = "oss-zip";
} }
break; break;
@ -177,10 +174,6 @@ public class InternalDistributionDownloadPlugin implements Plugin<Project> {
projectName += "docker" + archString + "-export"; projectName += "docker" + archString + "-export";
break; break;
case DOCKER_UBI:
projectName += "ubi-docker" + archString + "-export";
break;
default: default:
projectName += distribution.getType(); projectName += distribution.getType();
break; break;

View File

@ -22,7 +22,6 @@ package org.elasticsearch.gradle.test;
import org.elasticsearch.gradle.Architecture; import org.elasticsearch.gradle.Architecture;
import org.elasticsearch.gradle.DistributionDownloadPlugin; import org.elasticsearch.gradle.DistributionDownloadPlugin;
import org.elasticsearch.gradle.ElasticsearchDistribution; import org.elasticsearch.gradle.ElasticsearchDistribution;
import org.elasticsearch.gradle.ElasticsearchDistribution.Flavor;
import org.elasticsearch.gradle.ElasticsearchDistribution.Platform; import org.elasticsearch.gradle.ElasticsearchDistribution.Platform;
import org.elasticsearch.gradle.ElasticsearchDistribution.Type; import org.elasticsearch.gradle.ElasticsearchDistribution.Type;
import org.elasticsearch.gradle.Jdk; import org.elasticsearch.gradle.Jdk;
@ -110,24 +109,28 @@ public class DistroTestPlugin implements Plugin<Project> {
TaskProvider<?> depsTask = project.getTasks().register(taskname + "#deps"); TaskProvider<?> depsTask = project.getTasks().register(taskname + "#deps");
depsTask.configure(t -> t.dependsOn(distribution, examplePlugin)); depsTask.configure(t -> t.dependsOn(distribution, examplePlugin));
depsTasks.put(taskname, depsTask); depsTasks.put(taskname, depsTask);
TaskProvider<Test> destructiveTask = configureTestTask(project, taskname, distribution, t -> { // TODO - suppressing failure temporarily where duplicate tasks are created for docker.
t.onlyIf(t2 -> distribution.isDocker() == false || dockerSupport.get().getDockerAvailability().isAvailable); try {
addSysprop(t, DISTRIBUTION_SYSPROP, distribution::getFilepath); TaskProvider<Test> destructiveTask = configureTestTask(project, taskname, distribution, t -> {
addSysprop(t, EXAMPLE_PLUGIN_SYSPROP, () -> examplePlugin.getSingleFile().toString()); t.onlyIf(t2 -> distribution.isDocker() == false || dockerSupport.get().getDockerAvailability().isAvailable);
t.exclude("**/PackageUpgradeTests.class"); addSysprop(t, DISTRIBUTION_SYSPROP, distribution::getFilepath);
}, depsTask); addSysprop(t, EXAMPLE_PLUGIN_SYSPROP, () -> examplePlugin.getSingleFile().toString());
t.exclude("**/PackageUpgradeTests.class");
if (distribution.getPlatform() == Platform.WINDOWS) { }, depsTask);
windowsTestTasks.add(destructiveTask); if (distribution.getPlatform() == Platform.WINDOWS) {
} else { windowsTestTasks.add(destructiveTask);
linuxTestTasks.computeIfAbsent(distribution.getType(), k -> new ArrayList<>()).add(destructiveTask); } else {
linuxTestTasks.computeIfAbsent(distribution.getType(), k -> new ArrayList<>()).add(destructiveTask);
}
destructiveDistroTest.configure(t -> t.dependsOn(destructiveTask));
lifecycleTasks.get(distribution.getType()).configure(t -> t.dependsOn(destructiveTask));
} catch (Exception ex) {
System.out.println(ex.getMessage());
} }
destructiveDistroTest.configure(t -> t.dependsOn(destructiveTask));
lifecycleTasks.get(distribution.getType()).configure(t -> t.dependsOn(destructiveTask));
if ((distribution.getType() == Type.DEB || distribution.getType() == Type.RPM) && distribution.getBundledJdk()) { if ((distribution.getType() == Type.DEB || distribution.getType() == Type.RPM) && distribution.getBundledJdk()) {
for (Version version : BuildParams.getBwcVersions().getIndexCompatible()) { for (Version version : BuildParams.getBwcVersions().getIndexCompatible()) {
if (distribution.getFlavor() == Flavor.OSS && version.before("6.3.0")) { if (version.before("6.3.0")) {
continue; // before opening xpack continue; // before opening xpack
} }
final ElasticsearchDistribution bwcDistro; final ElasticsearchDistribution bwcDistro;
@ -140,7 +143,6 @@ public class DistroTestPlugin implements Plugin<Project> {
distribution.getArchitecture(), distribution.getArchitecture(),
distribution.getType(), distribution.getType(),
distribution.getPlatform(), distribution.getPlatform(),
distribution.getFlavor(),
distribution.getBundledJdk(), distribution.getBundledJdk(),
version.toString() version.toString()
); );
@ -206,8 +208,7 @@ public class DistroTestPlugin implements Plugin<Project> {
// auto-detection doesn't work. // auto-detection doesn't work.
// //
// The shouldTestDocker property could be null, hence we use Boolean.TRUE.equals() // The shouldTestDocker property could be null, hence we use Boolean.TRUE.equals()
boolean shouldExecute = (type != Type.DOCKER && type != Type.DOCKER_UBI) boolean shouldExecute = (type != Type.DOCKER) || Boolean.TRUE.equals(vmProject.findProperty("shouldTestDocker"));
|| Boolean.TRUE.equals(vmProject.findProperty("shouldTestDocker"));
if (shouldExecute) { if (shouldExecute) {
distroTest.configure(t -> t.dependsOn(wrapperTask)); distroTest.configure(t -> t.dependsOn(wrapperTask));
@ -234,7 +235,6 @@ public class DistroTestPlugin implements Plugin<Project> {
Map<ElasticsearchDistribution.Type, TaskProvider<?>> lifecyleTasks = new HashMap<>(); Map<ElasticsearchDistribution.Type, TaskProvider<?>> lifecyleTasks = new HashMap<>();
lifecyleTasks.put(Type.DOCKER, project.getTasks().register(taskPrefix + ".docker")); lifecyleTasks.put(Type.DOCKER, project.getTasks().register(taskPrefix + ".docker"));
lifecyleTasks.put(Type.DOCKER_UBI, project.getTasks().register(taskPrefix + ".ubi"));
lifecyleTasks.put(Type.ARCHIVE, project.getTasks().register(taskPrefix + ".archives")); lifecyleTasks.put(Type.ARCHIVE, project.getTasks().register(taskPrefix + ".archives"));
lifecyleTasks.put(Type.DEB, project.getTasks().register(taskPrefix + ".packages")); lifecyleTasks.put(Type.DEB, project.getTasks().register(taskPrefix + ".packages"));
lifecyleTasks.put(Type.RPM, lifecyleTasks.get(Type.DEB)); lifecyleTasks.put(Type.RPM, lifecyleTasks.get(Type.DEB));
@ -363,55 +363,38 @@ public class DistroTestPlugin implements Plugin<Project> {
List<ElasticsearchDistribution> currentDistros = new ArrayList<>(); List<ElasticsearchDistribution> currentDistros = new ArrayList<>();
for (Architecture architecture : Architecture.values()) { for (Architecture architecture : Architecture.values()) {
for (Type type : Arrays.asList(Type.DEB, Type.RPM, Type.DOCKER, Type.DOCKER_UBI)) { for (Type type : Arrays.asList(Type.DEB, Type.RPM, Type.DOCKER)) {
for (Flavor flavor : Flavor.values()) { for (boolean bundledJdk : Arrays.asList(true, false)) {
for (boolean bundledJdk : Arrays.asList(true, false)) { if (bundledJdk == false) {
if (bundledJdk == false) { // We'll never publish an ARM (aarch64) build without a bundled JDK.
// We'll never publish an ARM (aarch64) build without a bundled JDK. if (architecture == Architecture.AARCH64) {
if (architecture == Architecture.AARCH64) { continue;
continue; }
} // All our Docker images include a bundled JDK so it doesn't make sense to test without one.
// All our Docker images include a bundled JDK so it doesn't make sense to test without one. if (type == Type.DOCKER) {
if (type == Type.DOCKER || type == Type.DOCKER_UBI) {
continue;
}
}
// We don't publish the OSS distribution on UBI
if (type == Type.DOCKER_UBI && flavor == Flavor.OSS) {
continue; continue;
} }
currentDistros.add(
createDistro(distributions, architecture, type, null, flavor, bundledJdk, VersionProperties.getElasticsearch())
);
} }
currentDistros.add(
createDistro(distributions, architecture, type, null, bundledJdk, VersionProperties.getElasticsearch())
);
} }
} }
} }
for (Architecture architecture : Architecture.values()) { for (Architecture architecture : Architecture.values()) {
for (Platform platform : Arrays.asList(Platform.LINUX, Platform.WINDOWS)) { for (Platform platform : Arrays.asList(Platform.LINUX, Platform.WINDOWS)) {
for (Flavor flavor : Flavor.values()) { for (boolean bundledJdk : Arrays.asList(true, false)) {
for (boolean bundledJdk : Arrays.asList(true, false)) { if (bundledJdk == false && architecture != Architecture.X64) {
if (bundledJdk == false && architecture != Architecture.X64) { // We will never publish distributions for non-x86 (amd64) platforms
// We will never publish distributions for non-x86 (amd64) platforms // without a bundled JDK
// without a bundled JDK continue;
continue;
}
currentDistros.add(
createDistro(
distributions,
architecture,
Type.ARCHIVE,
platform,
flavor,
bundledJdk,
VersionProperties.getElasticsearch()
)
);
} }
currentDistros.add(
createDistro(distributions, architecture, Type.ARCHIVE, platform, bundledJdk, VersionProperties.getElasticsearch())
);
} }
} }
} }
@ -424,15 +407,13 @@ public class DistroTestPlugin implements Plugin<Project> {
Architecture architecture, Architecture architecture,
Type type, Type type,
Platform platform, Platform platform,
Flavor flavor,
boolean bundledJdk, boolean bundledJdk,
String version String version
) { ) {
String name = distroId(type, platform, flavor, bundledJdk, architecture) + "-" + version; String name = distroId(type, platform, bundledJdk, architecture) + "-" + version;
boolean isDocker = type == Type.DOCKER || type == Type.DOCKER_UBI; boolean isDocker = type == Type.DOCKER;
ElasticsearchDistribution distro = distributions.create(name, d -> { ElasticsearchDistribution distro = distributions.create(name, d -> {
d.setArchitecture(architecture); d.setArchitecture(architecture);
d.setFlavor(flavor);
d.setType(type); d.setType(type);
if (type == Type.ARCHIVE) { if (type == Type.ARCHIVE) {
d.setPlatform(platform); d.setPlatform(platform);
@ -457,19 +438,15 @@ public class DistroTestPlugin implements Plugin<Project> {
return project.getName().contains("windows"); return project.getName().contains("windows");
} }
private static String distroId(Type type, Platform platform, Flavor flavor, boolean bundledJdk, Architecture architecture) { private static String distroId(Type type, Platform platform, boolean bundledJdk, Architecture architecture) {
return flavor return (type == Type.ARCHIVE ? platform + "-" : "") + type + (bundledJdk ? "" : "-no-jdk") + (architecture == Architecture.X64
+ "-" ? ""
+ (type == Type.ARCHIVE ? platform + "-" : "") : "-" + architecture.toString().toLowerCase());
+ type
+ (bundledJdk ? "" : "-no-jdk")
+ (architecture == Architecture.X64 ? "" : "-" + architecture.toString().toLowerCase());
} }
private static String destructiveDistroTestTaskName(ElasticsearchDistribution distro) { private static String destructiveDistroTestTaskName(ElasticsearchDistribution distro) {
Type type = distro.getType(); Type type = distro.getType();
return "destructiveDistroTest." return "destructiveDistroTest." + distroId(type, distro.getPlatform(), distro.getBundledJdk(), distro.getArchitecture());
+ distroId(type, distro.getPlatform(), distro.getFlavor(), distro.getBundledJdk(), distro.getArchitecture());
} }
private static String destructiveDistroUpgradeTestTaskName(ElasticsearchDistribution distro, String bwcVersion) { private static String destructiveDistroUpgradeTestTaskName(ElasticsearchDistribution distro, String bwcVersion) {
@ -477,7 +454,7 @@ public class DistroTestPlugin implements Plugin<Project> {
return "destructiveDistroUpgradeTest.v" return "destructiveDistroUpgradeTest.v"
+ bwcVersion + bwcVersion
+ "." + "."
+ distroId(type, distro.getPlatform(), distro.getFlavor(), distro.getBundledJdk(), distro.getArchitecture()); + distroId(type, distro.getPlatform(), distro.getBundledJdk(), distro.getArchitecture());
} }
private static void addSysprop(Test task, String sysprop, Supplier<String> valueSupplier) { private static void addSysprop(Test task, String sysprop, Supplier<String> valueSupplier) {

View File

@ -267,16 +267,10 @@ public class ElasticsearchNode implements TestClusterConfiguration {
if (testDistribution == TestDistribution.INTEG_TEST) { if (testDistribution == TestDistribution.INTEG_TEST) {
distribution.setType(ElasticsearchDistribution.Type.INTEG_TEST_ZIP); distribution.setType(ElasticsearchDistribution.Type.INTEG_TEST_ZIP);
// we change the underlying distribution when changing the test distribution of the cluster. // we change the underlying distribution when changing the test distribution of the cluster.
distribution.setFlavor(null);
distribution.setPlatform(null); distribution.setPlatform(null);
distribution.setBundledJdk(null); distribution.setBundledJdk(null);
} else { } else {
distribution.setType(ElasticsearchDistribution.Type.ARCHIVE); distribution.setType(ElasticsearchDistribution.Type.ARCHIVE);
if (testDistribution == TestDistribution.DEFAULT) {
distribution.setFlavor(ElasticsearchDistribution.Flavor.DEFAULT);
} else {
distribution.setFlavor(ElasticsearchDistribution.Flavor.OSS);
}
} }
} }

View File

@ -19,7 +19,6 @@
package org.elasticsearch.gradle; package org.elasticsearch.gradle;
import org.elasticsearch.gradle.ElasticsearchDistribution.Flavor;
import org.elasticsearch.gradle.ElasticsearchDistribution.Platform; import org.elasticsearch.gradle.ElasticsearchDistribution.Platform;
import org.elasticsearch.gradle.ElasticsearchDistribution.Type; import org.elasticsearch.gradle.ElasticsearchDistribution.Type;
import org.elasticsearch.gradle.info.BuildParams; import org.elasticsearch.gradle.info.BuildParams;
@ -63,15 +62,7 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
); );
public void testVersionDefault() { public void testVersionDefault() {
ElasticsearchDistribution distro = checkDistro( ElasticsearchDistribution distro = checkDistro(createProject(null, false), "testdistro", null, Type.ARCHIVE, Platform.LINUX, true);
createProject(null, false),
"testdistro",
null,
Type.ARCHIVE,
Platform.LINUX,
Flavor.OSS,
true
);
assertEquals(distro.getVersion(), VersionProperties.getElasticsearch()); assertEquals(distro.getVersion(), VersionProperties.getElasticsearch());
} }
@ -82,35 +73,18 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
"badversion", "badversion",
Type.ARCHIVE, Type.ARCHIVE,
Platform.LINUX, Platform.LINUX,
Flavor.OSS,
true, true,
"Invalid version format: 'badversion'" "Invalid version format: 'badversion'"
); );
} }
public void testTypeDefault() { public void testTypeDefault() {
ElasticsearchDistribution distro = checkDistro( ElasticsearchDistribution distro = checkDistro(createProject(null, false), "testdistro", "5.0.0", null, Platform.LINUX, true);
createProject(null, false),
"testdistro",
"5.0.0",
null,
Platform.LINUX,
Flavor.OSS,
true
);
assertEquals(distro.getType(), Type.ARCHIVE); assertEquals(distro.getType(), Type.ARCHIVE);
} }
public void testPlatformDefault() { public void testPlatformDefault() {
ElasticsearchDistribution distro = checkDistro( ElasticsearchDistribution distro = checkDistro(createProject(null, false), "testdistro", "5.0.0", Type.ARCHIVE, null, true);
createProject(null, false),
"testdistro",
"5.0.0",
Type.ARCHIVE,
null,
Flavor.OSS,
true
);
assertEquals(distro.getPlatform(), ElasticsearchDistribution.CURRENT_PLATFORM); assertEquals(distro.getPlatform(), ElasticsearchDistribution.CURRENT_PLATFORM);
} }
@ -122,37 +96,10 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
Type.INTEG_TEST_ZIP, Type.INTEG_TEST_ZIP,
Platform.LINUX, Platform.LINUX,
null, null,
null,
"platform cannot be set on elasticsearch distribution [testdistro]" "platform cannot be set on elasticsearch distribution [testdistro]"
); );
} }
public void testFlavorDefault() {
ElasticsearchDistribution distro = checkDistro(
createProject(null, false),
"testdistro",
"5.0.0",
Type.ARCHIVE,
Platform.LINUX,
null,
true
);
assertEquals(distro.getFlavor(), Flavor.DEFAULT);
}
public void testFlavorForIntegTest() {
assertDistroError(
createProject(null, false),
"testdistro",
"5.0.0",
Type.INTEG_TEST_ZIP,
null,
Flavor.OSS,
null,
"flavor [oss] not allowed for elasticsearch distribution [testdistro] of type [integ_test_zip]"
);
}
public void testBundledJdkDefault() { public void testBundledJdkDefault() {
ElasticsearchDistribution distro = checkDistro( ElasticsearchDistribution distro = checkDistro(
createProject(null, false), createProject(null, false),
@ -160,7 +107,6 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
"5.0.0", "5.0.0",
Type.ARCHIVE, Type.ARCHIVE,
Platform.LINUX, Platform.LINUX,
null,
true true
); );
assertTrue(distro.getBundledJdk()); assertTrue(distro.getBundledJdk());
@ -173,7 +119,6 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
"5.0.0", "5.0.0",
Type.INTEG_TEST_ZIP, Type.INTEG_TEST_ZIP,
null, null,
null,
true, true,
"bundledJdk cannot be set on elasticsearch distribution [testdistro]" "bundledJdk cannot be set on elasticsearch distribution [testdistro]"
); );
@ -184,70 +129,62 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
Project archiveProject = ProjectBuilder.builder().withParent(archivesProject).withName("integ-test-zip").build(); Project archiveProject = ProjectBuilder.builder().withParent(archivesProject).withName("integ-test-zip").build();
archiveProject.getConfigurations().create("default"); archiveProject.getConfigurations().create("default");
archiveProject.getArtifacts().add("default", new File("doesnotmatter")); archiveProject.getArtifacts().add("default", new File("doesnotmatter"));
createDistro(project, "distro", VersionProperties.getElasticsearch(), Type.INTEG_TEST_ZIP, null, null, null); createDistro(project, "distro", VersionProperties.getElasticsearch(), Type.INTEG_TEST_ZIP, null, null);
checkPlugin(project); checkPlugin(project);
} }
public void testLocalCurrentVersionArchives() { public void testLocalCurrentVersionArchives() {
for (Platform platform : Platform.values()) { for (Platform platform : Platform.values()) {
for (Flavor flavor : Flavor.values()) { for (boolean bundledJdk : new boolean[] { true, false }) {
for (boolean bundledJdk : new boolean[] { true, false }) { // create a new project in each iteration, so that we know we are resolving the only additional project being created
// create a new project in each iteration, so that we know we are resolving the only additional project being created Project project = createProject(BWC_MINOR, true);
Project project = createProject(BWC_MINOR, true); String projectName = projectName(platform.toString(), bundledJdk);
String projectName = projectName(platform.toString(), flavor, bundledJdk); projectName += (platform == Platform.WINDOWS ? "-zip" : "-tar");
projectName += (platform == Platform.WINDOWS ? "-zip" : "-tar"); Project archiveProject = ProjectBuilder.builder().withParent(archivesProject).withName(projectName).build();
Project archiveProject = ProjectBuilder.builder().withParent(archivesProject).withName(projectName).build(); archiveProject.getConfigurations().create("default");
archiveProject.getConfigurations().create("default"); archiveProject.getArtifacts().add("default", new File("doesnotmatter"));
archiveProject.getArtifacts().add("default", new File("doesnotmatter")); createDistro(project, "distro", VersionProperties.getElasticsearch(), Type.ARCHIVE, platform, bundledJdk);
createDistro(project, "distro", VersionProperties.getElasticsearch(), Type.ARCHIVE, platform, flavor, bundledJdk); checkPlugin(project);
checkPlugin(project);
}
} }
} }
} }
public void testLocalCurrentVersionPackages() { public void testLocalCurrentVersionPackages() {
for (Type packageType : new Type[] { Type.RPM, Type.DEB }) { for (Type packageType : new Type[] { Type.RPM, Type.DEB }) {
for (Flavor flavor : Flavor.values()) { for (boolean bundledJdk : new boolean[] { true, false }) {
for (boolean bundledJdk : new boolean[] { true, false }) { Project project = createProject(BWC_MINOR, true);
Project project = createProject(BWC_MINOR, true); String projectName = projectName(packageType.toString(), bundledJdk);
String projectName = projectName(packageType.toString(), flavor, bundledJdk); Project packageProject = ProjectBuilder.builder().withParent(packagesProject).withName(projectName).build();
Project packageProject = ProjectBuilder.builder().withParent(packagesProject).withName(projectName).build(); packageProject.getConfigurations().create("default");
packageProject.getConfigurations().create("default"); packageProject.getArtifacts().add("default", new File("doesnotmatter"));
packageProject.getArtifacts().add("default", new File("doesnotmatter")); createDistro(project, "distro", VersionProperties.getElasticsearch(), packageType, null, bundledJdk);
createDistro(project, "distro", VersionProperties.getElasticsearch(), packageType, null, flavor, bundledJdk); checkPlugin(project);
checkPlugin(project);
}
} }
} }
} }
public void testLocalBwcArchives() { public void testLocalBwcArchives() {
for (Platform platform : Platform.values()) { for (Platform platform : Platform.values()) {
for (Flavor flavor : Flavor.values()) { // note: no non bundled jdk for bwc
// note: no non bundled jdk for bwc String configName = projectName(platform.toString(), true);
String configName = projectName(platform.toString(), flavor, true); configName += (platform == Platform.WINDOWS ? "-zip" : "-tar");
configName += (platform == Platform.WINDOWS ? "-zip" : "-tar");
checkBwc("minor", configName, BWC_MINOR_VERSION, Type.ARCHIVE, platform, flavor, BWC_MINOR, true); checkBwc("minor", configName, BWC_MINOR_VERSION, Type.ARCHIVE, platform, BWC_MINOR, true);
checkBwc("staged", configName, BWC_STAGED_VERSION, Type.ARCHIVE, platform, flavor, BWC_STAGED, true); checkBwc("staged", configName, BWC_STAGED_VERSION, Type.ARCHIVE, platform, BWC_STAGED, true);
checkBwc("bugfix", configName, BWC_BUGFIX_VERSION, Type.ARCHIVE, platform, flavor, BWC_BUGFIX, true); checkBwc("bugfix", configName, BWC_BUGFIX_VERSION, Type.ARCHIVE, platform, BWC_BUGFIX, true);
checkBwc("maintenance", configName, BWC_MAINTENANCE_VERSION, Type.ARCHIVE, platform, flavor, BWC_MAINTENANCE, true); checkBwc("maintenance", configName, BWC_MAINTENANCE_VERSION, Type.ARCHIVE, platform, BWC_MAINTENANCE, true);
}
} }
} }
public void testLocalBwcPackages() { public void testLocalBwcPackages() {
for (Type packageType : new Type[] { Type.RPM, Type.DEB }) { for (Type packageType : new Type[] { Type.RPM, Type.DEB }) {
for (Flavor flavor : Flavor.values()) { // note: no non bundled jdk for bwc
// note: no non bundled jdk for bwc String configName = projectName(packageType.toString(), true);
String configName = projectName(packageType.toString(), flavor, true);
checkBwc("minor", configName, BWC_MINOR_VERSION, packageType, null, flavor, BWC_MINOR, true); checkBwc("minor", configName, BWC_MINOR_VERSION, packageType, null, BWC_MINOR, true);
checkBwc("staged", configName, BWC_STAGED_VERSION, packageType, null, flavor, BWC_STAGED, true); checkBwc("staged", configName, BWC_STAGED_VERSION, packageType, null, BWC_STAGED, true);
checkBwc("bugfix", configName, BWC_BUGFIX_VERSION, packageType, null, flavor, BWC_BUGFIX, true); checkBwc("bugfix", configName, BWC_BUGFIX_VERSION, packageType, null, BWC_BUGFIX, true);
checkBwc("maintenance", configName, BWC_MAINTENANCE_VERSION, packageType, null, flavor, BWC_MAINTENANCE, true); checkBwc("maintenance", configName, BWC_MAINTENANCE_VERSION, packageType, null, BWC_MAINTENANCE, true);
}
} }
} }
@ -257,13 +194,12 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
String version, String version,
Type type, Type type,
Platform platform, Platform platform,
Flavor flavor,
Boolean bundledJdk, Boolean bundledJdk,
String message String message
) { ) {
IllegalArgumentException e = expectThrows( IllegalArgumentException e = expectThrows(
IllegalArgumentException.class, IllegalArgumentException.class,
() -> checkDistro(project, name, version, type, platform, flavor, bundledJdk) () -> checkDistro(project, name, version, type, platform, bundledJdk)
); );
assertThat(e.getMessage(), containsString(message)); assertThat(e.getMessage(), containsString(message));
} }
@ -274,7 +210,6 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
String version, String version,
Type type, Type type,
Platform platform, Platform platform,
Flavor flavor,
Boolean bundledJdk Boolean bundledJdk
) { ) {
NamedDomainObjectContainer<ElasticsearchDistribution> distros = DistributionDownloadPlugin.getContainer(project); NamedDomainObjectContainer<ElasticsearchDistribution> distros = DistributionDownloadPlugin.getContainer(project);
@ -288,9 +223,6 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
if (platform != null) { if (platform != null) {
distro.setPlatform(platform); distro.setPlatform(platform);
} }
if (flavor != null) {
distro.setFlavor(flavor);
}
if (bundledJdk != null) { if (bundledJdk != null) {
distro.setBundledJdk(bundledJdk); distro.setBundledJdk(bundledJdk);
} }
@ -304,10 +236,9 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
String version, String version,
Type type, Type type,
Platform platform, Platform platform,
Flavor flavor,
Boolean bundledJdk Boolean bundledJdk
) { ) {
ElasticsearchDistribution distribution = createDistro(project, name, version, type, platform, flavor, bundledJdk); ElasticsearchDistribution distribution = createDistro(project, name, version, type, platform, bundledJdk);
distribution.finalizeValues(); distribution.finalizeValues();
return distribution; return distribution;
} }
@ -324,7 +255,6 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
Version version, Version version,
Type type, Type type,
Platform platform, Platform platform,
Flavor flavor,
BwcVersions bwcVersions, BwcVersions bwcVersions,
boolean isInternal boolean isInternal
) { ) {
@ -332,7 +262,7 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
Project archiveProject = ProjectBuilder.builder().withParent(bwcProject).withName(projectName).build(); Project archiveProject = ProjectBuilder.builder().withParent(bwcProject).withName(projectName).build();
archiveProject.getConfigurations().create(config); archiveProject.getConfigurations().create(config);
archiveProject.getArtifacts().add(config, new File("doesnotmatter")); archiveProject.getArtifacts().add(config, new File("doesnotmatter"));
createDistro(project, "distro", version.toString(), type, platform, flavor, true); createDistro(project, "distro", version.toString(), type, platform, true);
checkPlugin(project); checkPlugin(project);
} }
@ -351,11 +281,8 @@ public class DistributionDownloadPluginTests extends GradleUnitTestCase {
return project; return project;
} }
private static String projectName(String base, Flavor flavor, boolean bundledJdk) { private static String projectName(String base, boolean bundledJdk) {
String prefix = ""; String prefix = "oss-";
if (flavor == Flavor.OSS) {
prefix += "oss-";
}
if (bundledJdk == false) { if (bundledJdk == false) {
prefix += "no-jdk-"; prefix += "no-jdk-";
} }

View File

@ -102,14 +102,13 @@ public class MainResponse {
private static final ConstructingObjectParser<Version, Void> PARSER = private static final ConstructingObjectParser<Version, Void> PARSER =
new ConstructingObjectParser<>(Version.class.getName(), true, new ConstructingObjectParser<>(Version.class.getName(), true,
args -> { args -> {
return new Version((String) args[0], (String) args[1], (String) args[2], (String) args[3], (String) args[4], return new Version((String) args[0], (String) args[1], (String) args[2], (String) args[3],
(Boolean) args[5], (String) args[6], (String) args[7], (String) args[8]); (Boolean) args[4], (String) args[5], (String) args[6], (String) args[7]);
} }
); );
static { static {
PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("number")); PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("number"));
PARSER.declareString(ConstructingObjectParser.optionalConstructorArg(), new ParseField("build_flavor"));
PARSER.declareString(ConstructingObjectParser.optionalConstructorArg(), new ParseField("build_type")); PARSER.declareString(ConstructingObjectParser.optionalConstructorArg(), new ParseField("build_type"));
PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("build_hash")); PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("build_hash"));
PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("build_date")); PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("build_date"));
@ -118,8 +117,8 @@ public class MainResponse {
PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("minimum_wire_compatibility_version")); PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("minimum_wire_compatibility_version"));
PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("minimum_index_compatibility_version")); PARSER.declareString(ConstructingObjectParser.constructorArg(), new ParseField("minimum_index_compatibility_version"));
} }
private final String number; private final String number;
private final String buildFlavor;
private final String buildType; private final String buildType;
private final String buildHash; private final String buildHash;
private final String buildDate; private final String buildDate;
@ -128,10 +127,9 @@ public class MainResponse {
private final String minimumWireCompatibilityVersion; private final String minimumWireCompatibilityVersion;
private final String minimumIndexCompatibilityVersion; private final String minimumIndexCompatibilityVersion;
public Version(String number, String buildFlavor, String buildType, String buildHash, String buildDate, boolean isSnapshot, public Version(String number, String buildType, String buildHash, String buildDate, boolean isSnapshot,
String luceneVersion, String minimumWireCompatibilityVersion, String minimumIndexCompatibilityVersion) { String luceneVersion, String minimumWireCompatibilityVersion, String minimumIndexCompatibilityVersion) {
this.number = number; this.number = number;
this.buildFlavor = buildFlavor;
this.buildType = buildType; this.buildType = buildType;
this.buildHash = buildHash; this.buildHash = buildHash;
this.buildDate = buildDate; this.buildDate = buildDate;
@ -145,10 +143,6 @@ public class MainResponse {
return number; return number;
} }
public String getBuildFlavor() {
return buildFlavor;
}
public String getBuildType() { public String getBuildType() {
return buildType; return buildType;
} }
@ -184,7 +178,6 @@ public class MainResponse {
Version version = (Version) o; Version version = (Version) o;
return isSnapshot == version.isSnapshot && return isSnapshot == version.isSnapshot &&
number.equals(version.number) && number.equals(version.number) &&
Objects.equals(buildFlavor, version.buildFlavor) &&
Objects.equals(buildType, version.buildType) && Objects.equals(buildType, version.buildType) &&
buildHash.equals(version.buildHash) && buildHash.equals(version.buildHash) &&
buildDate.equals(version.buildDate) && buildDate.equals(version.buildDate) &&
@ -195,7 +188,7 @@ public class MainResponse {
@Override @Override
public int hashCode() { public int hashCode() {
return Objects.hash(number, buildFlavor, buildType, buildHash, buildDate, isSnapshot, luceneVersion, return Objects.hash(number, buildType, buildHash, buildDate, isSnapshot, luceneVersion,
minimumWireCompatibilityVersion, minimumIndexCompatibilityVersion); minimumWireCompatibilityVersion, minimumIndexCompatibilityVersion);
} }
} }

View File

@ -42,7 +42,6 @@ public class PingAndInfoIT extends ESRestHighLevelClientTestCase {
assertNotNull(info.getNodeName()); assertNotNull(info.getNodeName());
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
Map<String, Object> versionMap = (Map<String, Object>) infoAsMap.get("version"); Map<String, Object> versionMap = (Map<String, Object>) infoAsMap.get("version");
assertEquals(versionMap.get("build_flavor"), info.getVersion().getBuildFlavor());
assertEquals(versionMap.get("build_type"), info.getVersion().getBuildType()); assertEquals(versionMap.get("build_type"), info.getVersion().getBuildType());
assertEquals(versionMap.get("build_hash"), info.getVersion().getBuildHash()); assertEquals(versionMap.get("build_hash"), info.getVersion().getBuildHash());
assertEquals(versionMap.get("build_date"), info.getVersion().getBuildDate()); assertEquals(versionMap.get("build_date"), info.getVersion().getBuildDate());

View File

@ -165,7 +165,7 @@ public class RestHighLevelClientTests extends ESTestCase {
} }
public void testInfo() throws IOException { public void testInfo() throws IOException {
MainResponse testInfo = new MainResponse("nodeName", new MainResponse.Version("number", "buildFlavor", "buildType", "buildHash", MainResponse testInfo = new MainResponse("nodeName", new MainResponse.Version("number", "buildType", "buildHash",
"buildDate", true, "luceneVersion", "minimumWireCompatibilityVersion", "minimumIndexCompatibilityVersion"), "buildDate", true, "luceneVersion", "minimumWireCompatibilityVersion", "minimumIndexCompatibilityVersion"),
"clusterName", "clusterUuid", "You Know, for Search"); "clusterName", "clusterUuid", "You Know, for Search");
mockResponse((ToXContentFragment) (builder, params) -> { mockResponse((ToXContentFragment) (builder, params) -> {
@ -175,7 +175,6 @@ public class RestHighLevelClientTests extends ESTestCase {
builder.field("cluster_uuid", testInfo.getClusterUuid()); builder.field("cluster_uuid", testInfo.getClusterUuid());
builder.startObject("version") builder.startObject("version")
.field("number", testInfo.getVersion().getNumber()) .field("number", testInfo.getVersion().getNumber())
.field("build_flavor", testInfo.getVersion().getBuildFlavor())
.field("build_type", testInfo.getVersion().getBuildType()) .field("build_type", testInfo.getVersion().getBuildType())
.field("build_hash", testInfo.getVersion().getBuildHash()) .field("build_hash", testInfo.getVersion().getBuildHash())
.field("build_date", testInfo.getVersion().getBuildDate()) .field("build_date", testInfo.getVersion().getBuildDate())

View File

@ -41,7 +41,7 @@ public class MainResponseTests extends AbstractResponseTestCase<org.elasticsearc
final String date = new Date(randomNonNegativeLong()).toString(); final String date = new Date(randomNonNegativeLong()).toString();
Version version = VersionUtils.randomVersionBetween(random(), Version.V_6_0_1, Version.CURRENT); Version version = VersionUtils.randomVersionBetween(random(), Version.V_6_0_1, Version.CURRENT);
Build build = new Build( Build build = new Build(
Build.Flavor.UNKNOWN, Build.Type.UNKNOWN, randomAlphaOfLength(8), date, randomBoolean(), Build.Type.UNKNOWN, randomAlphaOfLength(8), date, randomBoolean(),
version.toString() version.toString()
); );
return new org.elasticsearch.action.main.MainResponse(nodeName, version, clusterName, clusterUuid , build); return new org.elasticsearch.action.main.MainResponse(nodeName, version, clusterName, clusterUuid , build);
@ -62,7 +62,6 @@ public class MainResponseTests extends AbstractResponseTestCase<org.elasticsearc
assertThat(serverTestInstance.getBuild().hash(), equalTo(clientInstance.getVersion().getBuildHash())); assertThat(serverTestInstance.getBuild().hash(), equalTo(clientInstance.getVersion().getBuildHash()));
assertThat(serverTestInstance.getVersion().toString(), equalTo(clientInstance.getVersion().getNumber())); assertThat(serverTestInstance.getVersion().toString(), equalTo(clientInstance.getVersion().getNumber()));
assertThat(serverTestInstance.getBuild().date(), equalTo(clientInstance.getVersion().getBuildDate())); assertThat(serverTestInstance.getBuild().date(), equalTo(clientInstance.getVersion().getBuildDate()));
assertThat(serverTestInstance.getBuild().flavor().displayName(), equalTo(clientInstance.getVersion().getBuildFlavor()));
assertThat(serverTestInstance.getBuild().type().displayName(), equalTo(clientInstance.getVersion().getBuildType())); assertThat(serverTestInstance.getBuild().type().displayName(), equalTo(clientInstance.getVersion().getBuildType()));
assertThat(serverTestInstance.getVersion().luceneVersion.toString(), equalTo(clientInstance.getVersion().getLuceneVersion())); assertThat(serverTestInstance.getVersion().luceneVersion.toString(), equalTo(clientInstance.getVersion().getLuceneVersion()));
assertThat(serverTestInstance.getVersion().minimumIndexCompatibilityVersion().toString(), assertThat(serverTestInstance.getVersion().minimumIndexCompatibilityVersion().toString(),

View File

@ -46,7 +46,6 @@ public class MiscellaneousDocumentationIT extends ESRestHighLevelClientTestCase
String nodeName = response.getNodeName(); String nodeName = response.getNodeName();
MainResponse.Version version = response.getVersion(); MainResponse.Version version = response.getVersion();
String buildDate = version.getBuildDate(); String buildDate = version.getBuildDate();
String buildFlavor = version.getBuildFlavor();
String buildHash = version.getBuildHash(); String buildHash = version.getBuildHash();
String buildType = version.getBuildType(); String buildType = version.getBuildType();
String luceneVersion = version.getLuceneVersion(); String luceneVersion = version.getLuceneVersion();
@ -59,7 +58,6 @@ public class MiscellaneousDocumentationIT extends ESRestHighLevelClientTestCase
assertNotNull(nodeName); assertNotNull(nodeName);
assertNotNull(version); assertNotNull(version);
assertNotNull(buildDate); assertNotNull(buildDate);
assertNotNull(buildFlavor);
assertNotNull(buildHash); assertNotNull(buildHash);
assertNotNull(buildType); assertNotNull(buildType);
assertNotNull(luceneVersion); assertNotNull(luceneVersion);

View File

@ -17,28 +17,25 @@
* under the License. * under the License.
*/ */
import java.nio.file.Files
import java.nio.file.Path
apply plugin: 'elasticsearch.internal-distribution-archive-setup' apply plugin: 'elasticsearch.internal-distribution-archive-setup'
CopySpec archiveFiles(CopySpec modulesFiles, String distributionType, String platform, String architecture, boolean oss, boolean jdk) { CopySpec archiveFiles(CopySpec modulesFiles, String distributionType, String platform, String architecture, boolean jdk) {
return copySpec { return copySpec {
into("elasticsearch-${version}") { into("elasticsearch-${version}") {
into('lib') { into('lib') {
with libFiles(oss) with libFiles()
} }
into('config') { into('config') {
dirMode 0750 dirMode 0750
fileMode 0660 fileMode 0660
with configFiles(distributionType, oss, jdk) with configFiles(distributionType, jdk)
from { from {
dirMode 0750 dirMode 0750
jvmOptionsDir.getParent() jvmOptionsDir.getParent()
} }
} }
into('bin') { into('bin') {
with binFiles(distributionType, oss, jdk) with binFiles(distributionType, jdk)
} }
if (jdk) { if (jdk) {
into("darwin".equals(platform) ? 'jdk.app' : 'jdk') { into("darwin".equals(platform) ? 'jdk.app' : 'jdk') {
@ -65,7 +62,7 @@ CopySpec archiveFiles(CopySpec modulesFiles, String distributionType, String pla
rename { 'LICENSE.txt' } rename { 'LICENSE.txt' }
} }
with noticeFile(oss, jdk) with noticeFile(jdk)
into('modules') { into('modules') {
with modulesFiles with modulesFiles
} }
@ -76,105 +73,56 @@ CopySpec archiveFiles(CopySpec modulesFiles, String distributionType, String pla
distribution_archives { distribution_archives {
integTestZip { integTestZip {
content { content {
archiveFiles(transportModulesFiles, 'zip', null, 'x64', true, false) archiveFiles(transportModulesFiles, 'zip', null, 'x64', false)
}
}
windowsZip {
archiveClassifier = 'windows-x86_64'
content {
archiveFiles(modulesFiles(false, 'windows-x86_64'), 'zip', 'windows', 'x64', false, true)
} }
} }
ossWindowsZip { ossWindowsZip {
archiveClassifier = 'windows-x86_64' archiveClassifier = 'windows-x86_64'
content { content {
archiveFiles(modulesFiles(true, 'windows-x86_64'), 'zip', 'windows', 'x64', true, true) archiveFiles(modulesFiles('windows-x86_64'), 'zip', 'windows', 'x64', true)
}
}
noJdkWindowsZip {
archiveClassifier = 'no-jdk-windows-x86_64'
content {
archiveFiles(modulesFiles(false, 'windows-x86_64'), 'zip', 'windows', 'x64', false, false)
} }
} }
ossNoJdkWindowsZip { ossNoJdkWindowsZip {
archiveClassifier = 'no-jdk-windows-x86_64' archiveClassifier = 'no-jdk-windows-x86_64'
content { content {
archiveFiles(modulesFiles(true, 'windows-x86_64'), 'zip', 'windows', 'x64', true, false) archiveFiles(modulesFiles('windows-x86_64'), 'zip', 'windows', 'x64', false)
}
}
darwinTar {
archiveClassifier = 'darwin-x86_64'
content {
archiveFiles(modulesFiles(false, 'darwin-x86_64'), 'tar', 'darwin', 'x64', false, true)
} }
} }
ossDarwinTar { ossDarwinTar {
archiveClassifier = 'darwin-x86_64' archiveClassifier = 'darwin-x86_64'
content { content {
archiveFiles(modulesFiles(true, 'darwin-x86_64'), 'tar', 'darwin', 'x64', true, true) archiveFiles(modulesFiles('darwin-x86_64'), 'tar', 'darwin', 'x64', true)
}
}
noJdkDarwinTar {
archiveClassifier = 'no-jdk-darwin-x86_64'
content {
archiveFiles(modulesFiles(false, 'darwin-x86_64'), 'tar', 'darwin', 'x64', false, false)
} }
} }
ossNoJdkDarwinTar { ossNoJdkDarwinTar {
archiveClassifier = 'no-jdk-darwin-x86_64' archiveClassifier = 'no-jdk-darwin-x86_64'
content { content {
archiveFiles(modulesFiles(true, 'darwin-x86_64'), 'tar', 'darwin', 'x64', true, false) archiveFiles(modulesFiles('darwin-x86_64'), 'tar', 'darwin', 'x64', false)
}
}
linuxAarch64Tar {
archiveClassifier = 'linux-aarch64'
content {
archiveFiles(modulesFiles(false, 'linux-aarch64'), 'tar', 'linux', 'aarch64', false, true)
}
}
linuxTar {
archiveClassifier = 'linux-x86_64'
content {
archiveFiles(modulesFiles(false, 'linux-x86_64'), 'tar', 'linux', 'x64', false, true)
} }
} }
ossLinuxAarch64Tar { ossLinuxAarch64Tar {
archiveClassifier = 'linux-aarch64' archiveClassifier = 'linux-aarch64'
content { content {
archiveFiles(modulesFiles(true, 'linux-aarch64'), 'tar', 'linux', 'aarch64', true, true) archiveFiles(modulesFiles('linux-aarch64'), 'tar', 'linux', 'aarch64', true)
} }
} }
ossLinuxTar { ossLinuxTar {
archiveClassifier = 'linux-x86_64' archiveClassifier = 'linux-x86_64'
content { content {
archiveFiles(modulesFiles(true, 'linux-x86_64'), 'tar', 'linux', 'x64', true, true) archiveFiles(modulesFiles('linux-x86_64'), 'tar', 'linux', 'x64', true)
}
}
noJdkLinuxTar {
archiveClassifier = 'no-jdk-linux-x86_64'
content {
archiveFiles(modulesFiles(false, 'linux-x86_64'), 'tar', 'linux', 'x64', false, false)
} }
} }
ossNoJdkLinuxTar { ossNoJdkLinuxTar {
archiveClassifier = 'no-jdk-linux-x86_64' archiveClassifier = 'no-jdk-linux-x86_64'
content { content {
archiveFiles(modulesFiles(true, 'linux-x86_64'), 'tar', 'linux', 'x64', true, false) archiveFiles(modulesFiles('linux-x86_64'), 'tar', 'linux', 'x64', false)
} }
} }
} }
@ -183,5 +131,5 @@ subprojects {
apply plugin: 'distribution' apply plugin: 'distribution'
apply plugin: 'elasticsearch.internal-distribution-archive-check' apply plugin: 'elasticsearch.internal-distribution-archive-check'
group = "org.elasticsearch.distribution.${name.startsWith("oss-") ? "oss" : "default"}" group = "org.elasticsearch.distribution.oss"
} }

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -49,15 +49,6 @@ tasks.register("generateDependenciesReport", ConcatFilesTask) {
String sourceUrl = "https://hg.openjdk.java.net/jdk-updates/jdk${jdkMajorVersion}u/archive/jdk-${jdkVersion}.tar.gz" String sourceUrl = "https://hg.openjdk.java.net/jdk-updates/jdk${jdkMajorVersion}u/archive/jdk-${jdkVersion}.tar.gz"
additionalLines << "OpenJDK,${jdkVersion},https://openjdk.java.net/,GPL-2.0-with-classpath-exception,${sourceUrl}".toString() additionalLines << "OpenJDK,${jdkVersion},https://openjdk.java.net/,GPL-2.0-with-classpath-exception,${sourceUrl}".toString()
// Explicitly add the dependency on the RHEL UBI Docker base image
String[] rhelUbiFields = [
'Red Hat Universal Base Image minimal',
'8',
'https://catalog.redhat.com/software/containers/ubi8/ubi-minimal/5c359a62bed8bd75a2c3fba8',
'Custom;https://www.redhat.com/licenses/EULA_Red_Hat_Universal_Base_Image_English_20190422.pdf',
'https://oss-dependencies.elastic.co/redhat/ubi/ubi-minimal-8-source.tar.gz'
]
additionalLines << rhelUbiFields.join(',')
} }
/***************************************************************************** /*****************************************************************************
@ -334,7 +325,7 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
/***************************************************************************** /*****************************************************************************
* Common files in all distributions * * Common files in all distributions *
*****************************************************************************/ *****************************************************************************/
libFiles = { oss -> libFiles = {
copySpec { copySpec {
// delay by using closures, since they have not yet been configured, so no jar task exists yet // delay by using closures, since they have not yet been configured, so no jar task exists yet
from(configurations.libs) from(configurations.libs)
@ -344,15 +335,10 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
into('tools/keystore-cli') { into('tools/keystore-cli') {
from(configurations.libsKeystoreCli) from(configurations.libsKeystoreCli)
} }
if (oss == false) {
into('tools/security-cli') {
from(configurations.libsSecurityCli)
}
}
} }
} }
modulesFiles = { oss, platform -> modulesFiles = { platform ->
copySpec { copySpec {
eachFile { eachFile {
if (it.relativePath.segments[-2] == 'bin' || (platform == 'darwin-x86_64' && it.relativePath.segments[-2] == 'MacOS')) { if (it.relativePath.segments[-2] == 'bin' || (platform == 'darwin-x86_64' && it.relativePath.segments[-2] == 'MacOS')) {
@ -363,12 +349,7 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
it.mode = 0644 it.mode = 0644
} }
} }
def buildModules def buildModules = buildOssModulesTaskProvider
if (oss) {
buildModules = buildOssModulesTaskProvider
} else {
buildModules = buildDefaultModulesTaskProvider
}
List excludePlatforms = ['linux-x86_64', 'linux-aarch64', 'windows-x86_64', 'darwin-x86_64'] List excludePlatforms = ['linux-x86_64', 'linux-aarch64', 'windows-x86_64', 'darwin-x86_64']
if (platform != null) { if (platform != null) {
excludePlatforms.remove(excludePlatforms.indexOf(platform)) excludePlatforms.remove(excludePlatforms.indexOf(platform))
@ -393,25 +374,20 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
from buildTransportModulesTaskProvider from buildTransportModulesTaskProvider
} }
configFiles = { distributionType, oss, jdk -> configFiles = { distributionType, jdk ->
copySpec { copySpec {
with copySpec { with copySpec {
// main config files, processed with distribution specific substitutions // main config files, processed with distribution specific substitutions
from '../src/config' from '../src/config'
exclude 'log4j2.properties' // this is handled separately below exclude 'log4j2.properties' // this is handled separately below
MavenFilteringHack.filter(it, expansionsForDistribution(distributionType, oss, jdk)) MavenFilteringHack.filter(it, expansionsForDistribution(distributionType, jdk))
}
if (oss) {
from project(':distribution').buildOssLog4jConfig
from project(':distribution').buildOssConfig
} else {
from project(':distribution').buildDefaultLog4jConfig
from project(':distribution').buildDefaultConfig
} }
from project(':distribution').buildOssLog4jConfig
from project(':distribution').buildOssConfig
} }
} }
binFiles = { distributionType, oss, jdk -> binFiles = { distributionType, jdk ->
copySpec { copySpec {
// non-windows files, for all distributions // non-windows files, for all distributions
with copySpec { with copySpec {
@ -419,7 +395,7 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
exclude '*.exe' exclude '*.exe'
exclude '*.bat' exclude '*.bat'
eachFile { it.setMode(0755) } eachFile { it.setMode(0755) }
MavenFilteringHack.filter(it, expansionsForDistribution(distributionType, oss, jdk)) MavenFilteringHack.filter(it, expansionsForDistribution(distributionType, jdk))
} }
// windows files, only for zip // windows files, only for zip
if (distributionType == 'zip') { if (distributionType == 'zip') {
@ -427,7 +403,7 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
from '../src/bin' from '../src/bin'
include '*.bat' include '*.bat'
filter(FixCrLfFilter, eol: FixCrLfFilter.CrLf.newInstance('crlf')) filter(FixCrLfFilter, eol: FixCrLfFilter.CrLf.newInstance('crlf'))
MavenFilteringHack.filter(it, expansionsForDistribution(distributionType, oss, jdk)) MavenFilteringHack.filter(it, expansionsForDistribution(distributionType, jdk))
} }
with copySpec { with copySpec {
from '../src/bin' from '../src/bin'
@ -437,11 +413,7 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
// module provided bin files // module provided bin files
with copySpec { with copySpec {
eachFile { it.setMode(0755) } eachFile { it.setMode(0755) }
if (oss) { from project(':distribution').buildOssBin
from project(':distribution').buildOssBin
} else {
from project(':distribution').buildDefaultBin
}
if (distributionType != 'zip') { if (distributionType != 'zip') {
exclude '*.bat' exclude '*.bat'
} }
@ -449,19 +421,15 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
} }
} }
noticeFile = { oss, jdk -> noticeFile = { jdk ->
copySpec { copySpec {
if (project.name == 'integ-test-zip') { if (project.name == 'integ-test-zip') {
from buildServerNoticeTaskProvider from buildServerNoticeTaskProvider
} else { } else {
if (oss && jdk) { if (jdk) {
from buildOssNoticeTaskProvider from buildOssNoticeTaskProvider
} else if (oss) {
from buildOssNoJdkNoticeTaskProvider
} else if (jdk) {
from buildDefaultNoticeTaskProvider
} else { } else {
from buildDefaultNoJdkNoticeTaskProvider from buildOssNoJdkNoticeTaskProvider
} }
} }
} }
@ -522,7 +490,7 @@ configure(subprojects.findAll { ['archives', 'packages'].contains(it.name) }) {
* </dl> * </dl>
*/ */
subprojects { subprojects {
ext.expansionsForDistribution = { distributionType, oss, jdk -> ext.expansionsForDistribution = { distributionType, jdk ->
final String defaultHeapSize = "1g" final String defaultHeapSize = "1g"
final String packagingPathData = "path.data: /var/lib/elasticsearch" final String packagingPathData = "path.data: /var/lib/elasticsearch"
final String pathLogs = "/var/log/elasticsearch" final String pathLogs = "/var/log/elasticsearch"
@ -598,11 +566,6 @@ subprojects {
'def': footer 'def': footer
], ],
'es.distribution.flavor': [
'def': oss ? 'oss' : 'default'
],
'es.distribution.type': [ 'es.distribution.type': [
'deb': 'deb', 'deb': 'deb',
'rpm': 'rpm', 'rpm': 'rpm',
@ -649,13 +612,11 @@ subprojects {
} }
} }
['archives:windows-zip', 'archives:oss-windows-zip', ['archives:oss-windows-zip',
'archives:darwin-tar', 'archives:oss-darwin-tar', 'archives:oss-darwin-tar',
'archives:linux-aarch64-tar', 'archives:oss-linux-aarch64-tar', 'archives:oss-linux-aarch64-tar',
'archives:linux-tar', 'archives:oss-linux-tar', 'archives:oss-linux-tar',
'archives:integ-test-zip', 'archives:integ-test-zip',
'packages:rpm', 'packages:deb',
'packages:aarch64-rpm', 'packages:aarch64-deb',
'packages:oss-rpm', 'packages:oss-deb', 'packages:oss-rpm', 'packages:oss-deb',
'packages:aarch64-oss-rpm', 'packages:aarch64-oss-deb' 'packages:aarch64-oss-rpm', 'packages:aarch64-oss-deb'
].forEach { subName -> ].forEach { subName ->

View File

@ -1,6 +1,5 @@
import org.elasticsearch.gradle.Architecture import org.elasticsearch.gradle.Architecture
import org.elasticsearch.gradle.DockerBase import org.elasticsearch.gradle.DockerBase
import org.elasticsearch.gradle.ElasticsearchDistribution.Flavor
import org.elasticsearch.gradle.LoggedExec import org.elasticsearch.gradle.LoggedExec
import org.elasticsearch.gradle.VersionProperties import org.elasticsearch.gradle.VersionProperties
import org.elasticsearch.gradle.docker.DockerBuildTask import org.elasticsearch.gradle.docker.DockerBuildTask
@ -14,20 +13,16 @@ apply plugin: 'elasticsearch.rest-resources'
testFixtures.useFixture() testFixtures.useFixture()
configurations { configurations {
aarch64DockerSource
dockerSource
aarch64OssDockerSource aarch64OssDockerSource
ossDockerSource ossDockerSource
} }
dependencies { dependencies {
aarch64DockerSource project(path: ":distribution:archives:linux-aarch64-tar", configuration:"default")
dockerSource project(path: ":distribution:archives:linux-tar", configuration:"default")
aarch64OssDockerSource project(path: ":distribution:archives:oss-linux-aarch64-tar", configuration:"default") aarch64OssDockerSource project(path: ":distribution:archives:oss-linux-aarch64-tar", configuration:"default")
ossDockerSource project(path: ":distribution:archives:oss-linux-tar", configuration:"default") ossDockerSource project(path: ":distribution:archives:oss-linux-tar", configuration:"default")
} }
ext.expansions = { Architecture architecture, boolean oss, DockerBase base, boolean local -> ext.expansions = { Architecture architecture, DockerBase base, boolean local ->
String classifier String classifier
if (local) { if (local) {
if (architecture == Architecture.AARCH64) { if (architecture == Architecture.AARCH64) {
@ -44,7 +39,7 @@ ext.expansions = { Architecture architecture, boolean oss, DockerBase base, bool
classifier = "linux-\$(arch)" classifier = "linux-\$(arch)"
} }
final String elasticsearch = "elasticsearch-${oss ? 'oss-' : ''}${VersionProperties.elasticsearch}-${classifier}.tar.gz" final String elasticsearch = "elasticsearch-oss-${VersionProperties.elasticsearch}-${classifier}.tar.gz"
/* Both the following Dockerfile commands put the resulting artifact at /* Both the following Dockerfile commands put the resulting artifact at
* the same location, regardless of classifier, so that the commands that * the same location, regardless of classifier, so that the commands that
@ -66,83 +61,62 @@ RUN curl --retry 8 -S -L \\
'build_date' : BuildParams.buildDate, 'build_date' : BuildParams.buildDate,
'git_revision' : BuildParams.gitRevision, 'git_revision' : BuildParams.gitRevision,
'license' : 'Apache-2.0', 'license' : 'Apache-2.0',
'package_manager' : base == DockerBase.UBI ? 'microdnf' : 'yum', 'package_manager' : 'yum',
'source_elasticsearch': sourceElasticsearch, 'source_elasticsearch': sourceElasticsearch,
'docker_base' : base.name().toLowerCase(), 'docker_base' : base.name().toLowerCase(),
'version' : VersionProperties.elasticsearch 'version' : VersionProperties.elasticsearch
] ]
} }
private static String buildPath(Architecture architecture, boolean oss, DockerBase base) { private static String buildPath(Architecture architecture, DockerBase base) {
return 'build/' + return 'build/' +
(architecture == Architecture.AARCH64 ? 'aarch64-' : '') + (architecture == Architecture.AARCH64 ? 'aarch64-' : '') +
(oss ? 'oss-' : '') + 'oss-' +
(base == DockerBase.UBI ? 'ubi-' : '') +
'docker' 'docker'
} }
private static String taskName(String prefix, Architecture architecture, boolean oss, DockerBase base, String suffix) { private static String taskName(String prefix, Architecture architecture, DockerBase base, String suffix) {
return prefix + return prefix +
(architecture == Architecture.AARCH64 ? 'Aarch64' : '') + (architecture == Architecture.AARCH64 ? 'Aarch64' : '') +
(oss ? 'Oss' : '') + 'Oss' +
(base == DockerBase.UBI ? 'Ubi' : '') +
suffix suffix
} }
project.ext { project.ext {
dockerBuildContext = { Architecture architecture, boolean oss, DockerBase base, boolean local -> dockerBuildContext = { Architecture architecture, DockerBase base, boolean local ->
copySpec { copySpec {
into('bin') { into('bin') {
from project.projectDir.toPath().resolve("src/docker/bin") from project.projectDir.toPath().resolve("src/docker/bin")
} }
into('config') { into('config') {
/* from project.projectDir.toPath().resolve("src/docker/config")
* The OSS and default distributions have different configurations, therefore we want to allow overriding the default configuration
* from files in the 'oss' sub-directory. We don't want the 'oss' sub-directory to appear in the final build context, however.
*/
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
from(project.projectDir.toPath().resolve("src/docker/config")) {
exclude 'oss'
}
if (oss) {
// Overlay the config file
from project.projectDir.toPath().resolve("src/docker/config/oss")
}
} }
from(project.projectDir.toPath().resolve("src/docker/Dockerfile")) { from(project.projectDir.toPath().resolve("src/docker/Dockerfile")) {
expand(expansions(architecture, oss, base, local)) expand(expansions(architecture, base, local))
} }
} }
} }
} }
void addCopyDockerContextTask(Architecture architecture, boolean oss, DockerBase base) { void addCopyDockerContextTask(Architecture architecture, DockerBase base) {
if (oss && base != DockerBase.CENTOS) { if (base != DockerBase.CENTOS) {
throw new GradleException("The only allowed docker base image for OSS builds is CENTOS") throw new GradleException("The only allowed docker base image for OSS builds is CENTOS")
} }
tasks.register(taskName("copy", architecture, oss, base, "DockerContext"), Sync) { tasks.register(taskName("copy", architecture, base, "DockerContext"), Sync) {
expansions(architecture, oss, base, true).findAll { it.key != 'build_date' }.each { k, v -> expansions(architecture, base, true).findAll { it.key != 'build_date' }.each { k, v ->
inputs.property(k, { v.toString() }) inputs.property(k, { v.toString() })
} }
into buildPath(architecture, oss, base) into buildPath(architecture, base)
with dockerBuildContext(architecture, oss, base, true) with dockerBuildContext(architecture, base, true)
if (architecture == Architecture.AARCH64) { if (architecture == Architecture.AARCH64) {
if (oss) { from configurations.aarch64OssDockerSource
from configurations.aarch64OssDockerSource
} else {
from configurations.aarch64DockerSource
}
} else { } else {
if (oss) { from configurations.ossDockerSource
from configurations.ossDockerSource
} else {
from configurations.dockerSource
}
} }
} }
} }
@ -157,31 +131,24 @@ def createAndSetWritable(Object... locations) {
elasticsearch_distributions { elasticsearch_distributions {
Architecture.values().each { eachArchitecture -> Architecture.values().each { eachArchitecture ->
Flavor.values().each { distroFlavor -> "docker${ eachArchitecture == Architecture.AARCH64 ? '_aarch64' : '' }" {
"docker_$distroFlavor${ eachArchitecture == Architecture.AARCH64 ? '_aarch64' : '' }" { architecture = eachArchitecture
architecture = eachArchitecture type = 'docker'
flavor = distroFlavor version = VersionProperties.getElasticsearch()
type = 'docker' failIfUnavailable = false // This ensures we don't attempt to build images if docker is unavailable
version = VersionProperties.getElasticsearch()
failIfUnavailable = false // This ensures we don't attempt to build images if docker is unavailable
}
} }
} }
} }
tasks.named("preProcessFixture").configure { tasks.named("preProcessFixture").configure {
dependsOn elasticsearch_distributions.docker_default, elasticsearch_distributions.docker_oss dependsOn elasticsearch_distributions.docker
doLast { doLast {
// tests expect to have an empty repo // tests expect to have an empty repo
project.delete( project.delete(
"${buildDir}/repo",
"${buildDir}/oss-repo" "${buildDir}/oss-repo"
) )
createAndSetWritable( createAndSetWritable(
"${buildDir}/repo",
"${buildDir}/oss-repo", "${buildDir}/oss-repo",
"${buildDir}/logs/default-1",
"${buildDir}/logs/default-2",
"${buildDir}/logs/oss-1", "${buildDir}/logs/oss-1",
"${buildDir}/logs/oss-2" "${buildDir}/logs/oss-2"
) )
@ -198,34 +165,24 @@ tasks.named("check").configure {
dependsOn "integTest" dependsOn "integTest"
} }
void addBuildDockerImage(Architecture architecture, boolean oss, DockerBase base) { void addBuildDockerImage(Architecture architecture, DockerBase base) {
if (oss && base != DockerBase.CENTOS) { if (base != DockerBase.CENTOS) {
throw new GradleException("The only allowed docker base image for OSS builds is CENTOS") throw new GradleException("The only allowed docker base image for OSS builds is CENTOS")
} }
final TaskProvider<DockerBuildTask> buildDockerImageTask = final TaskProvider<DockerBuildTask> buildDockerImageTask =
tasks.register(taskName("build", architecture, oss, base, "DockerImage"), DockerBuildTask) { tasks.register(taskName("build", architecture, base, "DockerImage"), DockerBuildTask) {
onlyIf { Architecture.current() == architecture } onlyIf { Architecture.current() == architecture }
TaskProvider<Sync> copyContextTask = tasks.named(taskName("copy", architecture, oss, base, "DockerContext")) TaskProvider<Sync> copyContextTask = tasks.named(taskName("copy", architecture, base, "DockerContext"))
dependsOn(copyContextTask) dependsOn(copyContextTask)
dockerContext.fileProvider(copyContextTask.map { it.destinationDir }) dockerContext.fileProvider(copyContextTask.map { it.destinationDir })
baseImages = [ base.getImage() ] baseImages = [ base.getImage() ]
String version = VersionProperties.elasticsearch String version = VersionProperties.elasticsearch
if (oss) {
tags = [ tags = [
"docker.elastic.co/elasticsearch/elasticsearch-oss:${version}", "docker.elastic.co/elasticsearch/elasticsearch-oss:${version}",
"elasticsearch-oss:test" "elasticsearch-oss:test"
] ]
} else {
String suffix = base == DockerBase.UBI ? '-ubi8' : ''
tags = [
"elasticsearch${suffix}:${version}",
"docker.elastic.co/elasticsearch/elasticsearch${suffix}:${version}",
"docker.elastic.co/elasticsearch/elasticsearch-full${suffix}:${version}",
"elasticsearch${suffix}:test",
]
}
} }
tasks.named("assemble").configure { tasks.named("assemble").configure {
dependsOn(buildDockerImageTask) dependsOn(buildDockerImageTask)
@ -233,15 +190,11 @@ void addBuildDockerImage(Architecture architecture, boolean oss, DockerBase base
} }
for (final Architecture architecture : Architecture.values()) { for (final Architecture architecture : Architecture.values()) {
// We only create Docker images for the OSS distribution on CentOS.
for (final DockerBase base : DockerBase.values()) { for (final DockerBase base : DockerBase.values()) {
for (final boolean oss : [false, true]) { if (base == DockerBase.CENTOS) {
if (oss && base != DockerBase.CENTOS) { addCopyDockerContextTask(architecture, base)
// We only create Docker images for the OSS distribution on CentOS. addBuildDockerImage(architecture, base)
// Other bases only use the default distribution.
continue
}
addCopyDockerContextTask(architecture, oss, base)
addBuildDockerImage(architecture, oss, base)
} }
} }
} }
@ -262,16 +215,15 @@ subprojects { Project subProject ->
apply plugin: 'distribution' apply plugin: 'distribution'
final Architecture architecture = subProject.name.contains('aarch64-') ? Architecture.AARCH64 : Architecture.X64 final Architecture architecture = subProject.name.contains('aarch64-') ? Architecture.AARCH64 : Architecture.X64
final boolean oss = subProject.name.contains('oss-') final DockerBase base = DockerBase.CENTOS
final DockerBase base = subProject.name.contains('ubi-') ? DockerBase.UBI : DockerBase.CENTOS
final String arch = architecture == Architecture.AARCH64 ? '-aarch64' : '' final String arch = architecture == Architecture.AARCH64 ? '-aarch64' : ''
final String suffix = oss ? '-oss' : base == DockerBase.UBI ? '-ubi8' : '' final String suffix = '-oss'
final String extension = base == DockerBase.UBI ? 'ubi.tar' : 'docker.tar' final String extension = 'docker.tar'
final String artifactName = "elasticsearch${arch}${suffix}_test" final String artifactName = "elasticsearch${arch}${suffix}_test"
final String exportTaskName = taskName("export", architecture, oss, base, "DockerImage") final String exportTaskName = taskName("export", architecture, base, "DockerImage")
final String buildTaskName = taskName("build", architecture, oss, base, "DockerImage") final String buildTaskName = taskName("build", architecture, base, "DockerImage")
final String tarFile = "${parent.projectDir}/build/${artifactName}_${VersionProperties.elasticsearch}.${extension}" final String tarFile = "${parent.projectDir}/build/${artifactName}_${VersionProperties.elasticsearch}.${extension}"
tasks.register(exportTaskName, LoggedExec) { tasks.register(exportTaskName, LoggedExec) {

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// export is done in the parent project.

View File

@ -1,14 +0,0 @@
import org.elasticsearch.gradle.DockerBase
apply plugin: 'base'
tasks.register("buildDockerBuildContext", Tar) {
archiveExtension = 'tar.gz'
compression = Compression.GZIP
archiveClassifier = "docker-build-context"
archiveBaseName = "elasticsearch"
// Non-local builds don't need to specify an architecture.
with dockerBuildContext(null, false, DockerBase.CENTOS, false)
}
tasks.named("assemble").configure {dependsOn "buildDockerBuildContext"}

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// export is done in the parent project.

View File

@ -8,7 +8,7 @@ tasks.register("buildOssDockerBuildContext", Tar) {
archiveClassifier = "docker-build-context" archiveClassifier = "docker-build-context"
archiveBaseName = "elasticsearch-oss" archiveBaseName = "elasticsearch-oss"
// Non-local builds don't need to specify an architecture. // Non-local builds don't need to specify an architecture.
with dockerBuildContext(null, true, DockerBase.CENTOS, false) with dockerBuildContext(null, DockerBase.CENTOS, false)
} }
tasks.named("assemble").configure { dependsOn "buildOssDockerBuildContext" } tasks.named("assemble").configure { dependsOn "buildOssDockerBuildContext" }

View File

@ -20,10 +20,6 @@
################################################################################ ################################################################################
FROM ${base_image} AS builder FROM ${base_image} AS builder
<% if (docker_base == 'ubi') { %>
# Install required packages to extract the Elasticsearch distribution
RUN ${package_manager} install -y tar gzip
<% } %>
# `tini` is a tiny but valid init for containers. This is used to cleanly # `tini` is a tiny but valid init for containers. This is used to cleanly
# control how ES and any child processes are shut down. # control how ES and any child processes are shut down.
# #
@ -70,7 +66,7 @@ ENV ELASTIC_CONTAINER true
RUN for iter in {1..10}; do \\ RUN for iter in {1..10}; do \\
${package_manager} update --setopt=tsflags=nodocs -y && \\ ${package_manager} update --setopt=tsflags=nodocs -y && \\
${package_manager} install --setopt=tsflags=nodocs -y \\ ${package_manager} install --setopt=tsflags=nodocs -y \\
nc shadow-utils zip unzip <%= docker_base == 'ubi' ? 'findutils procps-ng' : '' %> && \\ nc shadow-utils zip unzip && \\
${package_manager} clean all && exit_code=0 && break || exit_code=\$? && echo "${package_manager} error: retry \$iter in 10s" && \\ ${package_manager} clean all && exit_code=0 && break || exit_code=\$? && echo "${package_manager} error: retry \$iter in 10s" && \\
sleep 10; \\ sleep 10; \\
done; \\ done; \\
@ -124,18 +120,6 @@ LABEL org.label-schema.build-date="${build_date}" \\
org.opencontainers.image.url="https://www.elastic.co/products/elasticsearch" \\ org.opencontainers.image.url="https://www.elastic.co/products/elasticsearch" \\
org.opencontainers.image.vendor="Elastic" \\ org.opencontainers.image.vendor="Elastic" \\
org.opencontainers.image.version="${version}" org.opencontainers.image.version="${version}"
<% if (docker_base == 'ubi') { %>
LABEL name="Elasticsearch" \\
maintainer="infra@elastic.co" \\
vendor="Elastic" \\
version="${version}" \\
release="1" \\
summary="Elasticsearch" \\
description="You know, for search."
RUN mkdir /licenses && \\
cp LICENSE.txt /licenses/LICENSE
<% } %>
ENTRYPOINT ["/tini", "--", "/usr/local/bin/docker-entrypoint.sh"] ENTRYPOINT ["/tini", "--", "/usr/local/bin/docker-entrypoint.sh"]
# Dummy overridable parameter parsed by entrypoint # Dummy overridable parameter parsed by entrypoint

View File

@ -21,12 +21,8 @@ package org.elasticsearch.docker.test;
import com.carrotsearch.randomizedtesting.annotations.ParametersFactory; import com.carrotsearch.randomizedtesting.annotations.ParametersFactory;
import org.elasticsearch.ElasticsearchException; import org.elasticsearch.ElasticsearchException;
import org.elasticsearch.client.Request; import org.elasticsearch.client.Request;
import org.elasticsearch.common.CharArrays;
import org.elasticsearch.common.io.PathUtils; import org.elasticsearch.common.io.PathUtils;
import org.elasticsearch.common.settings.SecureString;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.util.concurrent.ThreadContext;
import org.elasticsearch.test.rest.ESRestTestCase;
import org.elasticsearch.test.rest.yaml.ClientYamlTestCandidate; import org.elasticsearch.test.rest.yaml.ClientYamlTestCandidate;
import org.elasticsearch.test.rest.yaml.ESClientYamlSuiteTestCase; import org.elasticsearch.test.rest.yaml.ESClientYamlSuiteTestCase;
import org.junit.AfterClass; import org.junit.AfterClass;
@ -35,11 +31,8 @@ import org.junit.BeforeClass;
import java.io.IOException; import java.io.IOException;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.nio.CharBuffer;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.Arrays;
import java.util.Base64;
public class DockerYmlTestSuiteIT extends ESClientYamlSuiteTestCase { public class DockerYmlTestSuiteIT extends ESClientYamlSuiteTestCase {
@ -58,13 +51,12 @@ public class DockerYmlTestSuiteIT extends ESClientYamlSuiteTestCase {
@Override @Override
protected String getTestRestCluster() { protected String getTestRestCluster() {
String distribution = getDistribution();
return new StringBuilder() return new StringBuilder()
.append("localhost:") .append("localhost:")
.append(getProperty("test.fixtures.elasticsearch-" + distribution + "-1.tcp.9200")) .append(getProperty("test.fixtures.elasticsearch-oss-1.tcp.9200"))
.append(",") .append(",")
.append("localhost:") .append("localhost:")
.append(getProperty("test.fixtures.elasticsearch-" + distribution + "-2.tcp.9200")) .append(getProperty("test.fixtures.elasticsearch-oss-2.tcp.9200"))
.toString(); .toString();
} }
@ -73,18 +65,6 @@ public class DockerYmlTestSuiteIT extends ESClientYamlSuiteTestCase {
return false; return false;
} }
private String getDistribution() {
String distribution = System.getProperty("tests.distribution", "default");
if (distribution.equals("oss") == false && distribution.equals("default") == false) {
throw new IllegalArgumentException("supported values for tests.distribution are oss or default but it was " + distribution);
}
return distribution;
}
private boolean isOss() {
return getDistribution().equals("oss");
}
private String getProperty(String key) { private String getProperty(String key) {
String value = System.getProperty(key); String value = System.getProperty(key);
if (value == null) { if (value == null) {
@ -124,40 +104,11 @@ public class DockerYmlTestSuiteIT extends ESClientYamlSuiteTestCase {
@Override @Override
protected Settings restClientSettings() { protected Settings restClientSettings() {
if (isOss()) { return super.restClientSettings();
return super.restClientSettings();
}
String token = basicAuthHeaderValue(USER, new SecureString(PASS.toCharArray()));
return Settings.builder()
.put(ThreadContext.PREFIX + ".Authorization", token)
.put(ESRestTestCase.TRUSTSTORE_PATH, keyStore)
.put(ESRestTestCase.TRUSTSTORE_PASSWORD, KEYSTORE_PASS)
.build();
} }
@Override @Override
protected String getProtocol() { protected String getProtocol() {
if (isOss()) { return "http";
return "http";
}
return "https";
}
private static String basicAuthHeaderValue(String username, SecureString passwd) {
CharBuffer chars = CharBuffer.allocate(username.length() + passwd.length() + 1);
byte[] charBytes = null;
try {
chars.put(username).put(':').put(passwd.getChars());
charBytes = CharArrays.toUtf8Bytes(chars.array());
//TODO we still have passwords in Strings in headers. Maybe we can look into using a CharSequence?
String basicToken = Base64.getEncoder().encodeToString(charBytes);
return "Basic " + basicToken;
} finally {
Arrays.fill(chars.array(), (char) 0);
if (charBytes != null) {
Arrays.fill(charBytes, (byte) 0);
}
}
} }
} }

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// export is done in the parent project.

View File

@ -1,13 +0,0 @@
import org.elasticsearch.gradle.DockerBase
apply plugin: 'base'
task buildUbiDockerBuildContext(type: Tar) {
archiveExtension = 'tar.gz'
compression = Compression.GZIP
archiveClassifier = "docker-build-context"
archiveBaseName = "elasticsearch-ubi8"
with dockerBuildContext(null, false, DockerBase.UBI, false)
}
assemble.dependsOn buildUbiDockerBuildContext

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// export is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -55,23 +55,23 @@ plugins {
id "nebula.ospackage-base" version "8.3.0" id "nebula.ospackage-base" version "8.3.0"
} }
void addProcessFilesTask(String type, boolean oss, boolean jdk) { void addProcessFilesTask(String type, boolean jdk) {
String packagingFiles = "build/packaging/${oss ? 'oss-' : ''}${jdk ? '' : 'no-jdk-'}${type}" String packagingFiles = "build/packaging/oss-${jdk ? '' : 'no-jdk-'}${type}"
String taskName = "process${oss ? 'Oss' : ''}${jdk ? '' : 'NoJdk'}${type.capitalize()}Files" String taskName = "processOss'${jdk ? '' : 'NoJdk'}${type.capitalize()}Files"
tasks.register(taskName, Copy) { tasks.register(taskName, Copy) {
into packagingFiles into packagingFiles
with copySpec { with copySpec {
from 'src/common' from 'src/common'
from "src/${type}" from "src/${type}"
MavenFilteringHack.filter(it, expansionsForDistribution(type, oss, jdk)) MavenFilteringHack.filter(it, expansionsForDistribution(type, jdk))
} }
into('etc/elasticsearch') { into('etc/elasticsearch') {
with configFiles(type, oss, jdk) with configFiles(type, jdk)
} }
MavenFilteringHack.filter(it, expansionsForDistribution(type, oss, jdk)) MavenFilteringHack.filter(it, expansionsForDistribution(type, jdk))
doLast { doLast {
// create empty dirs, we set the permissions when configuring the packages // create empty dirs, we set the permissions when configuring the packages
@ -86,25 +86,21 @@ void addProcessFilesTask(String type, boolean oss, boolean jdk) {
} }
} }
addProcessFilesTask('deb', true, true) addProcessFilesTask('deb', true)
addProcessFilesTask('deb', true, false) addProcessFilesTask('deb', false)
addProcessFilesTask('deb', false, true) addProcessFilesTask('rpm', true)
addProcessFilesTask('deb', false, false) addProcessFilesTask('rpm', false)
addProcessFilesTask('rpm', true, true)
addProcessFilesTask('rpm', true, false)
addProcessFilesTask('rpm', false, true)
addProcessFilesTask('rpm', false, false)
// Common configuration that is package dependent. This can't go in ospackage // Common configuration that is package dependent. This can't go in ospackage
// since we have different templated files that need to be consumed, but the structure // since we have different templated files that need to be consumed, but the structure
// is the same // is the same
Closure commonPackageConfig(String type, boolean oss, boolean jdk, String architecture) { Closure commonPackageConfig(String type, boolean jdk, String architecture) {
return { return {
onlyIf { onlyIf {
OS.current().equals(OS.WINDOWS) == false OS.current().equals(OS.WINDOWS) == false
} }
dependsOn "process${oss ? 'Oss' : ''}${jdk ? '' : 'NoJdk'}${type.capitalize()}Files" dependsOn "processOss'${jdk ? '' : 'NoJdk'}${type.capitalize()}Files"
packageName "elasticsearch${oss ? '-oss' : ''}" packageName "elasticsearch-oss"
if (type == 'deb') { if (type == 'deb') {
if (architecture == 'x64') { if (architecture == 'x64') {
arch('amd64') arch('amd64')
@ -123,13 +119,13 @@ Closure commonPackageConfig(String type, boolean oss, boolean jdk, String archit
} }
// Follow elasticsearch's file naming convention // Follow elasticsearch's file naming convention
String jdkString = jdk ? "" : "no-jdk-" String jdkString = jdk ? "" : "no-jdk-"
String prefix = "${architecture == 'aarch64' ? 'aarch64-' : ''}${oss ? 'oss-' : ''}${jdk ? '' : 'no-jdk-'}${type}" String prefix = "${architecture == 'aarch64' ? 'aarch64-' : ''}oss-${jdk ? '' : 'no-jdk-'}${type}"
destinationDirectory = file("${prefix}/build/distributions") destinationDirectory = file("${prefix}/build/distributions")
// SystemPackagingTask overrides default archive task convention mappings, but doesn't provide a setter so we have to override the convention mapping itself // SystemPackagingTask overrides default archive task convention mappings, but doesn't provide a setter so we have to override the convention mapping itself
conventionMapping.archiveFile = { objects.fileProperty().fileValue(file("${destinationDirectory.get()}/${packageName}-${project.version}-${jdkString}${archString}.${type}")) } conventionMapping.archiveFile = { objects.fileProperty().fileValue(file("${destinationDirectory.get()}/${packageName}-${project.version}-${jdkString}${archString}.${type}")) }
String packagingFiles = "build/packaging/${oss ? 'oss-' : ''}${jdk ? '' : 'no-jdk-'}${type}" String packagingFiles = "build/packaging/oss-${jdk ? '' : 'no-jdk-'}${type}"
String scripts = "${packagingFiles}/scripts" String scripts = "${packagingFiles}/scripts"
preInstall file("${scripts}/preinst") preInstall file("${scripts}/preinst")
@ -144,17 +140,17 @@ Closure commonPackageConfig(String type, boolean oss, boolean jdk, String archit
// specify it again explicitly for copying common files // specify it again explicitly for copying common files
into('/usr/share/elasticsearch') { into('/usr/share/elasticsearch') {
into('bin') { into('bin') {
with binFiles(type, oss, jdk) with binFiles(type, jdk)
} }
from(rootProject.projectDir) { from(rootProject.projectDir) {
include 'README.asciidoc' include 'README.asciidoc'
fileMode 0644 fileMode 0644
} }
into('lib') { into('lib') {
with libFiles(oss) with libFiles()
} }
into('modules') { into('modules') {
with modulesFiles(oss, 'linux-' + ((architecture == 'x64') ? 'x86_64' : architecture)) with modulesFiles('linux-' + ((architecture == 'x64') ? 'x86_64' : architecture))
} }
if (jdk) { if (jdk) {
into('jdk') { into('jdk') {
@ -200,12 +196,6 @@ Closure commonPackageConfig(String type, boolean oss, boolean jdk, String archit
configurationFile '/etc/elasticsearch/elasticsearch.yml' configurationFile '/etc/elasticsearch/elasticsearch.yml'
configurationFile '/etc/elasticsearch/jvm.options' configurationFile '/etc/elasticsearch/jvm.options'
configurationFile '/etc/elasticsearch/log4j2.properties' configurationFile '/etc/elasticsearch/log4j2.properties'
if (oss == false) {
configurationFile '/etc/elasticsearch/role_mapping.yml'
configurationFile '/etc/elasticsearch/roles.yml'
configurationFile '/etc/elasticsearch/users'
configurationFile '/etc/elasticsearch/users_roles'
}
from("${packagingFiles}") { from("${packagingFiles}") {
dirMode 02750 dirMode 02750
into('/etc') into('/etc')
@ -224,7 +214,7 @@ Closure commonPackageConfig(String type, boolean oss, boolean jdk, String archit
createDirectoryEntry true createDirectoryEntry true
fileType CONFIG | NOREPLACE fileType CONFIG | NOREPLACE
} }
String envFile = expansionsForDistribution(type, oss, jdk)['path.env'] String envFile = expansionsForDistribution(type, jdk)['path.env']
configurationFile envFile configurationFile envFile
into(new File(envFile).getParent()) { into(new File(envFile).getParent()) {
fileType CONFIG | NOREPLACE fileType CONFIG | NOREPLACE
@ -279,11 +269,8 @@ Closure commonPackageConfig(String type, boolean oss, boolean jdk, String archit
copyEmptyDir('/var/lib/elasticsearch', 'elasticsearch', 'elasticsearch', 02750) copyEmptyDir('/var/lib/elasticsearch', 'elasticsearch', 'elasticsearch', 02750)
copyEmptyDir('/usr/share/elasticsearch/plugins', 'root', 'root', 0755) copyEmptyDir('/usr/share/elasticsearch/plugins', 'root', 'root', 0755)
// the oss package conflicts with the default distribution and vice versa
conflicts('elasticsearch' + (oss ? '' : '-oss'))
into '/usr/share/elasticsearch' into '/usr/share/elasticsearch'
with noticeFile(oss, jdk) with noticeFile(jdk)
} }
} }
@ -321,9 +308,9 @@ ospackage {
into '/usr/share/elasticsearch' into '/usr/share/elasticsearch'
} }
Closure commonDebConfig(boolean oss, boolean jdk, String architecture) { Closure commonDebConfig(boolean jdk, String architecture) {
return { return {
configure(commonPackageConfig('deb', oss, jdk, architecture)) configure(commonPackageConfig('deb', jdk, architecture))
// jdeb does not provide a way to set the License control attribute, and ospackage // jdeb does not provide a way to set the License control attribute, and ospackage
// silently ignores setting it. Instead, we set the license as "custom field" // silently ignores setting it. Instead, we set the license as "custom field"
@ -340,40 +327,26 @@ Closure commonDebConfig(boolean oss, boolean jdk, String architecture) {
into('/usr/share/lintian/overrides') { into('/usr/share/lintian/overrides') {
from('src/deb/lintian/elasticsearch') from('src/deb/lintian/elasticsearch')
if (oss) { rename('elasticsearch', 'elasticsearch-oss')
rename('elasticsearch', 'elasticsearch-oss')
}
} }
} }
} }
tasks.register('buildAarch64Deb', Deb) {
configure(commonDebConfig(false, true, 'aarch64'))
}
tasks.register('buildDeb', Deb) {
configure(commonDebConfig(false, true, 'x64'))
}
tasks.register('buildAarch64OssDeb', Deb) { tasks.register('buildAarch64OssDeb', Deb) {
configure(commonDebConfig(true, true, 'aarch64')) configure(commonDebConfig(true, 'aarch64'))
} }
tasks.register('buildOssDeb', Deb) { tasks.register('buildOssDeb', Deb) {
configure(commonDebConfig(true, true, 'x64')) configure(commonDebConfig(true, 'x64'))
}
tasks.register('buildNoJdkDeb', Deb) {
configure(commonDebConfig(false, false, 'x64'))
} }
tasks.register('buildOssNoJdkDeb', Deb) { tasks.register('buildOssNoJdkDeb', Deb) {
configure(commonDebConfig(true, false, 'x64')) configure(commonDebConfig(true, 'x64'))
} }
Closure commonRpmConfig(boolean oss, boolean jdk, String architecture) { Closure commonRpmConfig(boolean jdk, String architecture) {
return { return {
configure(commonPackageConfig('rpm', oss, jdk, architecture)) configure(commonPackageConfig('rpm', jdk, architecture))
license 'ASL 2.0' license 'ASL 2.0'
@ -396,28 +369,16 @@ Closure commonRpmConfig(boolean oss, boolean jdk, String architecture) {
} }
} }
tasks.register('buildAarch64Rpm', Rpm) {
configure(commonRpmConfig(false, true, 'aarch64'))
}
tasks.register('buildRpm', Rpm) {
configure(commonRpmConfig(false, true, 'x64'))
}
tasks.register('buildAarch64OssRpm', Rpm) { tasks.register('buildAarch64OssRpm', Rpm) {
configure(commonRpmConfig(true, true, 'aarch64')) configure(commonRpmConfig(true, 'aarch64'))
} }
tasks.register('buildOssRpm', Rpm) { tasks.register('buildOssRpm', Rpm) {
configure(commonRpmConfig(true, true, 'x64')) configure(commonRpmConfig(true, 'x64'))
}
tasks.register('buildNoJdkRpm', Rpm) {
configure(commonRpmConfig(false, false, 'x64'))
} }
tasks.register('buildOssNoJdkRpm', Rpm) { tasks.register('buildOssNoJdkRpm', Rpm) {
configure(commonRpmConfig(true, false, 'x64')) configure(commonRpmConfig(true, 'x64'))
} }
Closure dpkgExists = { it -> new File('/bin/dpkg-deb').exists() || new File('/usr/bin/dpkg-deb').exists() || new File('/usr/local/bin/dpkg-deb').exists() } Closure dpkgExists = { it -> new File('/bin/dpkg-deb').exists() || new File('/usr/bin/dpkg-deb').exists() || new File('/usr/local/bin/dpkg-deb').exists() }
@ -494,14 +455,7 @@ subprojects {
Path copyrightPath Path copyrightPath
String expectedLicense String expectedLicense
String licenseFilename String licenseFilename
if (project.name.contains('oss-')) { copyrightPath = packageExtractionDir.toPath().resolve("usr/share/doc/elasticsearch-oss/copyright")
copyrightPath = packageExtractionDir.toPath().resolve("usr/share/doc/elasticsearch-oss/copyright")
}
// TODO - remove this block and only check for the OSS distribution
// https://github.com/opendistro-for-elasticsearch/search/issues/50
else {
copyrightPath = packageExtractionDir.toPath().resolve("usr/share/doc/elasticsearch/copyright")
}
expectedLicense = "ASL-2.0" expectedLicense = "ASL-2.0"
licenseFilename = "APACHE-LICENSE-2.0.txt" licenseFilename = "APACHE-LICENSE-2.0.txt"
final List<String> header = Arrays.asList("Format: https://www.debian.org/doc/packaging-manuals/copyright-format/1.0/", final List<String> header = Arrays.asList("Format: https://www.debian.org/doc/packaging-manuals/copyright-format/1.0/",

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 KiB

View File

@ -1,2 +0,0 @@
// This file is intentionally blank. All configuration of the
// distribution is done in the parent project.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 KiB

View File

@ -62,7 +62,6 @@ if [[ $DAEMONIZE = false ]]; then
$ES_JAVA_OPTS \ $ES_JAVA_OPTS \
-Des.path.home="$ES_HOME" \ -Des.path.home="$ES_HOME" \
-Des.path.conf="$ES_PATH_CONF" \ -Des.path.conf="$ES_PATH_CONF" \
-Des.distribution.flavor="$ES_DISTRIBUTION_FLAVOR" \
-Des.distribution.type="$ES_DISTRIBUTION_TYPE" \ -Des.distribution.type="$ES_DISTRIBUTION_TYPE" \
-Des.bundled_jdk="$ES_BUNDLED_JDK" \ -Des.bundled_jdk="$ES_BUNDLED_JDK" \
-cp "$ES_CLASSPATH" \ -cp "$ES_CLASSPATH" \
@ -75,7 +74,6 @@ else
$ES_JAVA_OPTS \ $ES_JAVA_OPTS \
-Des.path.home="$ES_HOME" \ -Des.path.home="$ES_HOME" \
-Des.path.conf="$ES_PATH_CONF" \ -Des.path.conf="$ES_PATH_CONF" \
-Des.distribution.flavor="$ES_DISTRIBUTION_FLAVOR" \
-Des.distribution.type="$ES_DISTRIBUTION_TYPE" \ -Des.distribution.type="$ES_DISTRIBUTION_TYPE" \
-Des.bundled_jdk="$ES_BUNDLED_JDK" \ -Des.bundled_jdk="$ES_BUNDLED_JDK" \
-cp "$ES_CLASSPATH" \ -cp "$ES_CLASSPATH" \

View File

@ -26,7 +26,6 @@ exec \
$ES_JAVA_OPTS \ $ES_JAVA_OPTS \
-Des.path.home="$ES_HOME" \ -Des.path.home="$ES_HOME" \
-Des.path.conf="$ES_PATH_CONF" \ -Des.path.conf="$ES_PATH_CONF" \
-Des.distribution.flavor="$ES_DISTRIBUTION_FLAVOR" \
-Des.distribution.type="$ES_DISTRIBUTION_TYPE" \ -Des.distribution.type="$ES_DISTRIBUTION_TYPE" \
-cp "$ES_CLASSPATH" \ -cp "$ES_CLASSPATH" \
"$ES_MAIN_CLASS" \ "$ES_MAIN_CLASS" \

View File

@ -20,7 +20,6 @@ set ES_JAVA_OPTS=-Xms4m -Xmx64m -XX:+UseSerialGC %ES_JAVA_OPTS%
%ES_JAVA_OPTS% ^ %ES_JAVA_OPTS% ^
-Des.path.home="%ES_HOME%" ^ -Des.path.home="%ES_HOME%" ^
-Des.path.conf="%ES_PATH_CONF%" ^ -Des.path.conf="%ES_PATH_CONF%" ^
-Des.distribution.flavor="%ES_DISTRIBUTION_FLAVOR%" ^
-Des.distribution.type="%ES_DISTRIBUTION_TYPE%" ^ -Des.distribution.type="%ES_DISTRIBUTION_TYPE%" ^
-cp "%ES_CLASSPATH%" ^ -cp "%ES_CLASSPATH%" ^
"%ES_MAIN_CLASS%" ^ "%ES_MAIN_CLASS%" ^

View File

@ -88,7 +88,6 @@ fi
# now make ES_PATH_CONF absolute # now make ES_PATH_CONF absolute
ES_PATH_CONF=`cd "$ES_PATH_CONF"; pwd` ES_PATH_CONF=`cd "$ES_PATH_CONF"; pwd`
ES_DISTRIBUTION_FLAVOR=${es.distribution.flavor}
ES_DISTRIBUTION_TYPE=${es.distribution.type} ES_DISTRIBUTION_TYPE=${es.distribution.type}
ES_BUNDLED_JDK=${es.bundled_jdk} ES_BUNDLED_JDK=${es.bundled_jdk}

View File

@ -25,7 +25,6 @@ if not defined ES_PATH_CONF (
rem now make ES_PATH_CONF absolute rem now make ES_PATH_CONF absolute
for %%I in ("%ES_PATH_CONF%..") do set ES_PATH_CONF=%%~dpfI for %%I in ("%ES_PATH_CONF%..") do set ES_PATH_CONF=%%~dpfI
set ES_DISTRIBUTION_FLAVOR=${es.distribution.flavor}
set ES_DISTRIBUTION_TYPE=${es.distribution.type} set ES_DISTRIBUTION_TYPE=${es.distribution.type}
set ES_BUNDLED_JDK=${es.bundled_jdk} set ES_BUNDLED_JDK=${es.bundled_jdk}

View File

@ -194,7 +194,7 @@ if "%JVM_SS%" == "" (
set OTHER_JAVA_OPTS=%OTHER_JAVA_OPTS:"=% set OTHER_JAVA_OPTS=%OTHER_JAVA_OPTS:"=%
set OTHER_JAVA_OPTS=%OTHER_JAVA_OPTS:~1% set OTHER_JAVA_OPTS=%OTHER_JAVA_OPTS:~1%
set ES_PARAMS=-Delasticsearch;-Des.path.home="%ES_HOME%";-Des.path.conf="%ES_PATH_CONF%";-Des.distribution.flavor="%ES_DISTRIBUTION_FLAVOR%";-Des.distribution.type="%ES_DISTRIBUTION_TYPE%";-Des.bundled_jdk="%ES_BUNDLED_JDK%" set ES_PARAMS=-Delasticsearch;-Des.path.home="%ES_HOME%";-Des.path.conf="%ES_PATH_CONF%";-Des.distribution.type="%ES_DISTRIBUTION_TYPE%";-Des.bundled_jdk="%ES_BUNDLED_JDK%"
if "%ES_START_TYPE%" == "" set ES_START_TYPE=manual if "%ES_START_TYPE%" == "" set ES_START_TYPE=manual
if "%ES_STOP_TIMEOUT%" == "" set ES_STOP_TIMEOUT=0 if "%ES_STOP_TIMEOUT%" == "" set ES_STOP_TIMEOUT=0

View File

@ -99,7 +99,6 @@ SET KEYSTORE_PASSWORD=!KEYSTORE_PASSWORD:^\=^^^\!
ECHO.!KEYSTORE_PASSWORD!| %JAVA% %ES_JAVA_OPTS% -Delasticsearch ^ ECHO.!KEYSTORE_PASSWORD!| %JAVA% %ES_JAVA_OPTS% -Delasticsearch ^
-Des.path.home="%ES_HOME%" -Des.path.conf="%ES_PATH_CONF%" ^ -Des.path.home="%ES_HOME%" -Des.path.conf="%ES_PATH_CONF%" ^
-Des.distribution.flavor="%ES_DISTRIBUTION_FLAVOR%" ^
-Des.distribution.type="%ES_DISTRIBUTION_TYPE%" ^ -Des.distribution.type="%ES_DISTRIBUTION_TYPE%" ^
-Des.bundled_jdk="%ES_BUNDLED_JDK%" ^ -Des.bundled_jdk="%ES_BUNDLED_JDK%" ^
-cp "%ES_CLASSPATH%" "org.elasticsearch.bootstrap.Elasticsearch" !newparams! -cp "%ES_CLASSPATH%" "org.elasticsearch.bootstrap.Elasticsearch" !newparams!

View File

@ -29,7 +29,6 @@ apply plugin:'elasticsearch.internal-distribution-download'
elasticsearch_distributions { elasticsearch_distributions {
local { local {
flavor = 'default'
type = 'archive' type = 'archive'
architecture = Architecture.current() architecture = Architecture.current()
} }

View File

@ -339,12 +339,6 @@ public class ArchiveTests extends PackagingTestCase {
final Result result = sh.run(bin.shardTool + " -h"); final Result result = sh.run(bin.shardTool + " -h");
assertThat(result.stdout, containsString("A CLI tool to remove corrupted parts of unrecoverable shards")); assertThat(result.stdout, containsString("A CLI tool to remove corrupted parts of unrecoverable shards"));
}; };
// TODO: this should be checked on all distributions
if (distribution().isDefault()) {
Platforms.onLinux(action);
Platforms.onWindows(action);
}
} }
public void test92ElasticsearchNodeCliPackaging() throws Exception { public void test92ElasticsearchNodeCliPackaging() throws Exception {
@ -354,12 +348,6 @@ public class ArchiveTests extends PackagingTestCase {
final Result result = sh.run(bin.nodeTool + " -h"); final Result result = sh.run(bin.nodeTool + " -h");
assertThat(result.stdout, containsString("A CLI tool to do unsafe cluster and index manipulations on current node")); assertThat(result.stdout, containsString("A CLI tool to do unsafe cluster and index manipulations on current node"));
}; };
// TODO: this should be checked on all distributions
if (distribution().isDefault()) {
Platforms.onLinux(action);
Platforms.onWindows(action);
}
} }
public void test93ElasticsearchNodeCustomDataPathAndNotEsHomeWorkDir() throws Exception { public void test93ElasticsearchNodeCustomDataPathAndNotEsHomeWorkDir() throws Exception {

View File

@ -52,12 +52,5 @@ public class DebMetadataTests extends PackagingTestCase {
final Shell.Result result = sh.run("dpkg -I " + getDistributionFile(distribution())); final Shell.Result result = sh.run("dpkg -I " + getDistributionFile(distribution()));
TestCase.assertTrue(Pattern.compile("(?m)^ Depends:.*bash.*").matcher(result.stdout).find()); TestCase.assertTrue(Pattern.compile("(?m)^ Depends:.*bash.*").matcher(result.stdout).find());
String oppositePackageName = "elasticsearch";
if (distribution().isDefault()) {
oppositePackageName += "-oss";
}
TestCase.assertTrue(Pattern.compile("(?m)^ Conflicts: " + oppositePackageName + "$").matcher(result.stdout).find());
} }
} }

View File

@ -32,10 +32,8 @@ import static org.elasticsearch.packaging.util.Packages.SYSVINIT_SCRIPT;
import static org.elasticsearch.packaging.util.Packages.assertInstalled; import static org.elasticsearch.packaging.util.Packages.assertInstalled;
import static org.elasticsearch.packaging.util.Packages.assertRemoved; import static org.elasticsearch.packaging.util.Packages.assertRemoved;
import static org.elasticsearch.packaging.util.Packages.installPackage; import static org.elasticsearch.packaging.util.Packages.installPackage;
import static org.elasticsearch.packaging.util.Packages.packageStatus;
import static org.elasticsearch.packaging.util.Packages.remove; import static org.elasticsearch.packaging.util.Packages.remove;
import static org.elasticsearch.packaging.util.Packages.verifyPackageInstallation; import static org.elasticsearch.packaging.util.Packages.verifyPackageInstallation;
import static org.hamcrest.core.Is.is;
import static org.junit.Assume.assumeTrue; import static org.junit.Assume.assumeTrue;
public class DebPreservationTests extends PackagingTestCase { public class DebPreservationTests extends PackagingTestCase {
@ -67,43 +65,14 @@ public class DebPreservationTests extends PackagingTestCase {
installation.config(Paths.get("jvm.options.d", "heap.options")) installation.config(Paths.get("jvm.options.d", "heap.options"))
); );
if (distribution().isDefault()) {
assertPathsExist(
installation.config,
installation.config("role_mapping.yml"),
installation.config("roles.yml"),
installation.config("users"),
installation.config("users_roles")
);
}
// keystore was removed // keystore was removed
assertPathsDoNotExist(installation.config("elasticsearch.keystore"), installation.config(".elasticsearch.keystore.initial_md5sum")); assertPathsDoNotExist(installation.config("elasticsearch.keystore"), installation.config(".elasticsearch.keystore.initial_md5sum"));
// doc files were removed
assertPathsDoNotExist(
Paths.get("/usr/share/doc/" + distribution().flavor.name),
Paths.get("/usr/share/doc/" + distribution().flavor.name + "/copyright")
);
// sysvinit service file was not removed // sysvinit service file was not removed
assertThat(SYSVINIT_SCRIPT, fileExists()); assertThat(SYSVINIT_SCRIPT, fileExists());
// defaults file was not removed // defaults file was not removed
assertThat(installation.envFile, fileExists()); assertThat(installation.envFile, fileExists());
} }
public void test30Purge() throws Exception {
append(installation.config(Paths.get("jvm.options.d", "heap.options")), "# foo");
sh.run("dpkg --purge " + distribution().flavor.name);
assertRemoved(distribution());
assertPathsDoNotExist(installation.config, installation.envFile, SYSVINIT_SCRIPT);
assertThat(packageStatus(distribution()).exitCode, is(1));
}
} }

View File

@ -20,8 +20,6 @@
package org.elasticsearch.packaging.test; package org.elasticsearch.packaging.test;
import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.JsonNode;
import org.apache.http.client.fluent.Request;
import org.elasticsearch.packaging.util.Distribution;
import org.elasticsearch.packaging.util.Installation; import org.elasticsearch.packaging.util.Installation;
import org.elasticsearch.packaging.util.Platforms; import org.elasticsearch.packaging.util.Platforms;
import org.elasticsearch.packaging.util.ServerUtils; import org.elasticsearch.packaging.util.ServerUtils;
@ -59,10 +57,8 @@ import static org.elasticsearch.packaging.util.Docker.waitForElasticsearch;
import static org.elasticsearch.packaging.util.FileMatcher.p600; import static org.elasticsearch.packaging.util.FileMatcher.p600;
import static org.elasticsearch.packaging.util.FileMatcher.p644; import static org.elasticsearch.packaging.util.FileMatcher.p644;
import static org.elasticsearch.packaging.util.FileMatcher.p660; import static org.elasticsearch.packaging.util.FileMatcher.p660;
import static org.elasticsearch.packaging.util.FileMatcher.p775;
import static org.elasticsearch.packaging.util.FileUtils.append; import static org.elasticsearch.packaging.util.FileUtils.append;
import static org.elasticsearch.packaging.util.FileUtils.rm; import static org.elasticsearch.packaging.util.FileUtils.rm;
import static org.hamcrest.Matchers.arrayContaining;
import static org.hamcrest.Matchers.arrayWithSize; import static org.hamcrest.Matchers.arrayWithSize;
import static org.hamcrest.Matchers.containsString; import static org.hamcrest.Matchers.containsString;
import static org.hamcrest.Matchers.emptyString; import static org.hamcrest.Matchers.emptyString;
@ -253,85 +249,6 @@ public class DockerTests extends PackagingTestCase {
waitForElasticsearch(installation); waitForElasticsearch(installation);
} }
/**
* Check that the elastic user's password can be configured via a file and the ELASTIC_PASSWORD_FILE environment variable.
*/
public void test080ConfigurePasswordThroughEnvironmentVariableFile() throws Exception {
// Test relies on configuring security
assumeTrue(distribution.isDefault());
final String xpackPassword = "hunter2";
final String passwordFilename = "password.txt";
append(tempDir.resolve(passwordFilename), xpackPassword + "\n");
Map<String, String> envVars = new HashMap<>();
envVars.put("ELASTIC_PASSWORD_FILE", "/run/secrets/" + passwordFilename);
// File permissions need to be secured in order for the ES wrapper to accept
// them for populating env var values
Files.setPosixFilePermissions(tempDir.resolve(passwordFilename), p600);
// But when running in Vagrant, also ensure ES can actually access the file
chownWithPrivilegeEscalation(tempDir.resolve(passwordFilename), "1000:0");
final Map<Path, Path> volumes = singletonMap(tempDir, Paths.get("/run/secrets"));
// Restart the container
runContainer(distribution(), volumes, envVars);
// If we configured security correctly, then this call will only work if we specify the correct credentials.
try {
waitForElasticsearch("green", null, installation, "elastic", "hunter2");
} catch (Exception e) {
throw new AssertionError(
"Failed to check whether Elasticsearch had started. This could be because "
+ "authentication isn't working properly. Check the container logs",
e
);
}
// Also check that an unauthenticated call fails
final int statusCode = Request.Get("http://localhost:9200/_nodes").execute().returnResponse().getStatusLine().getStatusCode();
assertThat("Expected server to require authentication", statusCode, equalTo(401));
}
/**
* Check that when verifying the file permissions of _FILE environment variables, symlinks
* are followed.
*/
public void test081SymlinksAreFollowedWithEnvironmentVariableFiles() throws Exception {
// Test relies on configuring security
assumeTrue(distribution.isDefault());
// Test relies on symlinks
assumeFalse(Platforms.WINDOWS);
final String xpackPassword = "hunter2";
final String passwordFilename = "password.txt";
final String symlinkFilename = "password_symlink";
// ELASTIC_PASSWORD_FILE
Files.write(tempDir.resolve(passwordFilename), (xpackPassword + "\n").getBytes(StandardCharsets.UTF_8));
// Link to the password file. We can't use an absolute path for the target, because
// it won't resolve inside the container.
Files.createSymbolicLink(tempDir.resolve(symlinkFilename), Paths.get(passwordFilename));
// Enable security so that we can test that the password has been used
Map<String, String> envVars = new HashMap<>();
envVars.put("ELASTIC_PASSWORD_FILE", "/run/secrets/" + symlinkFilename);
// File permissions need to be secured in order for the ES wrapper to accept
// them for populating env var values. The wrapper will resolve the symlink
// and check the target's permissions.
Files.setPosixFilePermissions(tempDir.resolve(passwordFilename), p600);
final Map<Path, Path> volumes = singletonMap(tempDir, Paths.get("/run/secrets"));
// Restart the container - this will check that Elasticsearch started correctly,
// and didn't fail to follow the symlink and check the file permissions
runContainer(distribution(), volumes, envVars);
}
/** /**
* Check that environment variables cannot be used with _FILE environment variables. * Check that environment variables cannot be used with _FILE environment variables.
*/ */
@ -385,70 +302,6 @@ public class DockerTests extends PackagingTestCase {
); );
} }
/**
* Check that when verifying the file permissions of _FILE environment variables, symlinks
* are followed, and that invalid target permissions are detected.
*/
public void test084SymlinkToFileWithInvalidPermissionsIsRejected() throws Exception {
// Test relies on configuring security
assumeTrue(distribution.isDefault());
// Test relies on symlinks
assumeFalse(Platforms.WINDOWS);
final String xpackPassword = "hunter2";
final String passwordFilename = "password.txt";
final String symlinkFilename = "password_symlink";
// ELASTIC_PASSWORD_FILE
Files.write(tempDir.resolve(passwordFilename), (xpackPassword + "\n").getBytes(StandardCharsets.UTF_8));
// Link to the password file. We can't use an absolute path for the target, because
// it won't resolve inside the container.
Files.createSymbolicLink(tempDir.resolve(symlinkFilename), Paths.get(passwordFilename));
// Enable security so that we can test that the password has been used
Map<String, String> envVars = new HashMap<>();
envVars.put("ELASTIC_PASSWORD_FILE", "/run/secrets/" + symlinkFilename);
// Set invalid permissions on the file that the symlink targets
Files.setPosixFilePermissions(tempDir.resolve(passwordFilename), p775);
final Map<Path, Path> volumes = singletonMap(tempDir, Paths.get("/run/secrets"));
// Restart the container
final Result dockerLogs = runContainerExpectingFailure(distribution(), volumes, envVars);
assertThat(
dockerLogs.stderr,
containsString(
"ERROR: File "
+ passwordFilename
+ " (target of symlink /run/secrets/"
+ symlinkFilename
+ " from ELASTIC_PASSWORD_FILE) must have file permissions 400 or 600, but actually has: 775"
)
);
}
/**
* Check that environment variables are translated to -E options even for commands invoked under
* `docker exec`, where the Docker image's entrypoint is not executed.
*/
@AwaitsFix(bugUrl = "https://github.com/elastic/elasticsearch/issues/67097")
public void test085EnvironmentVariablesAreRespectedUnderDockerExec() {
// This test relies on a CLI tool attempting to connect to Elasticsearch, and the
// tool in question is only in the default distribution.
assumeTrue(distribution.isDefault());
runContainer(distribution(), null, singletonMap("http.host", "this.is.not.valid"));
// This will fail if the env var above is passed as a -E argument
final Result result = sh.runIgnoreExitCode("elasticsearch-setup-passwords auto");
assertFalse("elasticsearch-setup-passwords command should have failed", result.isSuccess());
assertThat(result.stdout, containsString("java.net.UnknownHostException: this.is.not.valid: Name or service not known"));
}
/** /**
* Check that the elasticsearch-shard tool is shipped in the Docker image and is executable. * Check that the elasticsearch-shard tool is shipped in the Docker image and is executable.
*/ */
@ -513,11 +366,7 @@ public class DockerTests extends PackagingTestCase {
staticLabels.put("vcs-url", "https://github.com/elastic/elasticsearch"); staticLabels.put("vcs-url", "https://github.com/elastic/elasticsearch");
staticLabels.put("vendor", "Elastic"); staticLabels.put("vendor", "Elastic");
if (distribution.isOSS()) { staticLabels.put("license", "Apache-2.0");
staticLabels.put("license", "Apache-2.0");
} else {
staticLabels.put("license", "Elastic-License");
}
// TODO: we should check the actual version value // TODO: we should check the actual version value
final Set<String> dynamicLabels = new HashSet<>(); final Set<String> dynamicLabels = new HashSet<>();
@ -553,11 +402,7 @@ public class DockerTests extends PackagingTestCase {
staticLabels.put("source", "https://github.com/elastic/elasticsearch"); staticLabels.put("source", "https://github.com/elastic/elasticsearch");
staticLabels.put("vendor", "Elastic"); staticLabels.put("vendor", "Elastic");
if (distribution.isOSS()) { staticLabels.put("licenses", "Apache-2.0");
staticLabels.put("licenses", "Apache-2.0");
} else {
staticLabels.put("licenses", "Elastic-License");
}
// TODO: we should check the actual version value // TODO: we should check the actual version value
final Set<String> dynamicLabels = new HashSet<>(); final Set<String> dynamicLabels = new HashSet<>();
@ -644,46 +489,4 @@ public class DockerTests extends PackagingTestCase {
assertThat("Failed to find [cpu] in node OS cgroup stats", cgroupStats.get("cpu"), not(nullValue())); assertThat("Failed to find [cpu] in node OS cgroup stats", cgroupStats.get("cpu"), not(nullValue()));
assertThat("Failed to find [cpuacct] in node OS cgroup stats", cgroupStats.get("cpuacct"), not(nullValue())); assertThat("Failed to find [cpuacct] in node OS cgroup stats", cgroupStats.get("cpuacct"), not(nullValue()));
} }
/**
* Check that the UBI images has the correct license information in the correct place.
*/
public void test200UbiImagesHaveLicenseDirectory() {
assumeTrue(distribution.packaging == Distribution.Packaging.DOCKER_UBI);
final String[] files = sh.run("find /licenses -type f").stdout.split("\n");
assertThat(files, arrayContaining("/licenses/LICENSE"));
// UBI image doesn't contain `diff`
final String ubiLicense = sh.run("cat /licenses/LICENSE").stdout;
final String distroLicense = sh.run("cat /usr/share/elasticsearch/LICENSE.txt").stdout;
assertThat(ubiLicense, equalTo(distroLicense));
}
/**
* Check that the UBI image has the expected labels
*/
public void test210UbiLabels() throws Exception {
assumeTrue(distribution.packaging == Distribution.Packaging.DOCKER_UBI);
final Map<String, String> labels = getImageLabels(distribution);
final Map<String, String> staticLabels = new HashMap<>();
staticLabels.put("name", "Elasticsearch");
staticLabels.put("maintainer", "infra@elastic.co");
staticLabels.put("vendor", "Elastic");
staticLabels.put("summary", "Elasticsearch");
staticLabels.put("description", "You know, for search.");
final Set<String> dynamicLabels = new HashSet<>();
dynamicLabels.add("release");
dynamicLabels.add("version");
staticLabels.forEach((key, value) -> {
assertThat(labels, hasKey(key));
assertThat(labels.get(key), equalTo(value));
});
dynamicLabels.forEach(key -> assertThat(labels, hasKey(key)));
}
} }

View File

@ -491,7 +491,6 @@ public class KeystoreManagementTests extends PackagingTestCase {
assertThat(keystore, file(File, "root", "elasticsearch", p660)); assertThat(keystore, file(File, "root", "elasticsearch", p660));
break; break;
case DOCKER: case DOCKER:
case DOCKER_UBI:
assertPermissionsAndOwnership(keystore, p660); assertPermissionsAndOwnership(keystore, p660);
break; break;
default: default:

View File

@ -220,7 +220,6 @@ public abstract class PackagingTestCase extends Assert {
Packages.verifyPackageInstallation(installation, distribution, sh); Packages.verifyPackageInstallation(installation, distribution, sh);
break; break;
case DOCKER: case DOCKER:
case DOCKER_UBI:
installation = Docker.runContainer(distribution); installation = Docker.runContainer(distribution);
Docker.verifyContainerInstallation(installation, distribution); Docker.verifyContainerInstallation(installation, distribution);
break; break;
@ -296,7 +295,6 @@ public abstract class PackagingTestCase extends Assert {
case RPM: case RPM:
return Packages.runElasticsearchStartCommand(sh); return Packages.runElasticsearchStartCommand(sh);
case DOCKER: case DOCKER:
case DOCKER_UBI:
// nothing, "installing" docker image is running it // nothing, "installing" docker image is running it
return Shell.NO_OP; return Shell.NO_OP;
default: default:
@ -315,7 +313,6 @@ public abstract class PackagingTestCase extends Assert {
Packages.stopElasticsearch(sh); Packages.stopElasticsearch(sh);
break; break;
case DOCKER: case DOCKER:
case DOCKER_UBI:
// nothing, "installing" docker image is running it // nothing, "installing" docker image is running it
break; break;
default: default:
@ -335,7 +332,6 @@ public abstract class PackagingTestCase extends Assert {
Packages.assertElasticsearchStarted(sh, installation); Packages.assertElasticsearchStarted(sh, installation);
break; break;
case DOCKER: case DOCKER:
case DOCKER_UBI:
Docker.waitForElasticsearchToStart(); Docker.waitForElasticsearchToStart();
break; break;
default: default:

View File

@ -48,12 +48,5 @@ public class RpmMetadataTests extends PackagingTestCase {
TestCase.assertTrue(Pattern.compile("(?m)^/bin/bash\\s*$").matcher(deps.stdout).find()); TestCase.assertTrue(Pattern.compile("(?m)^/bin/bash\\s*$").matcher(deps.stdout).find());
final Shell.Result conflicts = sh.run("rpm -qp --conflicts " + getDistributionFile(distribution())); final Shell.Result conflicts = sh.run("rpm -qp --conflicts " + getDistributionFile(distribution()));
String oppositePackageName = "elasticsearch";
if (distribution().isDefault()) {
oppositePackageName += "-oss";
}
TestCase.assertTrue(Pattern.compile("(?m)^" + oppositePackageName + "\\s*$").matcher(conflicts.stdout).find());
} }
} }

View File

@ -82,11 +82,6 @@ public class RpmPreservationTests extends PackagingTestCase {
.map(each -> installation.config(each)) .map(each -> installation.config(each))
.forEach(path -> append(path, "# foo")); .forEach(path -> append(path, "# foo"));
append(installation.config(Paths.get("jvm.options.d", "heap.options")), "# foo"); append(installation.config(Paths.get("jvm.options.d", "heap.options")), "# foo");
if (distribution().isDefault()) {
Stream.of("role_mapping.yml", "roles.yml", "users", "users_roles")
.map(each -> installation.config(each))
.forEach(path -> append(path, "# foo"));
}
remove(distribution()); remove(distribution());
assertRemoved(distribution()); assertRemoved(distribution());
@ -112,10 +107,6 @@ public class RpmPreservationTests extends PackagingTestCase {
Stream.of("elasticsearch.yml", "jvm.options", "log4j2.properties").forEach(this::assertConfFilePreserved); Stream.of("elasticsearch.yml", "jvm.options", "log4j2.properties").forEach(this::assertConfFilePreserved);
assertThat(installation.config(Paths.get("jvm.options.d", "heap.options")), fileExists()); assertThat(installation.config(Paths.get("jvm.options.d", "heap.options")), fileExists());
if (distribution().isDefault()) {
Stream.of("role_mapping.yml", "roles.yml", "users", "users_roles").forEach(this::assertConfFilePreserved);
}
} }
private void assertConfFilePreserved(String configFile) { private void assertConfFilePreserved(String configFile) {

View File

@ -27,7 +27,6 @@ public class Distribution {
public final Path path; public final Path path;
public final Packaging packaging; public final Packaging packaging;
public final Platform platform; public final Platform platform;
public final Flavor flavor;
public final boolean hasJdk; public final boolean hasJdk;
public final String version; public final String version;
@ -39,15 +38,12 @@ public class Distribution {
this.packaging = Packaging.TAR; this.packaging = Packaging.TAR;
} else if (filename.endsWith(".docker.tar")) { } else if (filename.endsWith(".docker.tar")) {
this.packaging = Packaging.DOCKER; this.packaging = Packaging.DOCKER;
} else if (filename.endsWith(".ubi.tar")) {
this.packaging = Packaging.DOCKER_UBI;
} else { } else {
int lastDot = filename.lastIndexOf('.'); int lastDot = filename.lastIndexOf('.');
this.packaging = Packaging.valueOf(filename.substring(lastDot + 1).toUpperCase(Locale.ROOT)); this.packaging = Packaging.valueOf(filename.substring(lastDot + 1).toUpperCase(Locale.ROOT));
} }
this.platform = filename.contains("windows") ? Platform.WINDOWS : Platform.LINUX; this.platform = filename.contains("windows") ? Platform.WINDOWS : Platform.LINUX;
this.flavor = filename.contains("oss") ? Flavor.OSS : Flavor.DEFAULT;
this.hasJdk = filename.contains("no-jdk") == false; this.hasJdk = filename.contains("no-jdk") == false;
String version = filename.split("-", 3)[1]; String version = filename.split("-", 3)[1];
if (filename.contains("-SNAPSHOT")) { if (filename.contains("-SNAPSHOT")) {
@ -56,14 +52,6 @@ public class Distribution {
this.version = version; this.version = version;
} }
public boolean isDefault() {
return flavor.equals(Flavor.DEFAULT);
}
public boolean isOSS() {
return flavor.equals(Flavor.OSS);
}
public boolean isArchive() { public boolean isArchive() {
return packaging == Packaging.TAR || packaging == Packaging.ZIP; return packaging == Packaging.TAR || packaging == Packaging.ZIP;
} }
@ -73,7 +61,7 @@ public class Distribution {
} }
public boolean isDocker() { public boolean isDocker() {
return packaging == Packaging.DOCKER || packaging == Packaging.DOCKER_UBI; return packaging == Packaging.DOCKER;
} }
public enum Packaging { public enum Packaging {
@ -82,8 +70,7 @@ public class Distribution {
ZIP(".zip", Platforms.WINDOWS), ZIP(".zip", Platforms.WINDOWS),
DEB(".deb", Platforms.isDPKG()), DEB(".deb", Platforms.isDPKG()),
RPM(".rpm", Platforms.isRPM()), RPM(".rpm", Platforms.isRPM()),
DOCKER(".docker.tar", Platforms.isDocker()), DOCKER(".docker.tar", Platforms.isDocker());
DOCKER_UBI(".ubi.tar", Platforms.isDocker());
/** The extension of this distribution's file */ /** The extension of this distribution's file */
public final String extension; public final String extension;
@ -106,16 +93,4 @@ public class Distribution {
return name().toLowerCase(Locale.ROOT); return name().toLowerCase(Locale.ROOT);
} }
} }
public enum Flavor {
OSS("elasticsearch-oss"),
DEFAULT("elasticsearch");
public final String name;
Flavor(String name) {
this.name = name;
}
}
} }

View File

@ -586,6 +586,6 @@ public class Docker {
} }
public static String getImageName(Distribution distribution) { public static String getImageName(Distribution distribution) {
return distribution.flavor.name + (distribution.packaging == Distribution.Packaging.DOCKER_UBI ? "-ubi8" : "") + ":test"; return ":test";
} }
} }

View File

@ -124,9 +124,7 @@ public class Packages {
} }
private static Result runPackageManager(Distribution distribution, Shell sh, PackageManagerCommand command) { private static Result runPackageManager(Distribution distribution, Shell sh, PackageManagerCommand command) {
final String distributionArg = command == PackageManagerCommand.QUERY || command == PackageManagerCommand.REMOVE final String distributionArg = distribution.path.toString();
? distribution.flavor.name
: distribution.path.toString();
if (Platforms.isRPM()) { if (Platforms.isRPM()) {
String rpmOptions = RPM_OPTIONS.get(command); String rpmOptions = RPM_OPTIONS.get(command);
@ -204,7 +202,7 @@ public class Packages {
if (distribution.packaging == Distribution.Packaging.RPM) { if (distribution.packaging == Distribution.Packaging.RPM) {
assertThat(es.home.resolve("LICENSE.txt"), file(File, "root", "root", p644)); assertThat(es.home.resolve("LICENSE.txt"), file(File, "root", "root", p644));
} else { } else {
Path copyrightDir = Paths.get(sh.run("readlink -f /usr/share/doc/" + distribution.flavor.name).stdout.trim()); Path copyrightDir = Paths.get(sh.run("readlink -f /usr/share/doc/").stdout.trim());
assertThat(copyrightDir, file(Directory, "root", "root", p755)); assertThat(copyrightDir, file(Directory, "root", "root", p755));
assertThat(copyrightDir.resolve("copyright"), file(File, "root", "root", p644)); assertThat(copyrightDir.resolve("copyright"), file(File, "root", "root", p644));
} }

View File

@ -35,7 +35,6 @@ elasticsearch_distributions {
docker { docker {
type = 'docker' type = 'docker'
architecture = Architecture.current() architecture = Architecture.current()
flavor = System.getProperty('tests.distribution', 'default')
version = VersionProperties.getElasticsearch() version = VersionProperties.getElasticsearch()
failIfUnavailable = false // This ensures we skip this testing if Docker is unavailable failIfUnavailable = false // This ensures we skip this testing if Docker is unavailable
} }
@ -62,11 +61,7 @@ preProcessFixture {
dockerCompose { dockerCompose {
tcpPortsToIgnoreWhenWaiting = [9600, 9601] tcpPortsToIgnoreWhenWaiting = [9600, 9601]
if ('default'.equalsIgnoreCase(System.getProperty('tests.distribution', 'default'))) { useComposeFiles = ['docker-compose-oss.yml']
useComposeFiles = ['docker-compose.yml']
} else {
useComposeFiles = ['docker-compose-oss.yml']
}
} }
def createAndSetWritable(Object... locations) { def createAndSetWritable(Object... locations) {

View File

@ -24,11 +24,8 @@ import org.elasticsearch.action.admin.cluster.health.ClusterHealthRequest;
import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient; import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.common.CharArrays;
import org.elasticsearch.common.io.PathUtils; import org.elasticsearch.common.io.PathUtils;
import org.elasticsearch.common.settings.SecureString;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.util.concurrent.ThreadContext;
import org.elasticsearch.core.internal.io.IOUtils; import org.elasticsearch.core.internal.io.IOUtils;
import org.elasticsearch.test.rest.ESRestTestCase; import org.elasticsearch.test.rest.ESRestTestCase;
import org.junit.AfterClass; import org.junit.AfterClass;
@ -37,19 +34,12 @@ import org.junit.BeforeClass;
import java.io.IOException; import java.io.IOException;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.nio.CharBuffer;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.Arrays;
import java.util.Base64;
import java.util.Collections; import java.util.Collections;
public abstract class AbstractMultiClusterRemoteTestCase extends ESRestTestCase { public abstract class AbstractMultiClusterRemoteTestCase extends ESRestTestCase {
private static final String USER = "x_pack_rest_user";
private static final String PASS = "x-pack-test-password";
private static final String KEYSTORE_PASS = "testnode";
@Override @Override
protected boolean preserveClusterUponCompletion() { protected boolean preserveClusterUponCompletion() {
return true; return true;
@ -62,7 +52,7 @@ public abstract class AbstractMultiClusterRemoteTestCase extends ESRestTestCase
@Override @Override
protected String getTestRestCluster() { protected String getTestRestCluster() {
return "localhost:" + getProperty("test.fixtures.elasticsearch-" + getDistribution() + "-1.tcp.9200"); return "localhost:" + getProperty("test.fixtures.elasticsearch-oss-1.tcp.9200");
} }
@Before @Before
@ -71,8 +61,8 @@ public abstract class AbstractMultiClusterRemoteTestCase extends ESRestTestCase
return; return;
} }
cluster1Client = buildClient("localhost:" + getProperty("test.fixtures.elasticsearch-" + getDistribution() + "-1.tcp.9200")); cluster1Client = buildClient("localhost:" + getProperty("test.fixtures.elasticsearch-oss-1.tcp.9200"));
cluster2Client = buildClient("localhost:" + getProperty("test.fixtures.elasticsearch-" + getDistribution() + "-2.tcp.9200")); cluster2Client = buildClient("localhost:" + getProperty("test.fixtures.elasticsearch-oss-2.tcp.9200"));
cluster1Client().cluster().health(new ClusterHealthRequest().waitForNodes("1").waitForYellowStatus(), RequestOptions.DEFAULT); cluster1Client().cluster().health(new ClusterHealthRequest().waitForNodes("1").waitForYellowStatus(), RequestOptions.DEFAULT);
cluster2Client().cluster().health(new ClusterHealthRequest().waitForNodes("1").waitForYellowStatus(), RequestOptions.DEFAULT); cluster2Client().cluster().health(new ClusterHealthRequest().waitForNodes("1").waitForYellowStatus(), RequestOptions.DEFAULT);
@ -80,13 +70,6 @@ public abstract class AbstractMultiClusterRemoteTestCase extends ESRestTestCase
initialized = true; initialized = true;
} }
protected String getDistribution() {
String distribution = System.getProperty("tests.distribution", "default");
if (distribution.equals("oss") == false && distribution.equals("default") == false) {
throw new IllegalArgumentException("supported values for tests.distribution are oss or default but it was " + distribution);
}
return distribution;
}
@AfterClass @AfterClass
public static void destroyClients() throws IOException { public static void destroyClients() throws IOException {
@ -119,10 +102,6 @@ public abstract class AbstractMultiClusterRemoteTestCase extends ESRestTestCase
return new HighLevelClient(buildClient(restAdminSettings(), new HttpHost[]{httpHost})); return new HighLevelClient(buildClient(restAdminSettings(), new HttpHost[]{httpHost}));
} }
protected boolean isOss() {
return getDistribution().equals("oss");
}
static Path keyStore; static Path keyStore;
@BeforeClass @BeforeClass
@ -144,41 +123,12 @@ public abstract class AbstractMultiClusterRemoteTestCase extends ESRestTestCase
@Override @Override
protected Settings restClientSettings() { protected Settings restClientSettings() {
if (isOss()) { return super.restClientSettings();
return super.restClientSettings();
}
String token = basicAuthHeaderValue(USER, new SecureString(PASS.toCharArray()));
return Settings.builder()
.put(ThreadContext.PREFIX + ".Authorization", token)
.put(ESRestTestCase.TRUSTSTORE_PATH, keyStore)
.put(ESRestTestCase.TRUSTSTORE_PASSWORD, KEYSTORE_PASS)
.build();
} }
@Override @Override
protected String getProtocol() { protected String getProtocol() {
if (isOss()) { return "http";
return "http";
}
return "https";
}
private static String basicAuthHeaderValue(String username, SecureString passwd) {
CharBuffer chars = CharBuffer.allocate(username.length() + passwd.length() + 1);
byte[] charBytes = null;
try {
chars.put(username).put(':').put(passwd.getChars());
charBytes = CharArrays.toUtf8Bytes(chars.array());
//TODO we still have passwords in Strings in headers. Maybe we can look into using a CharSequence?
String basicToken = Base64.getEncoder().encodeToString(charBytes);
return "Basic " + basicToken;
} finally {
Arrays.fill(chars.array(), (char) 0);
if (charBytes != null) {
Arrays.fill(charBytes, (byte) 0);
}
}
} }
private String getProperty(String key) { private String getProperty(String key) {

View File

@ -68,7 +68,7 @@ public class RemoteClustersIT extends AbstractMultiClusterRemoteTestCase {
} }
public void testProxyModeConnectionWorks() throws IOException { public void testProxyModeConnectionWorks() throws IOException {
String cluster2RemoteClusterSeed = "elasticsearch-" + getDistribution() + "-2:9300"; String cluster2RemoteClusterSeed = "elasticsearch-oss-2:9300";
logger.info("Configuring remote cluster [{}]", cluster2RemoteClusterSeed); logger.info("Configuring remote cluster [{}]", cluster2RemoteClusterSeed);
ClusterUpdateSettingsRequest request = new ClusterUpdateSettingsRequest().persistentSettings(Settings.builder() ClusterUpdateSettingsRequest request = new ClusterUpdateSettingsRequest().persistentSettings(Settings.builder()
.put("cluster.remote.cluster2.mode", "proxy") .put("cluster.remote.cluster2.mode", "proxy")
@ -85,7 +85,7 @@ public class RemoteClustersIT extends AbstractMultiClusterRemoteTestCase {
} }
public void testSniffModeConnectionFails() throws IOException { public void testSniffModeConnectionFails() throws IOException {
String cluster2RemoteClusterSeed = "elasticsearch-" + getDistribution() + "-2:9300"; String cluster2RemoteClusterSeed = "elasticsearch-oss-2:9300";
logger.info("Configuring remote cluster [{}]", cluster2RemoteClusterSeed); logger.info("Configuring remote cluster [{}]", cluster2RemoteClusterSeed);
ClusterUpdateSettingsRequest request = new ClusterUpdateSettingsRequest().persistentSettings(Settings.builder() ClusterUpdateSettingsRequest request = new ClusterUpdateSettingsRequest().persistentSettings(Settings.builder()
.put("cluster.remote.cluster2alt.mode", "sniff") .put("cluster.remote.cluster2alt.mode", "sniff")

View File

@ -39,11 +39,4 @@ integTest {
project.delete(repo) project.delete(repo)
repo.mkdirs() repo.mkdirs()
} }
if ('default'.equalsIgnoreCase(System.getProperty('tests.distribution', 'oss'))) {
systemProperty 'tests.rest.blacklist', [
'cat.templates/10_basic/No templates',
'cat.templates/10_basic/Sort templates',
'cat.templates/10_basic/Multiple template',
].join(',')
}
} }

View File

@ -26,9 +26,8 @@ apply plugin: 'elasticsearch.testclusters'
apply plugin: 'elasticsearch.standalone-test' apply plugin: 'elasticsearch.standalone-test'
apply from : "$rootDir/gradle/bwc-test.gradle" apply from : "$rootDir/gradle/bwc-test.gradle"
boolean isDefaultDistro = System.getProperty('tests.distribution', 'oss') == 'default'
for (Version bwcVersion : BuildParams.bwcVersions.indexCompatible) { for (Version bwcVersion : BuildParams.bwcVersions.indexCompatible) {
if (bwcVersion.before('6.3.0') && isDefaultDistro) { if (bwcVersion.before('6.3.0')) {
// explicitly running restart on the current node does not work in step 2 // explicitly running restart on the current node does not work in step 2
// below when plugins are installed, wihch is the case for x-pack as a plugin // below when plugins are installed, wihch is the case for x-pack as a plugin
// prior to 6.3.0 // prior to 6.3.0

View File

@ -57,7 +57,6 @@ elasticsearch_distributions {
docker { docker {
type = 'docker' type = 'docker'
architecture = Architecture.current() architecture = Architecture.current()
flavor = System.getProperty('tests.distribution', 'default')
version = VersionProperties.getElasticsearch() version = VersionProperties.getElasticsearch()
failIfUnavailable = false // This ensures we skip this testing if Docker is unavailable failIfUnavailable = false // This ensures we skip this testing if Docker is unavailable
} }
@ -68,11 +67,7 @@ preProcessFixture {
} }
dockerCompose { dockerCompose {
if ('default'.equalsIgnoreCase(System.getProperty('tests.distribution', 'default'))) { useComposeFiles = ['docker-compose-oss.yml']
useComposeFiles = ['docker-compose.yml']
} else {
useComposeFiles = ['docker-compose-oss.yml']
}
} }
tasks.register("integTest", Test) { tasks.register("integTest", Test) {

View File

@ -41,42 +41,6 @@ public class Build {
*/ */
public static final Build CURRENT; public static final Build CURRENT;
public enum Flavor {
DEFAULT("default"),
OSS("oss"),
UNKNOWN("unknown");
final String displayName;
Flavor(final String displayName) {
this.displayName = displayName;
}
public String displayName() {
return displayName;
}
public static Flavor fromDisplayName(final String displayName, final boolean strict) {
switch (displayName) {
case "default":
return Flavor.DEFAULT;
case "oss":
return Flavor.OSS;
case "unknown":
return Flavor.UNKNOWN;
default:
if (strict) {
final String message = "unexpected distribution flavor [" + displayName + "]; your distribution is broken";
throw new IllegalStateException(message);
} else {
return Flavor.UNKNOWN;
}
}
}
}
public enum Type { public enum Type {
DEB("deb"), DEB("deb"),
@ -122,7 +86,6 @@ public class Build {
} }
static { static {
final Flavor flavor;
final Type type; final Type type;
final String hash; final String hash;
final String date; final String date;
@ -130,7 +93,6 @@ public class Build {
final String version; final String version;
// these are parsed at startup, and we require that we are able to recognize the values passed in by the startup scripts // these are parsed at startup, and we require that we are able to recognize the values passed in by the startup scripts
flavor = Flavor.fromDisplayName(System.getProperty("es.distribution.flavor", "unknown"), true);
type = Type.fromDisplayName(System.getProperty("es.distribution.type", "unknown"), true); type = Type.fromDisplayName(System.getProperty("es.distribution.type", "unknown"), true);
final String esPrefix = "elasticsearch-" + Version.CURRENT; final String esPrefix = "elasticsearch-" + Version.CURRENT;
@ -180,7 +142,7 @@ public class Build {
"Stopping Elasticsearch now so it doesn't run in subtly broken ways. This is likely a build bug."); "Stopping Elasticsearch now so it doesn't run in subtly broken ways. This is likely a build bug.");
} }
CURRENT = new Build(flavor, type, hash, date, isSnapshot, version); CURRENT = new Build(type, hash, date, isSnapshot, version);
} }
private final boolean isSnapshot; private final boolean isSnapshot;
@ -195,17 +157,15 @@ public class Build {
return codeSource == null ? null : codeSource.getLocation(); return codeSource == null ? null : codeSource.getLocation();
} }
private final Flavor flavor;
private final Type type; private final Type type;
private final String hash; private final String hash;
private final String date; private final String date;
private final String version; private final String version;
public Build( public Build(
final Flavor flavor, final Type type, final String hash, final String date, boolean isSnapshot, final Type type, final String hash, final String date, boolean isSnapshot,
String version String version
) { ) {
this.flavor = flavor;
this.type = type; this.type = type;
this.hash = hash; this.hash = hash;
this.date = date; this.date = date;
@ -222,13 +182,12 @@ public class Build {
} }
public static Build readBuild(StreamInput in) throws IOException { public static Build readBuild(StreamInput in) throws IOException {
final Flavor flavor; final String flavor;
final Type type; final Type type;
if (in.getVersion().onOrAfter(Version.V_6_3_0)) { // The following block is kept for existing BWS tests to pass.
// be lenient when reading on the wire, the enumeration values from other versions might be different than what we know // TODO - clean up this code when we remove all v6 bwc tests.
flavor = Flavor.fromDisplayName(in.readString(), false); if (in.getVersion().onOrAfter(Version.V_6_3_0) && in.getVersion().onOrBefore(Version.V_7_0_0)) {
} else { flavor = in.readString();
flavor = Flavor.OSS;
} }
if (in.getVersion().onOrAfter(Version.V_6_3_0)) { if (in.getVersion().onOrAfter(Version.V_6_3_0)) {
// be lenient when reading on the wire, the enumeration values from other versions might be different than what we know // be lenient when reading on the wire, the enumeration values from other versions might be different than what we know
@ -246,12 +205,14 @@ public class Build {
} else { } else {
version = in.getVersion().toString(); version = in.getVersion().toString();
} }
return new Build(flavor, type, hash, date, snapshot, version); return new Build(type, hash, date, snapshot, version);
} }
public static void writeBuild(Build build, StreamOutput out) throws IOException { public static void writeBuild(Build build, StreamOutput out) throws IOException {
if (out.getVersion().onOrAfter(Version.V_6_3_0)) { // The following block is kept for existing BWS tests to pass.
out.writeString(build.flavor().displayName()); // TODO - clean up this code when we remove all v6 bwc tests.
if (out.getVersion().onOrAfter(Version.V_6_3_0) && out.getVersion().onOrBefore(Version.V_7_0_0)) {
out.writeString("oss");
} }
if (out.getVersion().onOrAfter(Version.V_6_3_0)) { if (out.getVersion().onOrAfter(Version.V_6_3_0)) {
final Type buildType; final Type buildType;
@ -283,10 +244,6 @@ public class Build {
return version; return version;
} }
public Flavor flavor() {
return flavor;
}
public Type type() { public Type type() {
return type; return type;
} }
@ -306,7 +263,7 @@ public class Build {
@Override @Override
public String toString() { public String toString() {
return "[" + flavor.displayName() + "][" + type.displayName + "][" + hash + "][" + date + "][" + version +"]"; return "[" + type.displayName + "][" + hash + "][" + date + "][" + version +"]";
} }
@Override @Override
@ -320,10 +277,6 @@ public class Build {
Build build = (Build) o; Build build = (Build) o;
if (!flavor.equals(build.flavor)) {
return false;
}
if (!type.equals(build.type)) { if (!type.equals(build.type)) {
return false; return false;
} }
@ -342,7 +295,7 @@ public class Build {
@Override @Override
public int hashCode() { public int hashCode() {
return Objects.hash(flavor, type, isSnapshot, hash, date, version); return Objects.hash(type, isSnapshot, hash, date, version);
} }
} }

View File

@ -484,7 +484,6 @@ public class Version implements Comparable<Version>, ToXContentFragment {
Locale.ROOT, Locale.ROOT,
"Version: %s, Build: %s/%s/%s/%s, JVM: %s", "Version: %s, Build: %s/%s/%s/%s, JVM: %s",
Build.CURRENT.getQualifiedVersion(), Build.CURRENT.getQualifiedVersion(),
Build.CURRENT.flavor().displayName(),
Build.CURRENT.type().displayName(), Build.CURRENT.type().displayName(),
Build.CURRENT.hash(), Build.CURRENT.hash(),
Build.CURRENT.date(), Build.CURRENT.date(),

View File

@ -75,7 +75,6 @@ public class NodesInfoResponse extends BaseNodesResponse<NodeInfo> implements To
builder.field("ip", nodeInfo.getNode().getHostAddress()); builder.field("ip", nodeInfo.getNode().getHostAddress());
builder.field("version", nodeInfo.getVersion()); builder.field("version", nodeInfo.getVersion());
builder.field("build_flavor", nodeInfo.getBuild().flavor().displayName());
builder.field("build_type", nodeInfo.getBuild().type().displayName()); builder.field("build_type", nodeInfo.getBuild().type().displayName());
builder.field("build_hash", nodeInfo.getBuild().hash()); builder.field("build_hash", nodeInfo.getBuild().hash());
if (nodeInfo.getTotalIndexingBuffer() != null) { if (nodeInfo.getTotalIndexingBuffer() != null) {

View File

@ -28,7 +28,6 @@ import org.elasticsearch.action.admin.cluster.node.stats.NodeStats;
import org.elasticsearch.cluster.node.DiscoveryNode; import org.elasticsearch.cluster.node.DiscoveryNode;
import org.elasticsearch.cluster.node.DiscoveryNodeRole; import org.elasticsearch.cluster.node.DiscoveryNodeRole;
import org.elasticsearch.common.Strings; import org.elasticsearch.common.Strings;
import org.elasticsearch.common.collect.Tuple;
import org.elasticsearch.common.network.NetworkModule; import org.elasticsearch.common.network.NetworkModule;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.transport.TransportAddress; import org.elasticsearch.common.transport.TransportAddress;
@ -668,14 +667,13 @@ public class ClusterStatsNodes implements ToXContentFragment {
static class PackagingTypes implements ToXContentFragment { static class PackagingTypes implements ToXContentFragment {
private final Map<Tuple<String, String>, AtomicInteger> packagingTypes; private final Map<String, AtomicInteger> packagingTypes;
PackagingTypes(final List<NodeInfo> nodeInfos) { PackagingTypes(final List<NodeInfo> nodeInfos) {
final Map<Tuple<String, String>, AtomicInteger> packagingTypes = new HashMap<>(); final Map<String, AtomicInteger> packagingTypes = new HashMap<>();
for (final NodeInfo nodeInfo : nodeInfos) { for (final NodeInfo nodeInfo : nodeInfos) {
final String flavor = nodeInfo.getBuild().flavor().displayName();
final String type = nodeInfo.getBuild().type().displayName(); final String type = nodeInfo.getBuild().type().displayName();
packagingTypes.computeIfAbsent(Tuple.tuple(flavor, type), k -> new AtomicInteger()).incrementAndGet(); packagingTypes.computeIfAbsent(type, k -> new AtomicInteger()).incrementAndGet();
} }
this.packagingTypes = Collections.unmodifiableMap(packagingTypes); this.packagingTypes = Collections.unmodifiableMap(packagingTypes);
} }
@ -684,11 +682,10 @@ public class ClusterStatsNodes implements ToXContentFragment {
public XContentBuilder toXContent(final XContentBuilder builder, final Params params) throws IOException { public XContentBuilder toXContent(final XContentBuilder builder, final Params params) throws IOException {
builder.startArray("packaging_types"); builder.startArray("packaging_types");
{ {
for (final Map.Entry<Tuple<String, String>, AtomicInteger> entry : packagingTypes.entrySet()) { for (final Map.Entry<String, AtomicInteger> entry : packagingTypes.entrySet()) {
builder.startObject(); builder.startObject();
{ {
builder.field("flavor", entry.getKey().v1()); builder.field("type", entry.getKey());
builder.field("type", entry.getKey().v2());
builder.field("count", entry.getValue().get()); builder.field("count", entry.getValue().get());
} }
builder.endObject(); builder.endObject();

View File

@ -105,7 +105,6 @@ public class MainResponse extends ActionResponse implements ToXContentObject {
builder.field("cluster_uuid", clusterUuid); builder.field("cluster_uuid", clusterUuid);
builder.startObject("version") builder.startObject("version")
.field("number", build.getQualifiedVersion()) .field("number", build.getQualifiedVersion())
.field("build_flavor", build.flavor().displayName())
.field("build_type", build.type().displayName()) .field("build_type", build.type().displayName())
.field("build_hash", build.hash()) .field("build_hash", build.hash())
.field("build_date", build.date()) .field("build_date", build.date())
@ -128,7 +127,6 @@ public class MainResponse extends ActionResponse implements ToXContentObject {
PARSER.declareString((response, value) -> response.clusterUuid = value, new ParseField("cluster_uuid")); PARSER.declareString((response, value) -> response.clusterUuid = value, new ParseField("cluster_uuid"));
PARSER.declareString((response, value) -> {}, new ParseField("tagline")); PARSER.declareString((response, value) -> {}, new ParseField("tagline"));
PARSER.declareObject((response, value) -> { PARSER.declareObject((response, value) -> {
final String buildFlavor = (String) value.get("build_flavor");
final String buildType = (String) value.get("build_type"); final String buildType = (String) value.get("build_type");
response.build = response.build =
new Build( new Build(
@ -136,7 +134,6 @@ public class MainResponse extends ActionResponse implements ToXContentObject {
* Be lenient when reading on the wire, the enumeration values from other versions might be different than what * Be lenient when reading on the wire, the enumeration values from other versions might be different than what
* we know. * we know.
*/ */
buildFlavor == null ? Build.Flavor.UNKNOWN : Build.Flavor.fromDisplayName(buildFlavor, false),
buildType == null ? Build.Type.UNKNOWN : Build.Type.fromDisplayName(buildType, false), buildType == null ? Build.Type.UNKNOWN : Build.Type.fromDisplayName(buildType, false),
(String) value.get("build_hash"), (String) value.get("build_hash"),
(String) value.get("build_date"), (String) value.get("build_date"),

View File

@ -134,9 +134,8 @@ class Elasticsearch extends EnvironmentAwareCommand {
if (options.has(versionOption)) { if (options.has(versionOption)) {
final String versionOutput = String.format( final String versionOutput = String.format(
Locale.ROOT, Locale.ROOT,
"Version: %s, Build: %s/%s/%s/%s, JVM: %s", "Version: %s, Build: %s/%s/%s, JVM: %s",
Build.CURRENT.getQualifiedVersion(), Build.CURRENT.getQualifiedVersion(),
Build.CURRENT.flavor().displayName(),
Build.CURRENT.type().displayName(), Build.CURRENT.type().displayName(),
Build.CURRENT.hash(), Build.CURRENT.hash(),
Build.CURRENT.date(), Build.CURRENT.date(),

View File

@ -307,10 +307,9 @@ public class Node implements Closeable {
final JvmInfo jvmInfo = JvmInfo.jvmInfo(); final JvmInfo jvmInfo = JvmInfo.jvmInfo();
logger.info( logger.info(
"version[{}], pid[{}], build[{}/{}/{}/{}], OS[{}/{}/{}], JVM[{}/{}/{}/{}]", "version[{}], pid[{}], build[{}/{}/{}], OS[{}/{}/{}], JVM[{}/{}/{}/{}]",
Build.CURRENT.getQualifiedVersion(), Build.CURRENT.getQualifiedVersion(),
jvmInfo.pid(), jvmInfo.pid(),
Build.CURRENT.flavor().displayName(),
Build.CURRENT.type().displayName(), Build.CURRENT.type().displayName(),
Build.CURRENT.hash(), Build.CURRENT.hash(),
Build.CURRENT.date(), Build.CURRENT.date(),

View File

@ -143,7 +143,6 @@ public class RestNodesAction extends AbstractCatAction {
table.addCell("http_address", "default:false;alias:http;desc:bound http address"); table.addCell("http_address", "default:false;alias:http;desc:bound http address");
table.addCell("version", "default:false;alias:v;desc:es version"); table.addCell("version", "default:false;alias:v;desc:es version");
table.addCell("flavor", "default:false;alias:f;desc:es distribution flavor");
table.addCell("type", "default:false;alias:t;desc:es distribution type"); table.addCell("type", "default:false;alias:t;desc:es distribution type");
table.addCell("build", "default:false;alias:b;desc:es build hash"); table.addCell("build", "default:false;alias:b;desc:es build hash");
table.addCell("jdk", "default:false;alias:j;desc:jdk version"); table.addCell("jdk", "default:false;alias:j;desc:jdk version");
@ -299,7 +298,6 @@ public class RestNodesAction extends AbstractCatAction {
} }
table.addCell(node.getVersion().toString()); table.addCell(node.getVersion().toString());
table.addCell(info == null ? null : info.getBuild().flavor().displayName());
table.addCell(info == null ? null : info.getBuild().type().displayName()); table.addCell(info == null ? null : info.getBuild().type().displayName());
table.addCell(info == null ? null : info.getBuild().hash()); table.addCell(info == null ? null : info.getBuild().hash());
table.addCell(jvmInfo == null ? null : jvmInfo.version()); table.addCell(jvmInfo == null ? null : jvmInfo.version());

View File

@ -54,28 +54,28 @@ public class BuildTests extends ESTestCase {
public void testIsProduction() { public void testIsProduction() {
Build build = new Build( Build build = new Build(
Build.CURRENT.flavor(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(),
Build.CURRENT.isSnapshot(), Math.abs(randomInt()) + "." + Math.abs(randomInt()) + "." + Math.abs(randomInt()) Build.CURRENT.isSnapshot(), Math.abs(randomInt()) + "." + Math.abs(randomInt()) + "." + Math.abs(randomInt())
); );
assertTrue(build.getQualifiedVersion(), build.isProductionRelease()); assertTrue(build.getQualifiedVersion(), build.isProductionRelease());
assertFalse(new Build( assertFalse(new Build(
Build.CURRENT.flavor(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(),
Build.CURRENT.isSnapshot(), "7.0.0-alpha1" Build.CURRENT.isSnapshot(), "7.0.0-alpha1"
).isProductionRelease()); ).isProductionRelease());
assertFalse(new Build( assertFalse(new Build(
Build.CURRENT.flavor(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(),
Build.CURRENT.isSnapshot(), "7.0.0-alpha1-SNAPSHOT" Build.CURRENT.isSnapshot(), "7.0.0-alpha1-SNAPSHOT"
).isProductionRelease()); ).isProductionRelease());
assertFalse(new Build( assertFalse(new Build(
Build.CURRENT.flavor(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(),
Build.CURRENT.isSnapshot(), "7.0.0-SNAPSHOT" Build.CURRENT.isSnapshot(), "7.0.0-SNAPSHOT"
).isProductionRelease()); ).isProductionRelease());
assertFalse(new Build( assertFalse(new Build(
Build.CURRENT.flavor(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(), Build.CURRENT.type(), Build.CURRENT.hash(), Build.CURRENT.date(),
Build.CURRENT.isSnapshot(), "Unknown" Build.CURRENT.isSnapshot(), "Unknown"
).isProductionRelease()); ).isProductionRelease());
} }
@ -84,45 +84,37 @@ public class BuildTests extends ESTestCase {
Build build = Build.CURRENT; Build build = Build.CURRENT;
Build another = new Build( Build another = new Build(
build.flavor(), build.type(), build.hash(), build.date(), build.isSnapshot(), build.getQualifiedVersion() build.type(), build.hash(), build.date(), build.isSnapshot(), build.getQualifiedVersion()
); );
assertEquals(build, another); assertEquals(build, another);
assertEquals(build.hashCode(), another.hashCode()); assertEquals(build.hashCode(), another.hashCode());
final Set<Build.Flavor> otherFlavors =
Arrays.stream(Build.Flavor.values()).filter(f -> !f.equals(build.flavor())).collect(Collectors.toSet());
final Build.Flavor otherFlavor = randomFrom(otherFlavors);
Build differentFlavor = new Build(
otherFlavor, build.type(), build.hash(), build.date(), build.isSnapshot(), build.getQualifiedVersion()
);
assertNotEquals(build, differentFlavor);
final Set<Build.Type> otherTypes = final Set<Build.Type> otherTypes =
Arrays.stream(Build.Type.values()).filter(f -> !f.equals(build.type())).collect(Collectors.toSet()); Arrays.stream(Build.Type.values()).filter(f -> !f.equals(build.type())).collect(Collectors.toSet());
final Build.Type otherType = randomFrom(otherTypes); final Build.Type otherType = randomFrom(otherTypes);
Build differentType = new Build( Build differentType = new Build(
build.flavor(), otherType, build.hash(), build.date(), build.isSnapshot(), build.getQualifiedVersion() otherType, build.hash(), build.date(), build.isSnapshot(), build.getQualifiedVersion()
); );
assertNotEquals(build, differentType); assertNotEquals(build, differentType);
Build differentHash = new Build( Build differentHash = new Build(
build.flavor(), build.type(), randomAlphaOfLengthBetween(3, 10), build.date(), build.isSnapshot(), build.type(), randomAlphaOfLengthBetween(3, 10), build.date(), build.isSnapshot(),
build.getQualifiedVersion() build.getQualifiedVersion()
); );
assertNotEquals(build, differentHash); assertNotEquals(build, differentHash);
Build differentDate = new Build( Build differentDate = new Build(
build.flavor(), build.type(), build.hash(), "1970-01-01", build.isSnapshot(), build.getQualifiedVersion() build.type(), build.hash(), "1970-01-01", build.isSnapshot(), build.getQualifiedVersion()
); );
assertNotEquals(build, differentDate); assertNotEquals(build, differentDate);
Build differentSnapshot = new Build( Build differentSnapshot = new Build(
build.flavor(), build.type(), build.hash(), build.date(), !build.isSnapshot(), build.getQualifiedVersion() build.type(), build.hash(), build.date(), !build.isSnapshot(), build.getQualifiedVersion()
); );
assertNotEquals(build, differentSnapshot); assertNotEquals(build, differentSnapshot);
Build differentVersion = new Build( Build differentVersion = new Build(
build.flavor(), build.type(), build.hash(), build.date(), build.isSnapshot(), "1.2.3" build.type(), build.hash(), build.date(), build.isSnapshot(), "1.2.3"
); );
assertNotEquals(build, differentVersion); assertNotEquals(build, differentVersion);
} }
@ -163,31 +155,27 @@ public class BuildTests extends ESTestCase {
public void testSerialization() { public void testSerialization() {
EqualsHashCodeTestUtils.checkEqualsAndHashCode(new WriteableBuild(new Build( EqualsHashCodeTestUtils.checkEqualsAndHashCode(new WriteableBuild(new Build(
randomFrom(Build.Flavor.values()), randomFrom(Build.Type.values()), randomFrom(Build.Type.values()),
randomAlphaOfLength(6), randomAlphaOfLength(6), randomBoolean(), randomAlphaOfLength(6))), randomAlphaOfLength(6), randomAlphaOfLength(6), randomBoolean(), randomAlphaOfLength(6))),
// Note: the cast of the Copy- and MutateFunction is needed for some IDE (specifically Eclipse 4.10.0) to infer the right type // Note: the cast of the Copy- and MutateFunction is needed for some IDE (specifically Eclipse 4.10.0) to infer the right type
(WriteableBuild b) -> copyWriteable(b, writableRegistry(), WriteableBuild::new, Version.CURRENT), (WriteableBuild b) -> copyWriteable(b, writableRegistry(), WriteableBuild::new, Version.CURRENT),
(WriteableBuild b) -> { (WriteableBuild b) -> {
switch (randomIntBetween(1, 6)) { switch (randomIntBetween(1, 5)) {
case 1: case 1:
return new WriteableBuild(new Build( return new WriteableBuild(new Build(
randomValueOtherThan(b.build.flavor(), () -> randomFrom(Build.Flavor.values())), b.build.type(),
b.build.hash(), b.build.date(), b.build.isSnapshot(), b.build.getQualifiedVersion()));
case 2:
return new WriteableBuild(new Build(b.build.flavor(),
randomValueOtherThan(b.build.type(), () -> randomFrom(Build.Type.values())), randomValueOtherThan(b.build.type(), () -> randomFrom(Build.Type.values())),
b.build.hash(), b.build.date(), b.build.isSnapshot(), b.build.getQualifiedVersion())); b.build.hash(), b.build.date(), b.build.isSnapshot(), b.build.getQualifiedVersion()));
case 3: case 2:
return new WriteableBuild(new Build(b.build.flavor(), b.build.type(), return new WriteableBuild(new Build(b.build.type(),
randomStringExcept(b.build.hash()), b.build.date(), b.build.isSnapshot(), b.build.getQualifiedVersion())); randomStringExcept(b.build.hash()), b.build.date(), b.build.isSnapshot(), b.build.getQualifiedVersion()));
case 4: case 3:
return new WriteableBuild(new Build(b.build.flavor(), b.build.type(), return new WriteableBuild(new Build(b.build.type(),
b.build.hash(), randomStringExcept(b.build.date()), b.build.isSnapshot(), b.build.getQualifiedVersion())); b.build.hash(), randomStringExcept(b.build.date()), b.build.isSnapshot(), b.build.getQualifiedVersion()));
case 5: case 4:
return new WriteableBuild(new Build(b.build.flavor(), b.build.type(), return new WriteableBuild(new Build(b.build.type(),
b.build.hash(), b.build.date(), b.build.isSnapshot() == false, b.build.getQualifiedVersion())); b.build.hash(), b.build.date(), b.build.isSnapshot() == false, b.build.getQualifiedVersion()));
case 6: case 5:
return new WriteableBuild(new Build(b.build.flavor(), b.build.type(), return new WriteableBuild(new Build(b.build.type(),
b.build.hash(), b.build.date(), b.build.isSnapshot(), randomStringExcept(b.build.getQualifiedVersion()))); b.build.hash(), b.build.date(), b.build.isSnapshot(), randomStringExcept(b.build.getQualifiedVersion())));
} }
throw new AssertionError(); throw new AssertionError();
@ -195,7 +183,7 @@ public class BuildTests extends ESTestCase {
} }
public void testSerializationBWC() throws IOException { public void testSerializationBWC() throws IOException {
final WriteableBuild dockerBuild = new WriteableBuild(new Build(randomFrom(Build.Flavor.values()), Build.Type.DOCKER, final WriteableBuild dockerBuild = new WriteableBuild(new Build(Build.Type.DOCKER,
randomAlphaOfLength(6), randomAlphaOfLength(6), randomBoolean(), randomAlphaOfLength(6))); randomAlphaOfLength(6), randomAlphaOfLength(6), randomBoolean(), randomAlphaOfLength(6)));
final List<Version> versions = Version.getDeclaredVersions(Version.class); final List<Version> versions = Version.getDeclaredVersions(Version.class);
@ -211,11 +199,6 @@ public class BuildTests extends ESTestCase {
final WriteableBuild post67pre70 = copyWriteable(dockerBuild, writableRegistry(), WriteableBuild::new, post67Pre70Version); final WriteableBuild post67pre70 = copyWriteable(dockerBuild, writableRegistry(), WriteableBuild::new, post67Pre70Version);
final WriteableBuild post70 = copyWriteable(dockerBuild, writableRegistry(), WriteableBuild::new, post70Version); final WriteableBuild post70 = copyWriteable(dockerBuild, writableRegistry(), WriteableBuild::new, post70Version);
assertThat(pre63.build.flavor(), equalTo(Build.Flavor.OSS));
assertThat(post63pre67.build.flavor(), equalTo(dockerBuild.build.flavor()));
assertThat(post67pre70.build.flavor(), equalTo(dockerBuild.build.flavor()));
assertThat(post70.build.flavor(), equalTo(dockerBuild.build.flavor()));
assertThat(pre63.build.type(), equalTo(Build.Type.UNKNOWN)); assertThat(pre63.build.type(), equalTo(Build.Type.UNKNOWN));
assertThat(post63pre67.build.type(), equalTo(Build.Type.TAR)); assertThat(post63pre67.build.type(), equalTo(Build.Type.TAR));
assertThat(post67pre70.build.type(), equalTo(dockerBuild.build.type())); assertThat(post67pre70.build.type(), equalTo(dockerBuild.build.type()));
@ -227,13 +210,6 @@ public class BuildTests extends ESTestCase {
assertThat(post70.build.getQualifiedVersion(), equalTo(dockerBuild.build.getQualifiedVersion())); assertThat(post70.build.getQualifiedVersion(), equalTo(dockerBuild.build.getQualifiedVersion()));
} }
public void testFlavorParsing() {
for (final Build.Flavor flavor : Build.Flavor.values()) {
// strict or not should not impact parsing at all here
assertThat(Build.Flavor.fromDisplayName(flavor.displayName(), randomBoolean()), sameInstance(flavor));
}
}
public void testTypeParsing() { public void testTypeParsing() {
for (final Build.Type type : Build.Type.values()) { for (final Build.Type type : Build.Type.values()) {
// strict or not should not impact parsing at all here // strict or not should not impact parsing at all here
@ -241,18 +217,6 @@ public class BuildTests extends ESTestCase {
} }
} }
public void testLenientFlavorParsing() {
final String displayName = randomAlphaOfLength(8);
assertThat(Build.Flavor.fromDisplayName(displayName, false), equalTo(Build.Flavor.UNKNOWN));
}
public void testStrictFlavorParsing() {
final String displayName = randomAlphaOfLength(8);
@SuppressWarnings("ResultOfMethodCallIgnored") final IllegalStateException e =
expectThrows(IllegalStateException.class, () -> Build.Flavor.fromDisplayName(displayName, true));
assertThat(e, hasToString(containsString("unexpected distribution flavor [" + displayName + "]; your distribution is broken")));
}
public void testLenientTypeParsing() { public void testLenientTypeParsing() {
final String displayName = randomAlphaOfLength(8); final String displayName = randomAlphaOfLength(8);
assertThat(Build.Type.fromDisplayName(displayName, false), equalTo(Build.Type.UNKNOWN)); assertThat(Build.Type.fromDisplayName(displayName, false), equalTo(Build.Type.UNKNOWN));

View File

@ -44,7 +44,7 @@ public class MainResponseTests extends AbstractSerializingTestCase<MainResponse>
final String date = new Date(randomNonNegativeLong()).toString(); final String date = new Date(randomNonNegativeLong()).toString();
Version version = VersionUtils.randomVersionBetween(random(), Version.V_6_0_1, Version.CURRENT); Version version = VersionUtils.randomVersionBetween(random(), Version.V_6_0_1, Version.CURRENT);
Build build = new Build( Build build = new Build(
Build.Flavor.UNKNOWN, Build.Type.UNKNOWN, randomAlphaOfLength(8), date, randomBoolean(), Build.Type.UNKNOWN, randomAlphaOfLength(8), date, randomBoolean(),
version.toString() version.toString()
); );
return new MainResponse(nodeName, version, clusterName, clusterUuid , build); return new MainResponse(nodeName, version, clusterName, clusterUuid , build);
@ -64,7 +64,7 @@ public class MainResponseTests extends AbstractSerializingTestCase<MainResponse>
String clusterUUID = randomAlphaOfLengthBetween(10, 20); String clusterUUID = randomAlphaOfLengthBetween(10, 20);
final Build current = Build.CURRENT; final Build current = Build.CURRENT;
Build build = new Build( Build build = new Build(
current.flavor(), current.type(), current.hash(), current.date(), current.isSnapshot(), current.type(), current.hash(), current.date(), current.isSnapshot(),
current.getQualifiedVersion() current.getQualifiedVersion()
); );
Version version = Version.CURRENT; Version version = Version.CURRENT;
@ -77,7 +77,6 @@ public class MainResponseTests extends AbstractSerializingTestCase<MainResponse>
+ "\"cluster_uuid\":\"" + clusterUUID + "\"," + "\"cluster_uuid\":\"" + clusterUUID + "\","
+ "\"version\":{" + "\"version\":{"
+ "\"number\":\"" + build.getQualifiedVersion() + "\"," + "\"number\":\"" + build.getQualifiedVersion() + "\","
+ "\"build_flavor\":\"" + current.flavor().displayName() + "\","
+ "\"build_type\":\"" + current.type().displayName() + "\"," + "\"build_type\":\"" + current.type().displayName() + "\","
+ "\"build_hash\":\"" + current.hash() + "\"," + "\"build_hash\":\"" + current.hash() + "\","
+ "\"build_date\":\"" + current.date() + "\"," + "\"build_date\":\"" + current.date() + "\","
@ -106,7 +105,7 @@ public class MainResponseTests extends AbstractSerializingTestCase<MainResponse>
case 2: case 2:
// toggle the snapshot flag of the original Build parameter // toggle the snapshot flag of the original Build parameter
build = new Build( build = new Build(
Build.Flavor.UNKNOWN, Build.Type.UNKNOWN, build.hash(), build.date(), !build.isSnapshot(), Build.Type.UNKNOWN, build.hash(), build.date(), !build.isSnapshot(),
build.getQualifiedVersion() build.getQualifiedVersion()
); );
break; break;

View File

@ -65,8 +65,7 @@ public class ElasticsearchCliTests extends ESElasticsearchCliTestCase {
assertThat(output, containsString("Version: " + Build.CURRENT.getQualifiedVersion())); assertThat(output, containsString("Version: " + Build.CURRENT.getQualifiedVersion()));
final String expectedBuildOutput = String.format( final String expectedBuildOutput = String.format(
Locale.ROOT, Locale.ROOT,
"Build: %s/%s/%s/%s", "Build: %s/%s/%s",
Build.CURRENT.flavor().displayName(),
Build.CURRENT.type().displayName(), Build.CURRENT.type().displayName(),
Build.CURRENT.hash(), Build.CURRENT.hash(),
Build.CURRENT.date()); Build.CURRENT.date());

View File

@ -19,43 +19,23 @@ List projects = [
'benchmarks', 'benchmarks',
'distribution:archives:integ-test-zip', 'distribution:archives:integ-test-zip',
'distribution:archives:oss-windows-zip', 'distribution:archives:oss-windows-zip',
'distribution:archives:windows-zip',
'distribution:archives:oss-no-jdk-windows-zip', 'distribution:archives:oss-no-jdk-windows-zip',
'distribution:archives:no-jdk-windows-zip',
'distribution:archives:oss-darwin-tar', 'distribution:archives:oss-darwin-tar',
'distribution:archives:darwin-tar',
'distribution:archives:oss-no-jdk-darwin-tar', 'distribution:archives:oss-no-jdk-darwin-tar',
'distribution:archives:no-jdk-darwin-tar',
'distribution:archives:oss-linux-aarch64-tar', 'distribution:archives:oss-linux-aarch64-tar',
'distribution:archives:oss-linux-tar', 'distribution:archives:oss-linux-tar',
'distribution:archives:linux-aarch64-tar',
'distribution:archives:linux-tar',
'distribution:archives:oss-no-jdk-linux-tar', 'distribution:archives:oss-no-jdk-linux-tar',
'distribution:archives:no-jdk-linux-tar',
'distribution:docker', 'distribution:docker',
'distribution:docker:docker-aarch64-build-context',
'distribution:docker:docker-aarch64-export',
'distribution:docker:docker-build-context',
'distribution:docker:docker-export',
'distribution:docker:oss-docker-aarch64-build-context', 'distribution:docker:oss-docker-aarch64-build-context',
'distribution:docker:oss-docker-aarch64-export', 'distribution:docker:oss-docker-aarch64-export',
'distribution:docker:oss-docker-build-context', 'distribution:docker:oss-docker-build-context',
'distribution:docker:oss-docker-export', 'distribution:docker:oss-docker-export',
'distribution:docker:ubi-docker-aarch64-export',
'distribution:docker:ubi-docker-build-context',
'distribution:docker:ubi-docker-export',
'distribution:packages:aarch64-oss-deb', 'distribution:packages:aarch64-oss-deb',
'distribution:packages:oss-deb', 'distribution:packages:oss-deb',
'distribution:packages:aarch64-deb',
'distribution:packages:deb',
'distribution:packages:oss-no-jdk-deb', 'distribution:packages:oss-no-jdk-deb',
'distribution:packages:no-jdk-deb',
'distribution:packages:aarch64-oss-rpm', 'distribution:packages:aarch64-oss-rpm',
'distribution:packages:oss-rpm', 'distribution:packages:oss-rpm',
'distribution:packages:aarch64-rpm',
'distribution:packages:rpm',
'distribution:packages:oss-no-jdk-rpm', 'distribution:packages:oss-no-jdk-rpm',
'distribution:packages:no-jdk-rpm',
'distribution:bwc:bugfix', 'distribution:bwc:bugfix',
'distribution:bwc:maintenance', 'distribution:bwc:maintenance',
'distribution:bwc:minor', 'distribution:bwc:minor',

View File

@ -172,7 +172,6 @@ public class ReproduceInfoPrinter extends RunListener {
} }
appendOpt("tests.locale", Locale.getDefault().toLanguageTag()); appendOpt("tests.locale", Locale.getDefault().toLanguageTag());
appendOpt("tests.timezone", TimeZone.getDefault().getID()); appendOpt("tests.timezone", TimeZone.getDefault().getID());
appendOpt("tests.distribution", System.getProperty("tests.distribution"));
appendOpt("runtime.java", Integer.toString(JavaVersion.current().getVersion().get(0))); appendOpt("runtime.java", Integer.toString(JavaVersion.current().getVersion().get(0)));
appendOpt(ESTestCase.FIPS_SYSPROP, System.getProperty(ESTestCase.FIPS_SYSPROP)); appendOpt(ESTestCase.FIPS_SYSPROP, System.getProperty(ESTestCase.FIPS_SYSPROP));
return this; return this;