Fix IndexShardIT.testIndexCanChangeCustomDataPath() (#43978)

The test IndexShardIT.testIndexCanChangeCustomDataPath() fails
 on 7.x and 7.3 because the translog cannot be recovered.

While I can't reproduce the issue, I think it has been introduced in #43752 
which changed ReadOnlyEngine so that it opens the translog in its 
constructor in order to load the translog stats. This opening writes a 
new checkpoint file, but because 7.x/7.3 does not wait for shards to be 
started after being closed, the test immediately starts to copy shard files
 to a new directory and possibly does not copy all the required translog files.

By waiting for the shards to be started after being closed, we ensure 
that the shards (and engines) have been correctly initialized and that
 the translog checkpoint file is not currently being written.

closes #43964
This commit is contained in:
Tanguy Leroux 2019-07-04 17:06:37 +02:00 committed by GitHub
parent 36f7259737
commit b037aeaa6e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 3 additions and 2 deletions

View File

@ -30,6 +30,7 @@ import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.index.IndexResponse; import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.action.search.SearchRequest; import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.action.support.ActiveShardCount;
import org.elasticsearch.action.support.IndicesOptions; import org.elasticsearch.action.support.IndicesOptions;
import org.elasticsearch.cluster.ClusterInfoService; import org.elasticsearch.cluster.ClusterInfoService;
import org.elasticsearch.cluster.ClusterState; import org.elasticsearch.cluster.ClusterState;
@ -296,7 +297,7 @@ public class IndexShardIT extends ESSingleNodeTestCase {
assertHitCount(client().prepareSearch(index).setSize(0).get(), 1L); assertHitCount(client().prepareSearch(index).setSize(0).get(), 1L);
logger.info("--> closing the index [{}]", index); logger.info("--> closing the index [{}]", index);
assertAcked(client().admin().indices().prepareClose(index)); assertAcked(client().admin().indices().prepareClose(index).setWaitForActiveShards(ActiveShardCount.DEFAULT));
logger.info("--> index closed, re-opening..."); logger.info("--> index closed, re-opening...");
assertAcked(client().admin().indices().prepareOpen(index)); assertAcked(client().admin().indices().prepareOpen(index));
logger.info("--> index re-opened"); logger.info("--> index re-opened");
@ -306,7 +307,7 @@ public class IndexShardIT extends ESSingleNodeTestCase {
// Now, try closing and changing the settings // Now, try closing and changing the settings
logger.info("--> closing the index [{}] before updating data_path", index); logger.info("--> closing the index [{}] before updating data_path", index);
assertAcked(client().admin().indices().prepareClose(index)); assertAcked(client().admin().indices().prepareClose(index).setWaitForActiveShards(ActiveShardCount.DEFAULT));
final Path newIndexDataPath = sharedDataPath.resolve("end-" + randomAlphaOfLength(10)); final Path newIndexDataPath = sharedDataPath.resolve("end-" + randomAlphaOfLength(10));
IOUtils.rm(newIndexDataPath); IOUtils.rm(newIndexDataPath);