LUCENE-5543: Add allowReadingFilesStillOpenForWrite to MockDirectoryFactory and MockDirectoryWrapper and set it to true for cloud tests.

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1580707 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Mark Robert Miller 2014-03-24 02:47:53 +00:00
parent 742aadf5a2
commit 1567665c96
3 changed files with 19 additions and 1 deletions

View File

@ -75,6 +75,7 @@ public class MockDirectoryWrapper extends BaseDirectoryWrapper {
boolean trackDiskUsage = false; boolean trackDiskUsage = false;
boolean wrapLockFactory = true; boolean wrapLockFactory = true;
boolean allowRandomFileNotFoundException = true; boolean allowRandomFileNotFoundException = true;
boolean allowReadingFilesStillOpenForWrite = false;
private Set<String> unSyncedFiles; private Set<String> unSyncedFiles;
private Set<String> createdFiles; private Set<String> createdFiles;
private Set<String> openFilesForWrite = new HashSet<>(); private Set<String> openFilesForWrite = new HashSet<>();
@ -146,6 +147,12 @@ public class MockDirectoryWrapper extends BaseDirectoryWrapper {
public void setAllowRandomFileNotFoundException(boolean value) { public void setAllowRandomFileNotFoundException(boolean value) {
allowRandomFileNotFoundException = value; allowRandomFileNotFoundException = value;
} }
/** If set to true, you can open an inputstream on a file
* that is still open for writes. */
public void setAllowReadingFilesStillOpenForWrite(boolean value) {
allowReadingFilesStillOpenForWrite = value;
}
/** /**
* Enum for controlling hard disk throttling. * Enum for controlling hard disk throttling.
@ -564,7 +571,7 @@ public class MockDirectoryWrapper extends BaseDirectoryWrapper {
// cannot open a file for input if it's still open for // cannot open a file for input if it's still open for
// output, except for segments.gen and segments_N // output, except for segments.gen and segments_N
if (openFilesForWrite.contains(name) && !name.startsWith("segments")) { if (!allowReadingFilesStillOpenForWrite && openFilesForWrite.contains(name) && !name.startsWith("segments")) {
throw (IOException) fillOpenTrace(new IOException("MockDirectoryWrapper: file \"" + name + "\" is still open for writing"), name, false); throw (IOException) fillOpenTrace(new IOException("MockDirectoryWrapper: file \"" + name + "\" is still open for writing"), name, false);
} }
@ -1004,4 +1011,5 @@ public class MockDirectoryWrapper extends BaseDirectoryWrapper {
* e.g. from {@link MockDirectoryWrapper.Failure}. */ * e.g. from {@link MockDirectoryWrapper.Failure}. */
public static class FakeIOException extends IOException { public static class FakeIOException extends IOException {
} }
} }

View File

@ -30,6 +30,7 @@ import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.SolrZkClient; import org.apache.solr.common.cloud.SolrZkClient;
import org.apache.solr.common.cloud.ZkStateReader; import org.apache.solr.common.cloud.ZkStateReader;
import org.apache.solr.core.Diagnostics; import org.apache.solr.core.Diagnostics;
import org.apache.solr.core.MockDirectoryFactory;
import org.apache.solr.servlet.SolrDispatchFilter; import org.apache.solr.servlet.SolrDispatchFilter;
import org.apache.zookeeper.KeeperException; import org.apache.zookeeper.KeeperException;
import org.junit.After; import org.junit.After;
@ -69,6 +70,7 @@ public abstract class AbstractDistribZkTestBase extends BaseDistributedSearchTes
System.setProperty(ENABLE_UPDATE_LOG, "true"); System.setProperty(ENABLE_UPDATE_LOG, "true");
System.setProperty(REMOVE_VERSION_FIELD, "true"); System.setProperty(REMOVE_VERSION_FIELD, "true");
System.setProperty(ZOOKEEPER_FORCE_SYNC, "false"); System.setProperty(ZOOKEEPER_FORCE_SYNC, "false");
System.setProperty(MockDirectoryFactory.SOLR_TESTS_ALLOW_READING_FILES_STILL_OPEN_FOR_WRITE, "true");
String schema = getSchemaFile(); String schema = getSchemaFile();
if (schema == null) schema = "schema.xml"; if (schema == null) schema = "schema.xml";
@ -224,6 +226,7 @@ public abstract class AbstractDistribZkTestBase extends BaseDistributedSearchTes
System.clearProperty("solr.test.sys.prop1"); System.clearProperty("solr.test.sys.prop1");
System.clearProperty("solr.test.sys.prop2"); System.clearProperty("solr.test.sys.prop2");
System.clearProperty(ZOOKEEPER_FORCE_SYNC); System.clearProperty(ZOOKEEPER_FORCE_SYNC);
System.clearProperty(MockDirectoryFactory.SOLR_TESTS_ALLOW_READING_FILES_STILL_OPEN_FOR_WRITE);
resetExceptionIgnores(); resetExceptionIgnores();
super.tearDown(); super.tearDown();

View File

@ -31,6 +31,9 @@ import org.apache.lucene.util.LuceneTestCase;
* Opens a directory with {@link LuceneTestCase#newDirectory()} * Opens a directory with {@link LuceneTestCase#newDirectory()}
*/ */
public class MockDirectoryFactory extends EphemeralDirectoryFactory { public class MockDirectoryFactory extends EphemeralDirectoryFactory {
public static final String SOLR_TESTS_ALLOW_READING_FILES_STILL_OPEN_FOR_WRITE = "solr.tests.allow_reading_files_still_open_for_write";
private boolean allowReadingFilesStillOpenForWrite = Boolean.getBoolean(SOLR_TESTS_ALLOW_READING_FILES_STILL_OPEN_FOR_WRITE);
@Override @Override
protected Directory create(String path, DirContext dirContext) throws IOException { protected Directory create(String path, DirContext dirContext) throws IOException {
@ -59,6 +62,10 @@ public class MockDirectoryFactory extends EphemeralDirectoryFactory {
// tries to write to index.properties after the file has // tries to write to index.properties after the file has
// already been created. // already been created.
mockDirWrapper.setPreventDoubleWrite(false); mockDirWrapper.setPreventDoubleWrite(false);
if (allowReadingFilesStillOpenForWrite) {
mockDirWrapper.setAllowReadingFilesStillOpenForWrite(true);
}
} }
return dir; return dir;