[TEST] Add test only API that allows to pass the inactive time in NS directly

if we set the inactive time for the shard via API the entire test if fully time
dependent and might fail if we concurrently check if the shard is inactive
while the document we are indexing is in-flight.
This commit is contained in:
Simon Willnauer 2015-11-06 09:16:30 +01:00
parent 54d2b5f3b6
commit 1bff08b2b3
2 changed files with 8 additions and 7 deletions

View File

@ -1034,8 +1034,12 @@ public class IndexShard extends AbstractIndexShardComponent {
* indexing operation, and become inactive (reducing indexing and translog buffers to tiny values) if so. This returns true * indexing operation, and become inactive (reducing indexing and translog buffers to tiny values) if so. This returns true
* if the shard is inactive. */ * if the shard is inactive. */
public boolean checkIdle() { public boolean checkIdle() {
return checkIdle(inactiveTime.nanos());
}
final boolean checkIdle(long inactiveTimeNS) { // pkg private for testing
Engine engineOrNull = getEngineOrNull(); Engine engineOrNull = getEngineOrNull();
if (engineOrNull != null && System.nanoTime() - engineOrNull.getLastWriteNanos() >= inactiveTime.nanos()) { if (engineOrNull != null && System.nanoTime() - engineOrNull.getLastWriteNanos() >= inactiveTimeNS) {
boolean wasActive = active.getAndSet(false); boolean wasActive = active.getAndSet(false);
if (wasActive) { if (wasActive) {
updateBufferSize(IndexingMemoryController.INACTIVE_SHARD_INDEXING_BUFFER, IndexingMemoryController.INACTIVE_SHARD_TRANSLOG_BUFFER); updateBufferSize(IndexingMemoryController.INACTIVE_SHARD_INDEXING_BUFFER, IndexingMemoryController.INACTIVE_SHARD_TRANSLOG_BUFFER);

View File

@ -81,7 +81,6 @@ import org.elasticsearch.indices.recovery.RecoveryState;
import org.elasticsearch.test.DummyShardLock; import org.elasticsearch.test.DummyShardLock;
import org.elasticsearch.test.ESSingleNodeTestCase; import org.elasticsearch.test.ESSingleNodeTestCase;
import org.elasticsearch.test.VersionUtils; import org.elasticsearch.test.VersionUtils;
import org.elasticsearch.test.junit.annotations.TestLogging;
import java.io.IOException; import java.io.IOException;
import java.nio.file.Files; import java.nio.file.Files;
@ -330,15 +329,13 @@ public class IndexShardTests extends ESSingleNodeTestCase {
assertEquals(0, indexShard.getOperationsCount()); assertEquals(0, indexShard.getOperationsCount());
} }
@TestLogging("indices.flush:TRACE,index.shard:TRACE,index.engine:TRACE")
@AwaitsFix(bugUrl = "simonw is working on this")
public void testMarkAsInactiveTriggersSyncedFlush() throws Exception { public void testMarkAsInactiveTriggersSyncedFlush() throws Exception {
assertAcked(client().admin().indices().prepareCreate("test") assertAcked(client().admin().indices().prepareCreate("test")
.setSettings(SETTING_NUMBER_OF_SHARDS, 1, SETTING_NUMBER_OF_REPLICAS, 0, IndexShard.INDEX_SHARD_INACTIVE_TIME_SETTING, "0s")); .setSettings(SETTING_NUMBER_OF_SHARDS, 1, SETTING_NUMBER_OF_REPLICAS, 0));
client().prepareIndex("test", "test").setSource("{}").get();
ensureGreen("test"); ensureGreen("test");
IndicesService indicesService = getInstanceFromNode(IndicesService.class); IndicesService indicesService = getInstanceFromNode(IndicesService.class);
client().prepareIndex("test", "test").setSource("{}").get();// make the shard active... Boolean result = indicesService.indexService("test").getShardOrNull(0).checkIdle(0);
Boolean result = indicesService.indexService("test").getShardOrNull(0).checkIdle();
assertEquals(Boolean.TRUE, result); assertEquals(Boolean.TRUE, result);
assertBusy(() -> { assertBusy(() -> {
IndexStats indexStats = client().admin().indices().prepareStats("test").clear().get().getIndex("test"); IndexStats indexStats = client().admin().indices().prepareStats("test").clear().get().getIndex("test");