2010-02-08 15:30:06 +02:00
|
|
|
/*
|
2014-01-06 22:48:02 +01:00
|
|
|
* Licensed to Elasticsearch under one or more contributor
|
|
|
|
* license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright
|
|
|
|
* ownership. Elasticsearch licenses this file to you under
|
|
|
|
* the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
* not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
2010-02-08 15:30:06 +02:00
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing,
|
|
|
|
* software distributed under the License is distributed on an
|
|
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
|
|
* KIND, either express or implied. See the License for the
|
|
|
|
* specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*/
|
|
|
|
|
2013-09-11 12:49:49 -05:00
|
|
|
package org.elasticsearch;
|
2010-02-08 15:30:06 +02:00
|
|
|
|
2014-05-20 17:34:00 +02:00
|
|
|
import org.elasticsearch.cluster.metadata.IndexMetaData;
|
2014-07-28 12:43:37 +02:00
|
|
|
import org.elasticsearch.common.lucene.Lucene;
|
2014-05-20 17:34:00 +02:00
|
|
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
2013-10-13 22:37:40 +02:00
|
|
|
import org.elasticsearch.test.ElasticsearchTestCase;
|
2015-04-18 12:47:26 -07:00
|
|
|
import org.elasticsearch.test.VersionUtils;
|
2014-07-28 12:43:37 +02:00
|
|
|
import org.hamcrest.Matchers;
|
2013-07-19 14:38:59 +02:00
|
|
|
import org.junit.Test;
|
2013-05-31 17:01:21 +02:00
|
|
|
|
2015-01-09 15:09:45 -08:00
|
|
|
import java.lang.reflect.Modifier;
|
|
|
|
import java.util.HashMap;
|
2014-07-28 12:43:37 +02:00
|
|
|
import java.util.Locale;
|
2015-01-09 15:09:45 -08:00
|
|
|
import java.util.Map;
|
2014-07-28 12:43:37 +02:00
|
|
|
|
2013-05-31 17:01:21 +02:00
|
|
|
import static org.elasticsearch.Version.V_0_20_0;
|
|
|
|
import static org.elasticsearch.Version.V_0_90_0;
|
2015-04-18 12:47:26 -07:00
|
|
|
import static org.elasticsearch.test.VersionUtils.randomVersion;
|
2014-01-22 11:25:36 +01:00
|
|
|
import static org.hamcrest.CoreMatchers.equalTo;
|
2013-05-31 17:01:21 +02:00
|
|
|
import static org.hamcrest.Matchers.is;
|
2014-01-22 11:25:36 +01:00
|
|
|
import static org.hamcrest.Matchers.sameInstance;
|
2013-05-31 17:01:21 +02:00
|
|
|
|
2013-10-13 22:37:40 +02:00
|
|
|
public class VersionTests extends ElasticsearchTestCase {
|
2015-01-09 15:09:45 -08:00
|
|
|
|
2014-09-29 17:41:56 +02:00
|
|
|
public void testMavenVersion() {
|
|
|
|
// maven sets this property to ensure that the latest version
|
|
|
|
// we use here is the version that is actually set to the project.version
|
|
|
|
// in maven
|
|
|
|
String property = System.getProperty("tests.version", null);
|
2015-04-17 21:02:05 -04:00
|
|
|
assumeTrue("tests.version is set", property != null);
|
2014-09-29 17:41:56 +02:00
|
|
|
assertEquals(property, Version.CURRENT.toString());
|
|
|
|
}
|
2015-01-09 15:09:45 -08:00
|
|
|
|
|
|
|
public void testVersionComparison() throws Exception {
|
2013-05-31 17:01:21 +02:00
|
|
|
assertThat(V_0_20_0.before(V_0_90_0), is(true));
|
|
|
|
assertThat(V_0_20_0.before(V_0_20_0), is(false));
|
|
|
|
assertThat(V_0_90_0.before(V_0_20_0), is(false));
|
|
|
|
|
|
|
|
assertThat(V_0_20_0.onOrBefore(V_0_90_0), is(true));
|
|
|
|
assertThat(V_0_20_0.onOrBefore(V_0_20_0), is(true));
|
|
|
|
assertThat(V_0_90_0.onOrBefore(V_0_20_0), is(false));
|
|
|
|
|
|
|
|
assertThat(V_0_20_0.after(V_0_90_0), is(false));
|
|
|
|
assertThat(V_0_20_0.after(V_0_20_0), is(false));
|
|
|
|
assertThat(V_0_90_0.after(V_0_20_0), is(true));
|
|
|
|
|
|
|
|
assertThat(V_0_20_0.onOrAfter(V_0_90_0), is(false));
|
|
|
|
assertThat(V_0_20_0.onOrAfter(V_0_20_0), is(true));
|
|
|
|
assertThat(V_0_90_0.onOrAfter(V_0_20_0), is(true));
|
|
|
|
}
|
2015-01-09 15:09:45 -08:00
|
|
|
|
2014-01-22 11:25:36 +01:00
|
|
|
public void testVersionConstantPresent() {
|
|
|
|
assertThat(Version.CURRENT, sameInstance(Version.fromId(Version.CURRENT.id)));
|
2014-09-05 12:21:08 -04:00
|
|
|
assertThat(Version.CURRENT.luceneVersion, equalTo(org.apache.lucene.util.Version.LATEST));
|
2014-03-12 18:42:21 +01:00
|
|
|
final int iters = scaledRandomIntBetween(20, 100);
|
2014-01-22 11:25:36 +01:00
|
|
|
for (int i = 0; i < iters; i++) {
|
2015-04-18 03:00:45 -07:00
|
|
|
Version version = randomVersion(random());
|
2014-01-22 11:25:36 +01:00
|
|
|
assertThat(version, sameInstance(Version.fromId(version.id)));
|
|
|
|
assertThat(version.luceneVersion, sameInstance(Version.fromId(version.id).luceneVersion));
|
|
|
|
}
|
|
|
|
}
|
2014-11-24 13:40:26 +02:00
|
|
|
|
2014-03-20 21:09:22 +01:00
|
|
|
public void testCURRENTIsLatest() {
|
|
|
|
final int iters = scaledRandomIntBetween(100, 1000);
|
|
|
|
for (int i = 0; i < iters; i++) {
|
2015-04-18 03:00:45 -07:00
|
|
|
Version version = randomVersion(random());
|
2014-03-20 21:09:22 +01:00
|
|
|
if (version != Version.CURRENT) {
|
|
|
|
assertThat("Version: " + version + " should be before: " + Version.CURRENT + " but wasn't", version.before(Version.CURRENT), is(true));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-01-09 15:09:45 -08:00
|
|
|
|
2014-04-22 11:36:53 +02:00
|
|
|
public void testVersionFromString() {
|
|
|
|
final int iters = scaledRandomIntBetween(100, 1000);
|
|
|
|
for (int i = 0; i < iters; i++) {
|
2015-04-18 03:00:45 -07:00
|
|
|
Version version = randomVersion(random());
|
2014-11-07 09:28:24 +01:00
|
|
|
if (version.snapshot()) { // number doesn't include SNAPSHOT but the parser checks for that
|
|
|
|
assertEquals(Version.fromString(version.number()), version);
|
|
|
|
} else {
|
|
|
|
assertThat(Version.fromString(version.number()), sameInstance(version));
|
|
|
|
}
|
|
|
|
assertFalse(Version.fromString(version.number()).snapshot());
|
2014-04-22 11:36:53 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test(expected = IllegalArgumentException.class)
|
|
|
|
public void testTooLongVersionFromString() {
|
|
|
|
Version.fromString("1.0.0.1.3");
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test(expected = IllegalArgumentException.class)
|
|
|
|
public void testTooShortVersionFromString() {
|
|
|
|
Version.fromString("1.0");
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test(expected = IllegalArgumentException.class)
|
|
|
|
public void testWrongVersionFromString() {
|
|
|
|
Version.fromString("WRONG.VERSION");
|
|
|
|
}
|
2014-05-20 17:34:00 +02:00
|
|
|
|
2015-04-28 22:41:15 +02:00
|
|
|
@Test(expected = IllegalStateException.class)
|
2014-10-08 09:16:03 +02:00
|
|
|
public void testVersionNoPresentInSettings() {
|
|
|
|
Version.indexCreated(ImmutableSettings.builder().build());
|
|
|
|
}
|
|
|
|
|
2015-01-09 15:09:45 -08:00
|
|
|
public void testIndexCreatedVersion() {
|
2014-05-20 17:34:00 +02:00
|
|
|
// an actual index has a IndexMetaData.SETTING_UUID
|
|
|
|
final Version version = randomFrom(Version.V_0_18_0, Version.V_0_90_13, Version.V_1_3_0);
|
|
|
|
assertEquals(version, Version.indexCreated(ImmutableSettings.builder().put(IndexMetaData.SETTING_UUID, "foo").put(IndexMetaData.SETTING_VERSION_CREATED, version).build()));
|
|
|
|
}
|
2015-01-09 15:09:45 -08:00
|
|
|
|
2014-07-17 14:38:56 +02:00
|
|
|
public void testMinCompatVersion() {
|
|
|
|
assertThat(Version.V_2_0_0.minimumCompatibilityVersion(), equalTo(Version.V_2_0_0));
|
|
|
|
assertThat(Version.V_1_3_0.minimumCompatibilityVersion(), equalTo(Version.V_1_0_0));
|
|
|
|
assertThat(Version.V_1_2_0.minimumCompatibilityVersion(), equalTo(Version.V_1_0_0));
|
|
|
|
assertThat(Version.V_1_2_3.minimumCompatibilityVersion(), equalTo(Version.V_1_0_0));
|
|
|
|
assertThat(Version.V_1_0_0_RC2.minimumCompatibilityVersion(), equalTo(Version.V_1_0_0_RC2));
|
|
|
|
}
|
2015-01-09 15:09:45 -08:00
|
|
|
|
2014-11-07 09:28:24 +01:00
|
|
|
public void testParseVersion() {
|
|
|
|
final int iters = scaledRandomIntBetween(100, 1000);
|
|
|
|
for (int i = 0; i < iters; i++) {
|
2015-04-18 03:00:45 -07:00
|
|
|
Version version = randomVersion(random());
|
2014-11-07 09:28:24 +01:00
|
|
|
String stringVersion = version.toString();
|
2015-04-16 00:58:02 -04:00
|
|
|
if (version.snapshot() == false && random().nextBoolean()) {
|
2014-11-07 09:28:24 +01:00
|
|
|
version = new Version(version.id, true, version.luceneVersion);
|
|
|
|
}
|
|
|
|
Version parsedVersion = Version.fromString(version.toString());
|
|
|
|
assertEquals(version, parsedVersion);
|
|
|
|
assertEquals(version.snapshot(), parsedVersion.snapshot());
|
|
|
|
}
|
|
|
|
}
|
2015-01-09 15:09:45 -08:00
|
|
|
|
|
|
|
public void testParseLenient() {
|
2014-09-05 12:21:08 -04:00
|
|
|
// note this is just a silly sanity check, we test it in lucene
|
2015-04-18 12:47:26 -07:00
|
|
|
for (Version version : VersionUtils.allVersions()) {
|
2014-07-28 12:43:37 +02:00
|
|
|
org.apache.lucene.util.Version luceneVersion = version.luceneVersion;
|
2014-09-05 12:21:08 -04:00
|
|
|
String string = luceneVersion.toString().toUpperCase(Locale.ROOT)
|
2014-07-28 12:43:37 +02:00
|
|
|
.replaceFirst("^LUCENE_(\\d+)_(\\d+)$", "$1.$2");
|
|
|
|
assertThat(luceneVersion, Matchers.equalTo(Lucene.parseVersionLenient(string, null)));
|
|
|
|
}
|
|
|
|
}
|
2015-01-09 15:09:45 -08:00
|
|
|
|
|
|
|
public void testAllVersionsMatchId() throws Exception {
|
|
|
|
Map<String, Version> maxBranchVersions = new HashMap<>();
|
|
|
|
for (java.lang.reflect.Field field : Version.class.getDeclaredFields()) {
|
|
|
|
if (field.getName().endsWith("_ID")) {
|
|
|
|
assertTrue(field.getName() + " should be static", Modifier.isStatic(field.getModifiers()));
|
|
|
|
assertTrue(field.getName() + " should be final", Modifier.isFinal(field.getModifiers()));
|
|
|
|
int versionId = (Integer)field.get(Version.class);
|
|
|
|
|
|
|
|
String constantName = field.getName().substring(0, field.getName().length() - 3);
|
|
|
|
java.lang.reflect.Field versionConstant = Version.class.getField(constantName);
|
|
|
|
assertTrue(constantName + " should be static", Modifier.isStatic(versionConstant.getModifiers()));
|
|
|
|
assertTrue(constantName + " should be final", Modifier.isFinal(versionConstant.getModifiers()));
|
|
|
|
|
|
|
|
Version v = (Version) versionConstant.get(Version.class);
|
|
|
|
logger.info("Checking " + v);
|
|
|
|
assertEquals("Version id " + field.getName() + " does not point to " + constantName, v, Version.fromId(versionId));
|
|
|
|
assertEquals("Version " + constantName + " does not have correct id", versionId, v.id);
|
|
|
|
assertEquals("V_" + v.number().replace('.', '_'), constantName);
|
|
|
|
|
|
|
|
// only the latest version for a branch should be a snapshot (ie unreleased)
|
|
|
|
String branchName = "" + v.major + "." + v.minor;
|
|
|
|
Version maxBranchVersion = maxBranchVersions.get(branchName);
|
|
|
|
if (maxBranchVersion == null) {
|
|
|
|
maxBranchVersions.put(branchName, v);
|
|
|
|
} else if (v.after(maxBranchVersion)) {
|
|
|
|
assertFalse("Version " + maxBranchVersion + " cannot be a snapshot because version " + v + " exists", maxBranchVersion.snapshot());
|
|
|
|
maxBranchVersions.put(branchName, v);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-07-28 12:43:37 +02:00
|
|
|
|
2014-07-28 14:04:34 +02:00
|
|
|
}
|