mirror of https://github.com/apache/lucene.git
LUCENE-812: make sure Native/SimpleFSLockFactory can be set via system property
git-svn-id: https://svn.apache.org/repos/asf/lucene/java/trunk@512493 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
178500b09c
commit
66d4eb336f
|
@ -29,6 +29,11 @@ Bug fixes
|
||||||
that there is a single trailing wildcard (and no additional wildcard
|
that there is a single trailing wildcard (and no additional wildcard
|
||||||
or '?' in the query text). (Doron Cohen)
|
or '?' in the query text). (Doron Cohen)
|
||||||
|
|
||||||
|
3. LUCENE-812: Add no-argument constructors to NativeFSLockFactory
|
||||||
|
and SimpleFSLockFactory. This enables all 4 builtin LockFactory
|
||||||
|
implementations to be specified via the System property
|
||||||
|
org.apache.lucene.store.FSDirectoryLockFactoryClass. (Mike McCandless)
|
||||||
|
|
||||||
Optimizations
|
Optimizations
|
||||||
|
|
||||||
======================= Release 2.1.0 2007-02-14 =======================
|
======================= Release 2.1.0 2007-02-14 =======================
|
||||||
|
|
|
@ -291,6 +291,12 @@ public class FSDirectory extends Directory {
|
||||||
} catch (ClassCastException e) {
|
} catch (ClassCastException e) {
|
||||||
throw new IOException("unable to cast LockClass " + lockClassName + " instance to a LockFactory");
|
throw new IOException("unable to cast LockClass " + lockClassName + " instance to a LockFactory");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (lockFactory instanceof NativeFSLockFactory) {
|
||||||
|
((NativeFSLockFactory) lockFactory).setLockDir(path);
|
||||||
|
} else if (lockFactory instanceof SimpleFSLockFactory) {
|
||||||
|
((SimpleFSLockFactory) lockFactory).setLockDir(path);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// Our default lock is SimpleFSLockFactory;
|
// Our default lock is SimpleFSLockFactory;
|
||||||
// default lockDir is our index directory:
|
// default lockDir is our index directory:
|
||||||
|
|
|
@ -52,10 +52,6 @@ import java.util.Random;
|
||||||
* is fine because the OS will free the locks held against
|
* is fine because the OS will free the locks held against
|
||||||
* these files even though the files still remain.</p>
|
* these files even though the files still remain.</p>
|
||||||
*
|
*
|
||||||
* <p>Native locks file names have the substring "-n-", which
|
|
||||||
* you can use to differentiate them from lock files created
|
|
||||||
* by {@link SimpleFSLockFactory}.</p>
|
|
||||||
*
|
|
||||||
* @see LockFactory
|
* @see LockFactory
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -90,6 +86,17 @@ public class NativeFSLockFactory extends LockFactory {
|
||||||
l.release();
|
l.release();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a NativeFSLockFactory instance, with null (unset)
|
||||||
|
* lock directory. This is package-private and is only
|
||||||
|
* used by FSDirectory when creating this LockFactory via
|
||||||
|
* the System property
|
||||||
|
* org.apache.lucene.store.FSDirectoryLockFactoryClass.
|
||||||
|
*/
|
||||||
|
NativeFSLockFactory() throws IOException {
|
||||||
|
this((File) null);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a NativeFSLockFactory instance, storing lock
|
* Create a NativeFSLockFactory instance, storing lock
|
||||||
* files into the specified lockDirName:
|
* files into the specified lockDirName:
|
||||||
|
@ -107,20 +114,30 @@ public class NativeFSLockFactory extends LockFactory {
|
||||||
* @param lockDir where lock files are created.
|
* @param lockDir where lock files are created.
|
||||||
*/
|
*/
|
||||||
public NativeFSLockFactory(File lockDir) throws IOException {
|
public NativeFSLockFactory(File lockDir) throws IOException {
|
||||||
|
setLockDir(lockDir);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the lock directory. This is package-private and is
|
||||||
|
* only used externally by FSDirectory when creating this
|
||||||
|
* LockFactory via the System property
|
||||||
|
* org.apache.lucene.store.FSDirectoryLockFactoryClass.
|
||||||
|
*/
|
||||||
|
void setLockDir(File lockDir) throws IOException {
|
||||||
this.lockDir = lockDir;
|
this.lockDir = lockDir;
|
||||||
|
if (lockDir != null) {
|
||||||
// Ensure that lockDir exists and is a directory.
|
// Ensure that lockDir exists and is a directory.
|
||||||
if (!lockDir.exists()) {
|
if (!lockDir.exists()) {
|
||||||
if (!lockDir.mkdirs())
|
if (!lockDir.mkdirs())
|
||||||
throw new IOException("Cannot create directory: " +
|
throw new IOException("Cannot create directory: " +
|
||||||
|
lockDir.getAbsolutePath());
|
||||||
|
} else if (!lockDir.isDirectory()) {
|
||||||
|
throw new IOException("Found regular file where directory expected: " +
|
||||||
lockDir.getAbsolutePath());
|
lockDir.getAbsolutePath());
|
||||||
} else if (!lockDir.isDirectory()) {
|
}
|
||||||
throw new IOException("Found regular file where directory expected: " +
|
|
||||||
lockDir.getAbsolutePath());
|
|
||||||
}
|
|
||||||
|
|
||||||
acquireTestLock();
|
acquireTestLock();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized Lock makeLock(String lockName) {
|
public synchronized Lock makeLock(String lockName) {
|
||||||
|
|
|
@ -40,12 +40,23 @@ public class SimpleFSLockFactory extends LockFactory {
|
||||||
|
|
||||||
private File lockDir;
|
private File lockDir;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a SimpleFSLockFactory instance, with null (unset)
|
||||||
|
* lock directory. This is package-private and is only
|
||||||
|
* used by FSDirectory when creating this LockFactory via
|
||||||
|
* the System property
|
||||||
|
* org.apache.lucene.store.FSDirectoryLockFactoryClass.
|
||||||
|
*/
|
||||||
|
SimpleFSLockFactory() throws IOException {
|
||||||
|
this((File) null);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instantiate using the provided directory (as a File instance).
|
* Instantiate using the provided directory (as a File instance).
|
||||||
* @param lockDir where lock files should be created.
|
* @param lockDir where lock files should be created.
|
||||||
*/
|
*/
|
||||||
public SimpleFSLockFactory(File lockDir) throws IOException {
|
public SimpleFSLockFactory(File lockDir) throws IOException {
|
||||||
init(lockDir);
|
setLockDir(lockDir);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -54,10 +65,16 @@ public class SimpleFSLockFactory extends LockFactory {
|
||||||
*/
|
*/
|
||||||
public SimpleFSLockFactory(String lockDirName) throws IOException {
|
public SimpleFSLockFactory(String lockDirName) throws IOException {
|
||||||
lockDir = new File(lockDirName);
|
lockDir = new File(lockDirName);
|
||||||
init(lockDir);
|
setLockDir(lockDir);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void init(File lockDir) throws IOException {
|
/**
|
||||||
|
* Set the lock directory. This is package-private and is
|
||||||
|
* only used externally by FSDirectory when creating this
|
||||||
|
* LockFactory via the System property
|
||||||
|
* org.apache.lucene.store.FSDirectoryLockFactoryClass.
|
||||||
|
*/
|
||||||
|
void setLockDir(File lockDir) throws IOException {
|
||||||
this.lockDir = lockDir;
|
this.lockDir = lockDir;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -197,23 +197,47 @@ public class TestLockFactory extends TestCase {
|
||||||
|
|
||||||
|
|
||||||
// Verify: setting custom lock factory class (as system property) works:
|
// Verify: setting custom lock factory class (as system property) works:
|
||||||
|
// Verify: all 4 builtin LockFactory implementations are
|
||||||
|
// settable this way
|
||||||
// Verify: FSDirectory does basic locking correctly
|
// Verify: FSDirectory does basic locking correctly
|
||||||
public void testLockClassProperty() throws IOException {
|
public void testLockClassProperty() throws IOException {
|
||||||
String indexDirName = "index.TestLockFactory3";
|
String indexDirName = "index.TestLockFactory3";
|
||||||
|
String prpName = "org.apache.lucene.store.FSDirectoryLockFactoryClass";
|
||||||
|
|
||||||
System.setProperty("org.apache.lucene.store.FSDirectoryLockFactoryClass",
|
try {
|
||||||
"org.apache.lucene.store.NoLockFactory");
|
|
||||||
|
|
||||||
IndexWriter writer = new IndexWriter(indexDirName, new WhitespaceAnalyzer(), true);
|
// NoLockFactory:
|
||||||
|
System.setProperty(prpName, "org.apache.lucene.store.NoLockFactory");
|
||||||
|
IndexWriter writer = new IndexWriter(indexDirName, new WhitespaceAnalyzer(), true);
|
||||||
|
assertTrue("FSDirectory did not use correct LockFactory: got " + writer.getDirectory().getLockFactory(),
|
||||||
|
NoLockFactory.class.isInstance(writer.getDirectory().getLockFactory()));
|
||||||
|
writer.close();
|
||||||
|
|
||||||
assertTrue("FSDirectory did not use correct LockFactory: got " + writer.getDirectory().getLockFactory(),
|
// SingleInstanceLockFactory:
|
||||||
NoLockFactory.class.isInstance(writer.getDirectory().getLockFactory()));
|
System.setProperty(prpName, "org.apache.lucene.store.SingleInstanceLockFactory");
|
||||||
|
writer = new IndexWriter(indexDirName, new WhitespaceAnalyzer(), true);
|
||||||
|
assertTrue("FSDirectory did not use correct LockFactory: got " + writer.getDirectory().getLockFactory(),
|
||||||
|
SingleInstanceLockFactory.class.isInstance(writer.getDirectory().getLockFactory()));
|
||||||
|
writer.close();
|
||||||
|
|
||||||
// Put back to the correct default for subsequent tests:
|
// NativeFSLockFactory:
|
||||||
// System.clearProperty("org.apache.lucene.store.FSDirectoryLockFactoryClass");
|
System.setProperty(prpName, "org.apache.lucene.store.NativeFSLockFactory");
|
||||||
System.setProperty("org.apache.lucene.store.FSDirectoryLockFactoryClass", "");
|
writer = new IndexWriter(indexDirName, new WhitespaceAnalyzer(), true);
|
||||||
|
assertTrue("FSDirectory did not use correct LockFactory: got " + writer.getDirectory().getLockFactory(),
|
||||||
|
NativeFSLockFactory.class.isInstance(writer.getDirectory().getLockFactory()));
|
||||||
|
writer.close();
|
||||||
|
|
||||||
|
// SimpleFSLockFactory:
|
||||||
|
System.setProperty(prpName, "org.apache.lucene.store.SimpleFSLockFactory");
|
||||||
|
writer = new IndexWriter(indexDirName, new WhitespaceAnalyzer(), true);
|
||||||
|
assertTrue("FSDirectory did not use correct LockFactory: got " + writer.getDirectory().getLockFactory(),
|
||||||
|
SimpleFSLockFactory.class.isInstance(writer.getDirectory().getLockFactory()));
|
||||||
|
writer.close();
|
||||||
|
} finally {
|
||||||
|
// Put back to the correct default for subsequent tests:
|
||||||
|
System.setProperty("org.apache.lucene.store.FSDirectoryLockFactoryClass", "");
|
||||||
|
}
|
||||||
|
|
||||||
writer.close();
|
|
||||||
// Cleanup
|
// Cleanup
|
||||||
rmDir(indexDirName);
|
rmDir(indexDirName);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue