Merge branch 'master' into close-index-api-refactoring
This commit is contained in:
commit
096a83183e
|
@ -51,10 +51,6 @@ public class SnapshotException extends ElasticsearchException {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public SnapshotException(final String repositoryName, final SnapshotId snapshotId, final String msg) {
|
|
||||||
this(repositoryName, snapshotId, msg, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
public SnapshotException(final String repositoryName, final SnapshotId snapshotId, final String msg, final Throwable cause) {
|
public SnapshotException(final String repositoryName, final SnapshotId snapshotId, final String msg, final Throwable cause) {
|
||||||
super("[" + repositoryName + ":" + snapshotId + "] " + msg, cause);
|
super("[" + repositoryName + ":" + snapshotId + "] " + msg, cause);
|
||||||
this.repositoryName = repositoryName;
|
this.repositoryName = repositoryName;
|
||||||
|
|
|
@ -131,25 +131,17 @@ public final class SnapshotId implements Comparable<SnapshotId>, Writeable, ToXC
|
||||||
}
|
}
|
||||||
|
|
||||||
public static SnapshotId fromXContent(XContentParser parser) throws IOException {
|
public static SnapshotId fromXContent(XContentParser parser) throws IOException {
|
||||||
// the new format from 5.0 which contains the snapshot name and uuid
|
String name = null;
|
||||||
if (parser.currentToken() == XContentParser.Token.START_OBJECT) {
|
String uuid = null;
|
||||||
String name = null;
|
while (parser.nextToken() != XContentParser.Token.END_OBJECT) {
|
||||||
String uuid = null;
|
String currentFieldName = parser.currentName();
|
||||||
while (parser.nextToken() != XContentParser.Token.END_OBJECT) {
|
parser.nextToken();
|
||||||
String currentFieldName = parser.currentName();
|
if (NAME.equals(currentFieldName)) {
|
||||||
parser.nextToken();
|
name = parser.text();
|
||||||
if (NAME.equals(currentFieldName)) {
|
} else if (UUID.equals(currentFieldName)) {
|
||||||
name = parser.text();
|
uuid = parser.text();
|
||||||
} else if (UUID.equals(currentFieldName)) {
|
|
||||||
uuid = parser.text();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return new SnapshotId(name, uuid);
|
|
||||||
} else {
|
|
||||||
// the old format pre 5.0 that only contains the snapshot name, use the name as the uuid too
|
|
||||||
final String name = parser.text();
|
|
||||||
return new SnapshotId(name, name);
|
|
||||||
}
|
}
|
||||||
|
return new SnapshotId(name, uuid);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,7 +94,7 @@ import static org.elasticsearch.transport.EmptyTransportResponseHandler.INSTANCE
|
||||||
public class SnapshotShardsService extends AbstractLifecycleComponent implements ClusterStateListener, IndexEventListener {
|
public class SnapshotShardsService extends AbstractLifecycleComponent implements ClusterStateListener, IndexEventListener {
|
||||||
private static final Logger logger = LogManager.getLogger(SnapshotShardsService.class);
|
private static final Logger logger = LogManager.getLogger(SnapshotShardsService.class);
|
||||||
|
|
||||||
public static final String UPDATE_SNAPSHOT_STATUS_ACTION_NAME = "internal:cluster/snapshot/update_snapshot_status";
|
private static final String UPDATE_SNAPSHOT_STATUS_ACTION_NAME = "internal:cluster/snapshot/update_snapshot_status";
|
||||||
|
|
||||||
private final ClusterService clusterService;
|
private final ClusterService clusterService;
|
||||||
|
|
||||||
|
|
|
@ -515,7 +515,7 @@ public class SnapshotsService extends AbstractLifecycleComponent implements Clus
|
||||||
cleanupAfterError(e);
|
cleanupAfterError(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onNoLongerMaster(String source) {
|
public void onNoLongerMaster() {
|
||||||
userCreateSnapshotListener.onFailure(e);
|
userCreateSnapshotListener.onFailure(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1073,7 +1073,7 @@ public class SnapshotsService extends AbstractLifecycleComponent implements Clus
|
||||||
@Override
|
@Override
|
||||||
public void onNoLongerMaster(String source) {
|
public void onNoLongerMaster(String source) {
|
||||||
if (listener != null) {
|
if (listener != null) {
|
||||||
listener.onNoLongerMaster(source);
|
listener.onNoLongerMaster();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1423,8 +1423,6 @@ public class SnapshotsService extends AbstractLifecycleComponent implements Clus
|
||||||
builder.put(shardId,
|
builder.put(shardId,
|
||||||
new SnapshotsInProgress.ShardSnapshotStatus(null, State.MISSING, "primary shard is not allocated"));
|
new SnapshotsInProgress.ShardSnapshotStatus(null, State.MISSING, "primary shard is not allocated"));
|
||||||
} else if (primary.relocating() || primary.initializing()) {
|
} else if (primary.relocating() || primary.initializing()) {
|
||||||
// The WAITING state was introduced in V1.2.0 -
|
|
||||||
// don't use it if there are nodes with older version in the cluster
|
|
||||||
builder.put(shardId, new SnapshotsInProgress.ShardSnapshotStatus(primary.currentNodeId(), State.WAITING));
|
builder.put(shardId, new SnapshotsInProgress.ShardSnapshotStatus(primary.currentNodeId(), State.WAITING));
|
||||||
} else if (!primary.started()) {
|
} else if (!primary.started()) {
|
||||||
builder.put(shardId,
|
builder.put(shardId,
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.cluster.coordination;
|
package org.elasticsearch.cluster.coordination;
|
||||||
|
|
||||||
|
import com.carrotsearch.randomizedtesting.RandomizedContext;
|
||||||
import org.apache.logging.log4j.CloseableThreadContext;
|
import org.apache.logging.log4j.CloseableThreadContext;
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
|
@ -70,6 +71,7 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import java.util.concurrent.Callable;
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
|
@ -128,6 +130,24 @@ public class CoordinatorTests extends ESTestCase {
|
||||||
resetPortCounter();
|
resetPortCounter();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// check that runRandomly leads to reproducible results
|
||||||
|
public void testRepeatableTests() throws Exception {
|
||||||
|
final Callable<Long> test = () -> {
|
||||||
|
final Cluster cluster = new Cluster(randomIntBetween(1, 5));
|
||||||
|
cluster.runRandomly();
|
||||||
|
final long afterRunRandomly = value(cluster.getAnyNode().getLastAppliedClusterState());
|
||||||
|
cluster.stabilise();
|
||||||
|
final long afterStabilisation = value(cluster.getAnyNode().getLastAppliedClusterState());
|
||||||
|
return afterRunRandomly ^ afterStabilisation;
|
||||||
|
};
|
||||||
|
final long seed = randomLong();
|
||||||
|
logger.info("First run with seed [{}]", seed);
|
||||||
|
final long result1 = RandomizedContext.current().runWithPrivateRandomness(seed, test);
|
||||||
|
logger.info("Second run with seed [{}]", seed);
|
||||||
|
final long result2 = RandomizedContext.current().runWithPrivateRandomness(seed, test);
|
||||||
|
assertEquals(result1, result2);
|
||||||
|
}
|
||||||
|
|
||||||
public void testCanUpdateClusterStateAfterStabilisation() {
|
public void testCanUpdateClusterStateAfterStabilisation() {
|
||||||
final Cluster cluster = new Cluster(randomIntBetween(1, 5));
|
final Cluster cluster = new Cluster(randomIntBetween(1, 5));
|
||||||
cluster.runRandomly();
|
cluster.runRandomly();
|
||||||
|
|
|
@ -72,6 +72,9 @@ public class TimeoutCheckerTests extends FileStructureTestCase {
|
||||||
} finally {
|
} finally {
|
||||||
TimeoutChecker.watchdog.unregister();
|
TimeoutChecker.watchdog.unregister();
|
||||||
}
|
}
|
||||||
|
} finally {
|
||||||
|
// ensure the interrupted flag is cleared to stop it making subsequent tests fail
|
||||||
|
Thread.interrupted();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -89,6 +92,9 @@ public class TimeoutCheckerTests extends FileStructureTestCase {
|
||||||
assertEquals("Aborting grok captures test during [should timeout] as it has taken longer than the timeout of [" +
|
assertEquals("Aborting grok captures test during [should timeout] as it has taken longer than the timeout of [" +
|
||||||
timeout + "]", e.getMessage());
|
timeout + "]", e.getMessage());
|
||||||
});
|
});
|
||||||
|
} finally {
|
||||||
|
// ensure the interrupted flag is cleared to stop it making subsequent tests fail
|
||||||
|
Thread.interrupted();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue