speed up directory wrapping
This commit is contained in:
parent
a985c972f2
commit
c7c4045e19
|
@ -45,7 +45,6 @@ import java.util.Set;
|
||||||
public class MockDirectoryHelper {
|
public class MockDirectoryHelper {
|
||||||
public static final String RANDOM_IO_EXCEPTION_RATE = "index.store.mock.random.io_exception_rate";
|
public static final String RANDOM_IO_EXCEPTION_RATE = "index.store.mock.random.io_exception_rate";
|
||||||
public static final String RANDOM_IO_EXCEPTION_RATE_ON_OPEN = "index.store.mock.random.io_exception_rate_on_open";
|
public static final String RANDOM_IO_EXCEPTION_RATE_ON_OPEN = "index.store.mock.random.io_exception_rate_on_open";
|
||||||
public static final String RANDOM_THROTTLE = "index.store.mock.random.throttle";
|
|
||||||
public static final String RANDOM_PREVENT_DOUBLE_WRITE = "index.store.mock.random.prevent_double_write";
|
public static final String RANDOM_PREVENT_DOUBLE_WRITE = "index.store.mock.random.prevent_double_write";
|
||||||
public static final String RANDOM_NO_DELETE_OPEN_FILE = "index.store.mock.random.no_delete_open_file";
|
public static final String RANDOM_NO_DELETE_OPEN_FILE = "index.store.mock.random.no_delete_open_file";
|
||||||
public static final String CRASH_INDEX = "index.store.mock.random.crash_index";
|
public static final String CRASH_INDEX = "index.store.mock.random.crash_index";
|
||||||
|
@ -70,7 +69,7 @@ public class MockDirectoryHelper {
|
||||||
preventDoubleWrite = indexSettings.getAsBoolean(RANDOM_PREVENT_DOUBLE_WRITE, true); // true is default in MDW
|
preventDoubleWrite = indexSettings.getAsBoolean(RANDOM_PREVENT_DOUBLE_WRITE, true); // true is default in MDW
|
||||||
noDeleteOpenFile = indexSettings.getAsBoolean(RANDOM_NO_DELETE_OPEN_FILE, random.nextBoolean()); // true is default in MDW
|
noDeleteOpenFile = indexSettings.getAsBoolean(RANDOM_NO_DELETE_OPEN_FILE, random.nextBoolean()); // true is default in MDW
|
||||||
random.nextInt(shardId.getId() + 1); // some randomness per shard
|
random.nextInt(shardId.getId() + 1); // some randomness per shard
|
||||||
throttle = Throttling.valueOf(indexSettings.get(RANDOM_THROTTLE, random.nextDouble() < 0.1 ? "SOMETIMES" : "NEVER"));
|
throttle = Throttling.NEVER;
|
||||||
crashIndex = indexSettings.getAsBoolean(CRASH_INDEX, true);
|
crashIndex = indexSettings.getAsBoolean(CRASH_INDEX, true);
|
||||||
|
|
||||||
if (logger.isDebugEnabled()) {
|
if (logger.isDebugEnabled()) {
|
||||||
|
@ -92,6 +91,7 @@ public class MockDirectoryHelper {
|
||||||
// TODO: make this test robust to virus scanner
|
// TODO: make this test robust to virus scanner
|
||||||
w.setEnableVirusScanner(false);
|
w.setEnableVirusScanner(false);
|
||||||
w.setNoDeleteOpenFile(noDeleteOpenFile);
|
w.setNoDeleteOpenFile(noDeleteOpenFile);
|
||||||
|
w.setUseSlowOpenClosers(false);
|
||||||
wrappers.add(w);
|
wrappers.add(w);
|
||||||
return w;
|
return w;
|
||||||
}
|
}
|
||||||
|
@ -115,7 +115,10 @@ public class MockDirectoryHelper {
|
||||||
case 1:
|
case 1:
|
||||||
return new MmapFsDirectoryService(shardId, indexSettings, indexStore);
|
return new MmapFsDirectoryService(shardId, indexSettings, indexStore);
|
||||||
case 0:
|
case 0:
|
||||||
return new SimpleFsDirectoryService(shardId, indexSettings, indexStore);
|
if (random.nextInt(10) == 0) {
|
||||||
|
// use simplefs less, it synchronizes all threads reads
|
||||||
|
return new SimpleFsDirectoryService(shardId, indexSettings, indexStore);
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
return new NioFsDirectoryService(shardId, indexSettings, indexStore);
|
return new NioFsDirectoryService(shardId, indexSettings, indexStore);
|
||||||
}
|
}
|
||||||
|
@ -184,7 +187,7 @@ public class MockDirectoryHelper {
|
||||||
@Override
|
@Override
|
||||||
public synchronized void sync(Collection<String> names) throws IOException {
|
public synchronized void sync(Collection<String> names) throws IOException {
|
||||||
// don't wear out our hardware so much in tests.
|
// don't wear out our hardware so much in tests.
|
||||||
if (LuceneTestCase.rarely(superRandomState) || mustSync()) {
|
if (superRandomState.nextInt(100) == 0 || mustSync()) {
|
||||||
super.sync(names);
|
super.sync(names);
|
||||||
} else {
|
} else {
|
||||||
superUnSyncedFiles.removeAll(names);
|
superUnSyncedFiles.removeAll(names);
|
||||||
|
|
Loading…
Reference in New Issue