Build: Extract all ES versions into gradle properties (#24748)
This commit expands the logic for version extraction from Version.java to include a list of all versions for backcompat purposes. The tests using bwcVersion are converted to use this list, but those tests (rolling upgrade and backwards-5.0) are still not randomized; that will happen in another followup.
This commit is contained in:
parent
1a7a926a03
commit
ff34434bba
40
build.gradle
40
build.gradle
|
@ -61,16 +61,41 @@ configure(subprojects.findAll { it.projectDir.toPath().startsWith(rootPath) }) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int prevMajor = Integer.parseInt(VersionProperties.elasticsearch.split('\\.')[0]) - 1
|
// introspect all versions of ES that may be tested agains for backwards compatibility
|
||||||
String prevSnapshot = VersionProperties.elasticsearch.contains('alpha') ? '-SNAPSHOT' : ''
|
String currentVersion = VersionProperties.elasticsearch.minus('-SNAPSHOT')
|
||||||
|
int prevMajor = Integer.parseInt(currentVersion.split('\\.')[0]) - 1
|
||||||
File versionFile = file('core/src/main/java/org/elasticsearch/Version.java')
|
File versionFile = file('core/src/main/java/org/elasticsearch/Version.java')
|
||||||
List<String> versionLines = versionFile.readLines('UTF-8')
|
List<String> versionLines = versionFile.readLines('UTF-8')
|
||||||
int prevMinor = 0
|
List<String> versions = []
|
||||||
|
// keep track of the previous major version's last minor, so we know where wire compat begins
|
||||||
|
int prevMinorIndex = -1 // index in the versions list of the last minor from the prev major
|
||||||
|
int lastPrevMinor = -1 // the minor version number from the prev major we most recently seen
|
||||||
for (String line : versionLines) {
|
for (String line : versionLines) {
|
||||||
Matcher match = line =~ /\W+public static final Version V_${prevMajor}_(\d+)_.*/
|
Matcher match = line =~ /\W+public static final Version V_(\d+)_(\d+)_(\d+)(_UNRELEASED)? .*/
|
||||||
if (match.matches()) {
|
if (match.matches()) {
|
||||||
prevMinor = Math.max(Integer.parseInt(match.group(1)), prevMinor)
|
int major = Integer.parseInt(match.group(1))
|
||||||
|
int minor = Integer.parseInt(match.group(2))
|
||||||
|
int bugfix = Integer.parseInt(match.group(3))
|
||||||
|
String versionStr = "${major}.${minor}.${bugfix}"
|
||||||
|
if (currentVersion != versionStr) {
|
||||||
|
versions.add(versionStr)
|
||||||
}
|
}
|
||||||
|
if (major == prevMajor && minor > lastPrevMinor) {
|
||||||
|
prevMinorIndex = versions.size() - 1
|
||||||
|
lastPrevMinor = minor
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (versions.toSorted() != versions) {
|
||||||
|
throw new GradleException('Versions.java contains out of order version constants')
|
||||||
|
}
|
||||||
|
if (currentVersion.split('\\.')[2].split('-')[0] == '0') {
|
||||||
|
// If on a release branch, after the initial release of that branch, the bugfix version will
|
||||||
|
// be bumped, and will be != 0. On master and N.x branches, we want to test against the
|
||||||
|
// unreleased version of closest branch. So for those cases, the version includes -SNAPSHOT,
|
||||||
|
// and the bwc-zip distribution will checkout and build that version. The version parsing
|
||||||
|
// logic above pulls the bugfix version, and then strips off any prerelease version
|
||||||
|
versions[-1] += '-SNAPSHOT'
|
||||||
}
|
}
|
||||||
|
|
||||||
// injecting groovy property variables into all projects
|
// injecting groovy property variables into all projects
|
||||||
|
@ -80,7 +105,8 @@ allprojects {
|
||||||
isEclipse = System.getProperty("eclipse.launcher") != null || gradle.startParameter.taskNames.contains('eclipse') || gradle.startParameter.taskNames.contains('cleanEclipse')
|
isEclipse = System.getProperty("eclipse.launcher") != null || gradle.startParameter.taskNames.contains('eclipse') || gradle.startParameter.taskNames.contains('cleanEclipse')
|
||||||
isIdea = System.getProperty("idea.active") != null || gradle.startParameter.taskNames.contains('idea') || gradle.startParameter.taskNames.contains('cleanIdea')
|
isIdea = System.getProperty("idea.active") != null || gradle.startParameter.taskNames.contains('idea') || gradle.startParameter.taskNames.contains('cleanIdea')
|
||||||
// for backcompat testing
|
// for backcompat testing
|
||||||
bwcVersion = "${prevMajor}.${prevMinor}.0${prevSnapshot}"
|
indexCompatVersions = versions
|
||||||
|
wireCompatVersions = versions.subList(prevMinorIndex, versions.size())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,7 +154,7 @@ subprojects {
|
||||||
"org.elasticsearch.client:transport:${version}": ':client:transport',
|
"org.elasticsearch.client:transport:${version}": ':client:transport',
|
||||||
"org.elasticsearch.test:framework:${version}": ':test:framework',
|
"org.elasticsearch.test:framework:${version}": ':test:framework',
|
||||||
"org.elasticsearch.distribution.integ-test-zip:elasticsearch:${version}": ':distribution:integ-test-zip',
|
"org.elasticsearch.distribution.integ-test-zip:elasticsearch:${version}": ':distribution:integ-test-zip',
|
||||||
"org.elasticsearch.distribution.zip:elasticsearch:${bwcVersion}": ':distribution:bwc-zip',
|
"org.elasticsearch.distribution.zip:elasticsearch:${wireCompatVersions[-1]}": ':distribution:bwc-zip',
|
||||||
"org.elasticsearch.distribution.zip:elasticsearch:${version}": ':distribution:zip',
|
"org.elasticsearch.distribution.zip:elasticsearch:${version}": ':distribution:zip',
|
||||||
"org.elasticsearch.distribution.tar:elasticsearch:${version}": ':distribution:tar',
|
"org.elasticsearch.distribution.tar:elasticsearch:${version}": ':distribution:tar',
|
||||||
"org.elasticsearch.distribution.rpm:elasticsearch:${version}": ':distribution:rpm',
|
"org.elasticsearch.distribution.rpm:elasticsearch:${version}": ':distribution:rpm',
|
||||||
|
|
|
@ -21,15 +21,19 @@ import java.util.regex.Matcher
|
||||||
import org.elasticsearch.gradle.LoggedExec
|
import org.elasticsearch.gradle.LoggedExec
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is a dummy project which does a local worktree checkout of the previous
|
* This is a dummy project which does a local checkout of the previous
|
||||||
* major version's stable branch, and builds a snapshot. This allows backcompat
|
* wire compat version's branch, and builds a snapshot. This allows backcompat
|
||||||
* tests in the next major version to test against the next unreleased minor
|
* tests to test against the next unreleased version, closest to this version,
|
||||||
* version, without relying on snapshots.
|
* without relying on snapshots.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
String bwcVersion = wireCompatVersions[-1]
|
||||||
|
if (bwcVersion.endsWith('-SNAPSHOT')) {
|
||||||
apply plugin: 'distribution'
|
apply plugin: 'distribution'
|
||||||
|
|
||||||
File checkoutDir = file("${buildDir}/bwc/checkout-5.x")
|
def (String major, String minor, String bugfix) = bwcVersion.split('\\.')
|
||||||
|
String bwcBranch = bugfix == '0-SNAPSHOT' ? "${major}.x" : "${major}.${minor}"
|
||||||
|
File checkoutDir = file("${buildDir}/bwc/checkout-${bwcBranch}")
|
||||||
task createClone(type: LoggedExec) {
|
task createClone(type: LoggedExec) {
|
||||||
onlyIf { checkoutDir.exists() == false }
|
onlyIf { checkoutDir.exists() == false }
|
||||||
commandLine = ['git', 'clone', rootDir, checkoutDir]
|
commandLine = ['git', 'clone', rootDir, checkoutDir]
|
||||||
|
@ -74,7 +78,7 @@ task fetchLatest(type: LoggedExec) {
|
||||||
task checkoutBwcBranch(type: LoggedExec) {
|
task checkoutBwcBranch(type: LoggedExec) {
|
||||||
dependsOn fetchLatest
|
dependsOn fetchLatest
|
||||||
workingDir = checkoutDir
|
workingDir = checkoutDir
|
||||||
commandLine = ['git', 'checkout', 'upstream/5.x']
|
commandLine = ['git', 'checkout', "upstream/${bwcBranch}"]
|
||||||
}
|
}
|
||||||
|
|
||||||
File bwcZip = file("${checkoutDir}/distribution/zip/build/distributions/elasticsearch-${bwcVersion}.zip")
|
File bwcZip = file("${checkoutDir}/distribution/zip/build/distributions/elasticsearch-${bwcVersion}.zip")
|
||||||
|
@ -87,4 +91,4 @@ task buildBwcVersion(type: GradleBuild) {
|
||||||
artifacts {
|
artifacts {
|
||||||
'default' file: bwcZip, name: 'elasticsearch', type: 'zip', builtBy: buildBwcVersion
|
'default' file: bwcZip, name: 'elasticsearch', type: 'zip', builtBy: buildBwcVersion
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -28,7 +28,7 @@ integTest {
|
||||||
integTestCluster {
|
integTestCluster {
|
||||||
numNodes = 4
|
numNodes = 4
|
||||||
numBwcNodes = 2
|
numBwcNodes = 2
|
||||||
bwcVersion = project.bwcVersion
|
bwcVersion = project.wireCompatVersions[-1]
|
||||||
setting 'logger.org.elasticsearch', 'DEBUG'
|
setting 'logger.org.elasticsearch', 'DEBUG'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ task oldClusterTest(type: RestIntegTestTask) {
|
||||||
|
|
||||||
oldClusterTestCluster {
|
oldClusterTestCluster {
|
||||||
distribution = 'zip'
|
distribution = 'zip'
|
||||||
bwcVersion = project.bwcVersion // TODO: either randomize, or make this settable with sysprop
|
bwcVersion = project.wireCompatVersions[-1] // TODO: either randomize, or make this settable with sysprop
|
||||||
numBwcNodes = 2
|
numBwcNodes = 2
|
||||||
numNodes = 2
|
numNodes = 2
|
||||||
clusterName = 'rolling-upgrade'
|
clusterName = 'rolling-upgrade'
|
||||||
|
|
Loading…
Reference in New Issue