LUCENE-2385: Move NoDeletionPolicy from benchmark to core

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@932129 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Shai Erera 2010-04-08 21:34:11 +00:00
parent 0a5e6806f3
commit 5792f0d711
7 changed files with 42 additions and 33 deletions

View File

@ -343,6 +343,10 @@ New features
and iterated as byte[] (wrapped in a BytesRef) by IndexReader for and iterated as byte[] (wrapped in a BytesRef) by IndexReader for
searching. searching.
* LUCENE-2385: Moved NoDeletionPolicy from benchmark to core. NoDeletionPolicy
can be used to prevent commits from ever getting deleted from the index.
(Shai Erera)
Optimizations Optimizations
* LUCENE-2075: Terms dict cache is now shared across threads instead * LUCENE-2075: Terms dict cache is now shared across threads instead

View File

@ -35,7 +35,7 @@ content.source=org.apache.lucene.benchmark.byTask.feeds.ReutersContentSource
#query.maker=org.apache.lucene.benchmark.byTask.feeds.SimpleQueryMaker #query.maker=org.apache.lucene.benchmark.byTask.feeds.SimpleQueryMaker
query.maker=org.apache.lucene.benchmark.byTask.feeds.ReutersQueryMaker query.maker=org.apache.lucene.benchmark.byTask.feeds.ReutersQueryMaker
deletion.policy=org.apache.lucene.benchmark.utils.NoDeletionPolicy deletion.policy=org.apache.lucene.index.NoDeletionPolicy
# task at this depth or less would print when they start # task at this depth or less would print when they start
task.max.depth.log=2 task.max.depth.log=2

View File

@ -83,7 +83,7 @@ BASE_INDEX_ALG = '''
analyzer=org.apache.lucene.analysis.standard.StandardAnalyzer analyzer=org.apache.lucene.analysis.standard.StandardAnalyzer
$OTHER$ $OTHER$
deletion.policy = org.apache.lucene.benchmark.utils.NoDeletionPolicy deletion.policy = org.apache.lucene.index.NoDeletionPolicy
doc.tokenized = false doc.tokenized = false
doc.body.tokenized = true doc.body.tokenized = true
doc.stored = true doc.stored = true

View File

@ -25,6 +25,7 @@ import org.apache.lucene.index.IndexWriterConfig;
import org.apache.lucene.index.MergeScheduler; import org.apache.lucene.index.MergeScheduler;
import org.apache.lucene.index.ConcurrentMergeScheduler; import org.apache.lucene.index.ConcurrentMergeScheduler;
import org.apache.lucene.index.MergePolicy; import org.apache.lucene.index.MergePolicy;
import org.apache.lucene.index.NoDeletionPolicy;
import org.apache.lucene.index.NoMergePolicy; import org.apache.lucene.index.NoMergePolicy;
import org.apache.lucene.index.NoMergeScheduler; import org.apache.lucene.index.NoMergeScheduler;
import org.apache.lucene.index.IndexWriterConfig.OpenMode; import org.apache.lucene.index.IndexWriterConfig.OpenMode;
@ -135,23 +136,15 @@ public class CreateIndexTask extends PerfTask {
public static IndexDeletionPolicy getIndexDeletionPolicy(Config config) { public static IndexDeletionPolicy getIndexDeletionPolicy(Config config) {
String deletionPolicyName = config.get("deletion.policy", "org.apache.lucene.index.KeepOnlyLastCommitDeletionPolicy"); String deletionPolicyName = config.get("deletion.policy", "org.apache.lucene.index.KeepOnlyLastCommitDeletionPolicy");
IndexDeletionPolicy indexDeletionPolicy = null; if (deletionPolicyName.equals(NoDeletionPolicy.class.getName())) {
RuntimeException err = null; return NoDeletionPolicy.INSTANCE;
} else {
try { try {
indexDeletionPolicy = Class.forName(deletionPolicyName).asSubclass(IndexDeletionPolicy.class).newInstance(); return Class.forName(deletionPolicyName).asSubclass(IndexDeletionPolicy.class).newInstance();
} catch (IllegalAccessException iae) { } catch (Exception e) {
err = new RuntimeException("unable to instantiate class '" + deletionPolicyName + "' as IndexDeletionPolicy"); throw new RuntimeException("unable to instantiate class '" + deletionPolicyName + "' as IndexDeletionPolicy", e);
err.initCause(iae); }
} catch (InstantiationException ie) {
err = new RuntimeException("unable to instantiate class '" + deletionPolicyName + "' as IndexDeletionPolicy");
err.initCause(ie);
} catch (ClassNotFoundException cnfe) {
err = new RuntimeException("unable to load class '" + deletionPolicyName + "' as IndexDeletionPolicy");
err.initCause(cnfe);
} }
if (err != null)
throw err;
return indexDeletionPolicy;
} }
@Override @Override

View File

@ -25,6 +25,7 @@ import java.util.Properties;
import org.apache.lucene.benchmark.BenchmarkTestCase; import org.apache.lucene.benchmark.BenchmarkTestCase;
import org.apache.lucene.benchmark.byTask.PerfRunData; import org.apache.lucene.benchmark.byTask.PerfRunData;
import org.apache.lucene.benchmark.byTask.utils.Config; import org.apache.lucene.benchmark.byTask.utils.Config;
import org.apache.lucene.index.NoDeletionPolicy;
import org.apache.lucene.index.NoMergePolicy; import org.apache.lucene.index.NoMergePolicy;
import org.apache.lucene.index.NoMergeScheduler; import org.apache.lucene.index.NoMergeScheduler;
@ -95,4 +96,11 @@ public class CreateIndexTaskTest extends BenchmarkTestCase {
new CloseIndexTask(runData).doLogic(); new CloseIndexTask(runData).doLogic();
} }
public void testNoDeletionPolicy() throws Exception {
PerfRunData runData = createPerfRunData(null);
runData.getConfig().set("deletion.policy", NoDeletionPolicy.class.getName());
new CreateIndexTask(runData).doLogic();
new CloseIndexTask(runData).doLogic();
}
} }

View File

@ -1,4 +1,4 @@
package org.apache.lucene.benchmark.utils; package org.apache.lucene.index;
/** /**
* Licensed to the Apache Software Foundation (ASF) under one or more * Licensed to the Apache Software Foundation (ASF) under one or more
@ -20,18 +20,22 @@ package org.apache.lucene.benchmark.utils;
import java.io.IOException; import java.io.IOException;
import java.util.List; import java.util.List;
import org.apache.lucene.index.IndexCommit; /**
import org.apache.lucene.index.IndexDeletionPolicy; * An {@link IndexDeletionPolicy} which keeps all index commits around, never
* deleting them. This class is a singleton and can be accessed by referencing
* {@link #INSTANCE}.
*/
public final class NoDeletionPolicy implements IndexDeletionPolicy {
public class NoDeletionPolicy implements IndexDeletionPolicy { /** The single instance of this class. */
public static final IndexDeletionPolicy INSTANCE = new NoDeletionPolicy();
public void onCommit(List<? extends IndexCommit> commits) throws IOException {
// TODO Auto-generated method stub
private NoDeletionPolicy() {
// keep private to avoid instantiation
} }
public void onInit(List<? extends IndexCommit> commits) throws IOException { public void onCommit(List<? extends IndexCommit> commits) throws IOException {}
// TODO Auto-generated method stub
public void onInit(List<? extends IndexCommit> commits) throws IOException {}
} }
}

View File

@ -46,9 +46,9 @@ public class TestNoMergeScheduler extends LuceneTestCaseJ4 {
@Test @Test
public void testMethodsOverridden() throws Exception { public void testMethodsOverridden() throws Exception {
// Ensures that all methods of MergePolicy are overridden. That's important // Ensures that all methods of MergeScheduler are overridden. That's
// to ensure that NoMergePolicy overrides everything, so that no unexpected // important to ensure that NoMergeScheduler overrides everything, so that
// behavior/error occurs // no unexpected behavior/error occurs
for (Method m : NoMergeScheduler.class.getMethods()) { for (Method m : NoMergeScheduler.class.getMethods()) {
// getDeclaredMethods() returns just those methods that are declared on // getDeclaredMethods() returns just those methods that are declared on
// NoMergeScheduler. getMethods() returns those that are visible in that // NoMergeScheduler. getMethods() returns those that are visible in that