mirror of https://github.com/apache/lucene.git
LUCENE-3847: LuceneTestCase will now check for modifications of System properties before and after each test (and suite). If changes are detected, the test will fail. A rule can be used to reset system properties to before-scope state (and this has been used to make Solr tests pass).
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1296888 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
726ac1883a
commit
ff27ca3738
|
@ -928,6 +928,12 @@ Documentation
|
||||||
|
|
||||||
Build
|
Build
|
||||||
|
|
||||||
|
* LUCENE-3847: LuceneTestCase will now check for modifications of System
|
||||||
|
properties before and after each test (and suite). If changes are detected,
|
||||||
|
the test will fail. A rule can be used to reset system properties to
|
||||||
|
before-scope state (and this has been used to make Solr tests pass).
|
||||||
|
(Dawid Weiss).
|
||||||
|
|
||||||
* LUCENE-3228: Stop downloading external javadoc package-list files:
|
* LUCENE-3228: Stop downloading external javadoc package-list files:
|
||||||
|
|
||||||
- Added package-list files for Oracle Java javadocs and JUnit javadocs to
|
- Added package-list files for Oracle Java javadocs and JUnit javadocs to
|
||||||
|
|
|
@ -0,0 +1,74 @@
|
||||||
|
package org.apache.lucene.util.junitcompat;
|
||||||
|
|
||||||
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.junit.AfterClass;
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.JUnitCore;
|
||||||
|
import org.junit.runner.Result;
|
||||||
|
import org.junit.runner.notification.Failure;
|
||||||
|
|
||||||
|
public class TestSystemPropertiesInvariantRule {
|
||||||
|
public static final String PROP_KEY1 = "new-property-1";
|
||||||
|
public static final String VALUE1 = "new-value-1";
|
||||||
|
|
||||||
|
public static class Base extends LuceneTestCase {
|
||||||
|
public void testEmpty() {}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class InBeforeClass extends Base {
|
||||||
|
@BeforeClass
|
||||||
|
public static void beforeClass() {
|
||||||
|
System.setProperty(PROP_KEY1, VALUE1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class InAfterClass extends Base {
|
||||||
|
@AfterClass
|
||||||
|
public static void afterClass() {
|
||||||
|
System.setProperty(PROP_KEY1, VALUE1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class InTestMethod extends Base {
|
||||||
|
public void testMethod1() {
|
||||||
|
if (System.getProperty(PROP_KEY1) != null) {
|
||||||
|
throw new RuntimeException("Shouldn't be here.");
|
||||||
|
}
|
||||||
|
System.setProperty(PROP_KEY1, VALUE1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testMethod2() {
|
||||||
|
testMethod1();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRuleInvariantBeforeClass() {
|
||||||
|
Result runClasses = JUnitCore.runClasses(InBeforeClass.class);
|
||||||
|
Assert.assertEquals(1, runClasses.getFailureCount());
|
||||||
|
Assert.assertTrue(runClasses.getFailures().get(0).getMessage()
|
||||||
|
.contains(PROP_KEY1));
|
||||||
|
Assert.assertNull(System.getProperty(PROP_KEY1));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRuleInvariantAfterClass() {
|
||||||
|
Result runClasses = JUnitCore.runClasses(InAfterClass.class);
|
||||||
|
Assert.assertEquals(1, runClasses.getFailureCount());
|
||||||
|
Assert.assertTrue(runClasses.getFailures().get(0).getMessage()
|
||||||
|
.contains(PROP_KEY1));
|
||||||
|
Assert.assertNull(System.getProperty(PROP_KEY1));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRuleInvariantInTestMethod() {
|
||||||
|
Result runClasses = JUnitCore.runClasses(InTestMethod.class);
|
||||||
|
Assert.assertEquals(2, runClasses.getFailureCount());
|
||||||
|
for (Failure f : runClasses.getFailures()) {
|
||||||
|
Assert.assertTrue(f.getMessage().contains(PROP_KEY1));
|
||||||
|
}
|
||||||
|
Assert.assertNull(System.getProperty(PROP_KEY1));
|
||||||
|
}
|
||||||
|
}
|
|
@ -97,6 +97,7 @@ import org.junit.Assert;
|
||||||
import org.junit.Assume;
|
import org.junit.Assume;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.ClassRule;
|
||||||
import org.junit.Ignore;
|
import org.junit.Ignore;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.internal.AssumptionViolatedException;
|
import org.junit.internal.AssumptionViolatedException;
|
||||||
|
@ -257,6 +258,11 @@ public abstract class LuceneTestCase extends Assert {
|
||||||
private static TimeZone timeZone;
|
private static TimeZone timeZone;
|
||||||
private static TimeZone savedTimeZone;
|
private static TimeZone savedTimeZone;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Restore these system property values in {@link #afterClassLuceneTestCaseJ4()}.
|
||||||
|
*/
|
||||||
|
private static HashMap<String, String> restoreProperties = new HashMap<String,String>();
|
||||||
|
|
||||||
protected static Map<MockDirectoryWrapper,StackTraceElement[]> stores;
|
protected static Map<MockDirectoryWrapper,StackTraceElement[]> stores;
|
||||||
|
|
||||||
/** @deprecated (4.0) until we fix no-fork problems in solr tests */
|
/** @deprecated (4.0) until we fix no-fork problems in solr tests */
|
||||||
|
@ -273,6 +279,9 @@ public abstract class LuceneTestCase extends Assert {
|
||||||
@Deprecated
|
@Deprecated
|
||||||
private static boolean icuTested = false;
|
private static boolean icuTested = false;
|
||||||
|
|
||||||
|
@ClassRule
|
||||||
|
public static TestRule classRules = RuleChain.outerRule(new SystemPropertiesInvariantRule());
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public static void beforeClassLuceneTestCaseJ4() {
|
public static void beforeClassLuceneTestCaseJ4() {
|
||||||
initRandom();
|
initRandom();
|
||||||
|
@ -282,6 +291,7 @@ public abstract class LuceneTestCase extends Assert {
|
||||||
// enable this by default, for IDE consistency with ant tests (as its the default from ant)
|
// enable this by default, for IDE consistency with ant tests (as its the default from ant)
|
||||||
// TODO: really should be in solr base classes, but some extend LTC directly.
|
// TODO: really should be in solr base classes, but some extend LTC directly.
|
||||||
// we do this in beforeClass, because some tests currently disable it
|
// we do this in beforeClass, because some tests currently disable it
|
||||||
|
restoreProperties.put("solr.directoryFactory", System.getProperty("solr.directoryFactory"));
|
||||||
if (System.getProperty("solr.directoryFactory") == null) {
|
if (System.getProperty("solr.directoryFactory") == null) {
|
||||||
System.setProperty("solr.directoryFactory", "org.apache.solr.core.MockDirectoryFactory");
|
System.setProperty("solr.directoryFactory", "org.apache.solr.core.MockDirectoryFactory");
|
||||||
}
|
}
|
||||||
|
@ -363,6 +373,9 @@ public abstract class LuceneTestCase extends Assert {
|
||||||
|
|
||||||
locale = TEST_LOCALE.equals("random") ? randomLocale(random) : localeForName(TEST_LOCALE);
|
locale = TEST_LOCALE.equals("random") ? randomLocale(random) : localeForName(TEST_LOCALE);
|
||||||
Locale.setDefault(locale);
|
Locale.setDefault(locale);
|
||||||
|
// TimeZone.getDefault will set user.timezone to the default timezone of the user's locale.
|
||||||
|
// So store the original property value and restore it at end.
|
||||||
|
restoreProperties.put("user.timezone", System.getProperty("user.timezone"));
|
||||||
savedTimeZone = TimeZone.getDefault();
|
savedTimeZone = TimeZone.getDefault();
|
||||||
timeZone = TEST_TIMEZONE.equals("random") ? randomTimeZone(random) : TimeZone.getTimeZone(TEST_TIMEZONE);
|
timeZone = TEST_TIMEZONE.equals("random") ? randomTimeZone(random) : TimeZone.getTimeZone(TEST_TIMEZONE);
|
||||||
TimeZone.setDefault(timeZone);
|
TimeZone.setDefault(timeZone);
|
||||||
|
@ -372,6 +385,15 @@ public abstract class LuceneTestCase extends Assert {
|
||||||
|
|
||||||
@AfterClass
|
@AfterClass
|
||||||
public static void afterClassLuceneTestCaseJ4() {
|
public static void afterClassLuceneTestCaseJ4() {
|
||||||
|
for (Map.Entry<String,String> e : restoreProperties.entrySet()) {
|
||||||
|
if (e.getValue() == null) {
|
||||||
|
System.clearProperty(e.getKey());
|
||||||
|
} else {
|
||||||
|
System.setProperty(e.getKey(), e.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
restoreProperties.clear();
|
||||||
|
|
||||||
Throwable problem = null;
|
Throwable problem = null;
|
||||||
|
|
||||||
if (! "false".equals(TEST_CLEAN_THREADS)) {
|
if (! "false".equals(TEST_CLEAN_THREADS)) {
|
||||||
|
@ -587,6 +609,7 @@ public abstract class LuceneTestCase extends Assert {
|
||||||
public final TestRule ruleChain = RuleChain
|
public final TestRule ruleChain = RuleChain
|
||||||
.outerRule(new RememberThreadRule())
|
.outerRule(new RememberThreadRule())
|
||||||
.around(new TestResultInterceptorRule())
|
.around(new TestResultInterceptorRule())
|
||||||
|
.around(new SystemPropertiesInvariantRule())
|
||||||
.around(new InternalSetupTeardownRule())
|
.around(new InternalSetupTeardownRule())
|
||||||
.around(new SubclassSetupTeardownRule());
|
.around(new SubclassSetupTeardownRule());
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,94 @@
|
||||||
|
package org.apache.lucene.util;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.TreeMap;
|
||||||
|
import java.util.TreeSet;
|
||||||
|
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
|
import org.junit.runner.Description;
|
||||||
|
import org.junit.runners.model.MultipleFailureException;
|
||||||
|
import org.junit.runners.model.Statement;
|
||||||
|
|
||||||
|
public class SystemPropertiesInvariantRule implements TestRule {
|
||||||
|
@Override
|
||||||
|
public Statement apply(final Statement s, Description d) {
|
||||||
|
return new Statement() {
|
||||||
|
@Override
|
||||||
|
public void evaluate() throws Throwable {
|
||||||
|
TreeMap<String,String> before = SystemPropertiesRestoreRule.cloneAsMap(System.getProperties());
|
||||||
|
ArrayList<Throwable> errors = new ArrayList<Throwable>();
|
||||||
|
try {
|
||||||
|
s.evaluate();
|
||||||
|
} catch (Throwable t) {
|
||||||
|
errors.add(t);
|
||||||
|
} finally {
|
||||||
|
TreeMap<String,String> after = SystemPropertiesRestoreRule.cloneAsMap(System.getProperties());
|
||||||
|
if (!after.equals(before)) {
|
||||||
|
errors.add(
|
||||||
|
new AssertionError("System properties invariant violated.\n" +
|
||||||
|
collectErrorMessage(before, after)));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Restore original properties.
|
||||||
|
SystemPropertiesRestoreRule.restore(before, after);
|
||||||
|
}
|
||||||
|
|
||||||
|
MultipleFailureException.assertEmpty(errors);
|
||||||
|
}
|
||||||
|
|
||||||
|
private StringBuilder collectErrorMessage(
|
||||||
|
TreeMap<String,String> before, TreeMap<String,String> after) {
|
||||||
|
TreeSet<String> newKeys = new TreeSet<String>(after.keySet());
|
||||||
|
newKeys.removeAll(before.keySet());
|
||||||
|
|
||||||
|
TreeSet<String> missingKeys = new TreeSet<String>(before.keySet());
|
||||||
|
missingKeys.removeAll(after.keySet());
|
||||||
|
|
||||||
|
TreeSet<String> differentKeyValues = new TreeSet<String>(before.keySet());
|
||||||
|
differentKeyValues.retainAll(after.keySet());
|
||||||
|
for (Iterator<String> i = differentKeyValues.iterator(); i.hasNext();) {
|
||||||
|
String key = i.next();
|
||||||
|
String valueBefore = before.get(key);
|
||||||
|
String valueAfter = after.get(key);
|
||||||
|
if ((valueBefore == null && valueAfter == null) ||
|
||||||
|
(valueBefore.equals(valueAfter))) {
|
||||||
|
i.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
final StringBuilder b = new StringBuilder();
|
||||||
|
if (!missingKeys.isEmpty()) {
|
||||||
|
b.append("Missing keys:\n");
|
||||||
|
for (String key : missingKeys) {
|
||||||
|
b.append(" ").append(key)
|
||||||
|
.append("=")
|
||||||
|
.append(before.get(key))
|
||||||
|
.append("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!newKeys.isEmpty()) {
|
||||||
|
b.append("New keys:\n");
|
||||||
|
for (String key : newKeys) {
|
||||||
|
b.append(" ").append(key)
|
||||||
|
.append("=")
|
||||||
|
.append(after.get(key))
|
||||||
|
.append("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!differentKeyValues.isEmpty()) {
|
||||||
|
b.append("Different values:\n");
|
||||||
|
for (String key : differentKeyValues) {
|
||||||
|
b.append(" [old]").append(key)
|
||||||
|
.append("=")
|
||||||
|
.append(before.get(key)).append("\n");
|
||||||
|
b.append(" [new]").append(key)
|
||||||
|
.append("=")
|
||||||
|
.append(after.get(key)).append("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,59 @@
|
||||||
|
package org.apache.lucene.util;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.util.TreeMap;
|
||||||
|
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
|
import org.junit.runner.Description;
|
||||||
|
import org.junit.runners.model.Statement;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Restore system properties from before the nested {@link Statement}.
|
||||||
|
*/
|
||||||
|
public class SystemPropertiesRestoreRule implements TestRule {
|
||||||
|
@Override
|
||||||
|
public Statement apply(final Statement s, Description d) {
|
||||||
|
return new Statement() {
|
||||||
|
@Override
|
||||||
|
public void evaluate() throws Throwable {
|
||||||
|
TreeMap<String,String> before = cloneAsMap(System.getProperties());
|
||||||
|
try {
|
||||||
|
s.evaluate();
|
||||||
|
} finally {
|
||||||
|
TreeMap<String,String> after = cloneAsMap(System.getProperties());
|
||||||
|
if (!after.equals(before)) {
|
||||||
|
// Restore original properties.
|
||||||
|
restore(before, after);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
static TreeMap<String,String> cloneAsMap(Properties properties) {
|
||||||
|
TreeMap<String,String> result = new TreeMap<String,String>();
|
||||||
|
for (Entry<Object,Object> e : properties.entrySet()) {
|
||||||
|
// We can be sure it's always strings, can't we?
|
||||||
|
result.put((String) e.getKey(), (String) e.getValue());
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void restore(
|
||||||
|
TreeMap<String,String> before,
|
||||||
|
TreeMap<String,String> after) {
|
||||||
|
after.keySet().removeAll(before.keySet());
|
||||||
|
for (String key : after.keySet()) {
|
||||||
|
System.clearProperty(key);
|
||||||
|
}
|
||||||
|
for (Map.Entry<String,String> e : before.entrySet()) {
|
||||||
|
if (e.getValue() == null) {
|
||||||
|
System.clearProperty(e.getKey()); // Can this happen?
|
||||||
|
} else {
|
||||||
|
System.setProperty(e.getKey(), e.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -16,7 +16,14 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.schema;
|
package org.apache.solr.schema;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.nio.ByteBuffer;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.SystemPropertiesRestoreRule;
|
||||||
import org.apache.solr.client.solrj.SolrQuery;
|
import org.apache.solr.client.solrj.SolrQuery;
|
||||||
import org.apache.solr.client.solrj.beans.Field;
|
import org.apache.solr.client.solrj.beans.Field;
|
||||||
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
|
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
|
||||||
|
@ -26,13 +33,9 @@ import org.apache.solr.common.SolrDocument;
|
||||||
import org.apache.solr.common.SolrDocumentList;
|
import org.apache.solr.common.SolrDocumentList;
|
||||||
import org.apache.solr.common.SolrInputDocument;
|
import org.apache.solr.common.SolrInputDocument;
|
||||||
import org.apache.solr.core.SolrResourceLoader;
|
import org.apache.solr.core.SolrResourceLoader;
|
||||||
import org.apache.commons.io.FileUtils;
|
import org.junit.Rule;
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.junit.rules.RuleChain;
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
import java.nio.ByteBuffer;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileOutputStream;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
public class TestBinaryField extends LuceneTestCase {
|
public class TestBinaryField extends LuceneTestCase {
|
||||||
CommonsHttpSolrServer server;
|
CommonsHttpSolrServer server;
|
||||||
|
@ -41,6 +44,10 @@ public class TestBinaryField extends LuceneTestCase {
|
||||||
int port = 0;
|
int port = 0;
|
||||||
static final String context = "/example";
|
static final String context = "/example";
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public TestRule solrTestRules =
|
||||||
|
RuleChain.outerRule(new SystemPropertiesRestoreRule());
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
super.setUp();
|
super.setUp();
|
||||||
|
|
|
@ -21,11 +21,14 @@ import java.io.File;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
|
||||||
|
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.SystemPropertiesRestoreRule;
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.util.ExternalPaths;
|
import org.apache.solr.util.ExternalPaths;
|
||||||
|
import org.junit.Rule;
|
||||||
|
import org.junit.rules.RuleChain;
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
import org.mortbay.jetty.Connector;
|
import org.mortbay.jetty.Connector;
|
||||||
import org.mortbay.jetty.Server;
|
import org.mortbay.jetty.Server;
|
||||||
import org.mortbay.jetty.bio.SocketConnector;
|
import org.mortbay.jetty.bio.SocketConnector;
|
||||||
|
@ -41,6 +44,10 @@ public class JettyWebappTest extends LuceneTestCase
|
||||||
int port = 0;
|
int port = 0;
|
||||||
static final String context = "/test";
|
static final String context = "/test";
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public TestRule solrTestRules =
|
||||||
|
RuleChain.outerRule(new SystemPropertiesRestoreRule());
|
||||||
|
|
||||||
Server server;
|
Server server;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -7,6 +7,7 @@ import java.util.List;
|
||||||
import junit.framework.Assert;
|
import junit.framework.Assert;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.SystemPropertiesRestoreRule;
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.common.util.FileUtils;
|
import org.apache.solr.common.util.FileUtils;
|
||||||
import org.apache.solr.core.CoreContainer;
|
import org.apache.solr.core.CoreContainer;
|
||||||
|
@ -14,11 +15,18 @@ import org.apache.solr.core.SolrCore;
|
||||||
import org.apache.solr.util.AbstractSolrTestCase;
|
import org.apache.solr.util.AbstractSolrTestCase;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
|
import org.junit.Rule;
|
||||||
|
import org.junit.rules.RuleChain;
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
public class TestEmbeddedSolrServer extends LuceneTestCase {
|
public class TestEmbeddedSolrServer extends LuceneTestCase {
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public TestRule solrTestRules =
|
||||||
|
RuleChain.outerRule(new SystemPropertiesRestoreRule());
|
||||||
|
|
||||||
protected static Logger log = LoggerFactory.getLogger(TestEmbeddedSolrServer.class);
|
protected static Logger log = LoggerFactory.getLogger(TestEmbeddedSolrServer.class);
|
||||||
|
|
||||||
protected CoreContainer cores = null;
|
protected CoreContainer cores = null;
|
||||||
|
|
|
@ -29,6 +29,7 @@ import javax.xml.xpath.XPathFactory;
|
||||||
|
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.SystemPropertiesRestoreRule;
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.client.solrj.SolrQuery;
|
import org.apache.solr.client.solrj.SolrQuery;
|
||||||
import org.apache.solr.client.solrj.SolrServer;
|
import org.apache.solr.client.solrj.SolrServer;
|
||||||
|
@ -43,7 +44,10 @@ import org.apache.solr.core.CoreContainer;
|
||||||
import org.apache.solr.util.AbstractSolrTestCase;
|
import org.apache.solr.util.AbstractSolrTestCase;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import org.junit.rules.RuleChain;
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.w3c.dom.Document;
|
import org.w3c.dom.Document;
|
||||||
|
@ -59,6 +63,10 @@ public class TestSolrProperties extends LuceneTestCase {
|
||||||
private File home;
|
private File home;
|
||||||
private File solrXml;
|
private File solrXml;
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public TestRule solrTestRules =
|
||||||
|
RuleChain.outerRule(new SystemPropertiesRestoreRule());
|
||||||
|
|
||||||
private static final XPathFactory xpathFactory = XPathFactory.newInstance();
|
private static final XPathFactory xpathFactory = XPathFactory.newInstance();
|
||||||
|
|
||||||
public String getSolrHome() {
|
public String getSolrHome() {
|
||||||
|
|
|
@ -19,8 +19,25 @@
|
||||||
package org.apache.solr;
|
package org.apache.solr;
|
||||||
|
|
||||||
|
|
||||||
import org.apache.lucene.store.MockDirectoryWrapper;
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.StringWriter;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Comparator;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.logging.ConsoleHandler;
|
||||||
|
import java.util.logging.Handler;
|
||||||
|
import java.util.logging.Level;
|
||||||
|
|
||||||
|
import javax.xml.xpath.XPathExpressionException;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.SystemPropertiesInvariantRule;
|
||||||
|
import org.apache.lucene.util.SystemPropertiesRestoreRule;
|
||||||
import org.apache.noggit.CharArr;
|
import org.apache.noggit.CharArr;
|
||||||
import org.apache.noggit.JSONUtil;
|
import org.apache.noggit.JSONUtil;
|
||||||
import org.apache.noggit.ObjectBuilder;
|
import org.apache.noggit.ObjectBuilder;
|
||||||
|
@ -43,25 +60,16 @@ import org.apache.solr.schema.SchemaField;
|
||||||
import org.apache.solr.search.SolrIndexSearcher;
|
import org.apache.solr.search.SolrIndexSearcher;
|
||||||
import org.apache.solr.servlet.DirectSolrConnection;
|
import org.apache.solr.servlet.DirectSolrConnection;
|
||||||
import org.apache.solr.util.TestHarness;
|
import org.apache.solr.util.TestHarness;
|
||||||
import org.apache.zookeeper.server.LogFormatter;
|
|
||||||
import org.junit.AfterClass;
|
import org.junit.AfterClass;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.ClassRule;
|
||||||
|
import org.junit.Rule;
|
||||||
|
import org.junit.rules.RuleChain;
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.xml.sax.SAXException;
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
import javax.xml.xpath.XPathExpressionException;
|
|
||||||
|
|
||||||
import java.io.Closeable;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.StringWriter;
|
|
||||||
import java.util.*;
|
|
||||||
import java.util.Map.Entry;
|
|
||||||
import java.util.logging.ConsoleHandler;
|
|
||||||
import java.util.logging.Handler;
|
|
||||||
import java.util.logging.Level;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A junit4 Solr test harness that extends LuceneTestCaseJ4.
|
* A junit4 Solr test harness that extends LuceneTestCaseJ4.
|
||||||
* Unlike AbstractSolrTestCase, a new core is not created for each test method.
|
* Unlike AbstractSolrTestCase, a new core is not created for each test method.
|
||||||
|
@ -69,6 +77,13 @@ import java.util.logging.Level;
|
||||||
*/
|
*/
|
||||||
public abstract class SolrTestCaseJ4 extends LuceneTestCase {
|
public abstract class SolrTestCaseJ4 extends LuceneTestCase {
|
||||||
|
|
||||||
|
@ClassRule
|
||||||
|
public static TestRule solrClassRules =
|
||||||
|
RuleChain.outerRule(new SystemPropertiesRestoreRule());
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public TestRule solrTestRules =
|
||||||
|
RuleChain.outerRule(new SystemPropertiesRestoreRule());
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public static void beforeClassSolrTestCase() throws Exception {
|
public static void beforeClassSolrTestCase() throws Exception {
|
||||||
|
|
|
@ -19,27 +19,34 @@
|
||||||
package org.apache.solr.util;
|
package org.apache.solr.util;
|
||||||
|
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.StringWriter;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import javax.xml.xpath.XPathExpressionException;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.SystemPropertiesRestoreRule;
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.core.SolrConfig;
|
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.SolrInputDocument;
|
import org.apache.solr.common.SolrInputDocument;
|
||||||
import org.apache.solr.common.SolrInputField;
|
import org.apache.solr.common.SolrInputField;
|
||||||
import org.apache.solr.common.params.CommonParams;
|
import org.apache.solr.common.params.CommonParams;
|
||||||
import org.apache.solr.common.util.XML;
|
import org.apache.solr.common.util.XML;
|
||||||
import org.apache.solr.request.*;
|
import org.apache.solr.core.SolrConfig;
|
||||||
|
import org.apache.solr.request.SolrQueryRequest;
|
||||||
import org.junit.AfterClass;
|
import org.junit.AfterClass;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.ClassRule;
|
||||||
import org.xml.sax.SAXException;
|
import org.junit.Rule;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.junit.rules.RuleChain;
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import javax.xml.xpath.XPathExpressionException;
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.xml.sax.SAXException;
|
||||||
import java.io.*;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An Abstract base class that makes writing Solr JUnit tests "easier"
|
* An Abstract base class that makes writing Solr JUnit tests "easier"
|
||||||
|
@ -56,6 +63,7 @@ import java.util.ArrayList;
|
||||||
*/
|
*/
|
||||||
public abstract class AbstractSolrTestCase extends LuceneTestCase {
|
public abstract class AbstractSolrTestCase extends LuceneTestCase {
|
||||||
protected SolrConfig solrConfig;
|
protected SolrConfig solrConfig;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Harness initialized by initTestHarness.
|
* Harness initialized by initTestHarness.
|
||||||
*
|
*
|
||||||
|
@ -94,6 +102,14 @@ public abstract class AbstractSolrTestCase extends LuceneTestCase {
|
||||||
return SolrTestCaseJ4.TEST_HOME();
|
return SolrTestCaseJ4.TEST_HOME();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ClassRule
|
||||||
|
public static TestRule solrClassRules =
|
||||||
|
RuleChain.outerRule(new SystemPropertiesRestoreRule());
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public TestRule solrTestRules =
|
||||||
|
RuleChain.outerRule(new SystemPropertiesRestoreRule());
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public static void beforeClassAbstractSolrTestCase() throws Exception {
|
public static void beforeClassAbstractSolrTestCase() throws Exception {
|
||||||
SolrTestCaseJ4.startTrackingSearchers();
|
SolrTestCaseJ4.startTrackingSearchers();
|
||||||
|
|
Loading…
Reference in New Issue