mirror of https://github.com/apache/lucene.git
SOLR-6170: Merge CoreContainer preRegisterInZk and register methods into create method
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1606891 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
b7290e523b
commit
3fb008e7f0
|
@ -107,6 +107,10 @@ Upgrading from Solr 4.9
|
||||||
schema version is 1.5 or greater (SOLR-3140), but TrieDateField's default was mistakenly
|
schema version is 1.5 or greater (SOLR-3140), but TrieDateField's default was mistakenly
|
||||||
not changed. As of Solr 4.10, TrieDateField omits norms by default (see SOLR-6211).
|
not changed. As of Solr 4.10, TrieDateField omits norms by default (see SOLR-6211).
|
||||||
|
|
||||||
|
* Creating a SolrCore via CoreContainer.create() no longer requires an
|
||||||
|
additional call to CoreContainer.register() to make it available to clients
|
||||||
|
(see SOLR-6170).
|
||||||
|
|
||||||
Detailed Change List
|
Detailed Change List
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
@ -154,6 +158,9 @@ Other Changes
|
||||||
* SOLR-6194: Allow access to DataImporter and DIHConfiguration from DataImportHandler.
|
* SOLR-6194: Allow access to DataImporter and DIHConfiguration from DataImportHandler.
|
||||||
(Aaron LaBella via shalin)
|
(Aaron LaBella via shalin)
|
||||||
|
|
||||||
|
* SOLR-6170: CoreContainer.preRegisterInZk() and CoreContainer.register() commands
|
||||||
|
are merged into CoreContainer.create(). (Alan Woodward)
|
||||||
|
|
||||||
================== 4.9.0 ==================
|
================== 4.9.0 ==================
|
||||||
|
|
||||||
Versions of Major Components
|
Versions of Major Components
|
||||||
|
|
|
@ -16,6 +16,25 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.hadoop;
|
package org.apache.solr.hadoop;
|
||||||
|
|
||||||
|
import org.apache.hadoop.conf.Configuration;
|
||||||
|
import org.apache.hadoop.filecache.DistributedCache;
|
||||||
|
import org.apache.hadoop.fs.FileSystem;
|
||||||
|
import org.apache.hadoop.fs.Path;
|
||||||
|
import org.apache.hadoop.mapreduce.RecordWriter;
|
||||||
|
import org.apache.hadoop.mapreduce.Reducer;
|
||||||
|
import org.apache.hadoop.mapreduce.TaskAttemptContext;
|
||||||
|
import org.apache.hadoop.mapreduce.TaskID;
|
||||||
|
import org.apache.solr.client.solrj.SolrServerException;
|
||||||
|
import org.apache.solr.client.solrj.embedded.EmbeddedSolrServer;
|
||||||
|
import org.apache.solr.common.SolrInputDocument;
|
||||||
|
import org.apache.solr.core.CoreContainer;
|
||||||
|
import org.apache.solr.core.CoreDescriptor;
|
||||||
|
import org.apache.solr.core.HdfsDirectoryFactory;
|
||||||
|
import org.apache.solr.core.SolrCore;
|
||||||
|
import org.apache.solr.core.SolrResourceLoader;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -29,26 +48,6 @@ import java.util.Properties;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import org.apache.hadoop.conf.Configuration;
|
|
||||||
import org.apache.hadoop.filecache.DistributedCache;
|
|
||||||
import org.apache.hadoop.fs.FileSystem;
|
|
||||||
import org.apache.hadoop.fs.Path;
|
|
||||||
import org.apache.hadoop.mapreduce.RecordWriter;
|
|
||||||
import org.apache.hadoop.mapreduce.Reducer;
|
|
||||||
import org.apache.hadoop.mapreduce.TaskAttemptContext;
|
|
||||||
import org.apache.hadoop.mapreduce.TaskID;
|
|
||||||
import org.apache.solr.hadoop.SolrOutputFormat;
|
|
||||||
import org.apache.solr.client.solrj.SolrServerException;
|
|
||||||
import org.apache.solr.client.solrj.embedded.EmbeddedSolrServer;
|
|
||||||
import org.apache.solr.common.SolrInputDocument;
|
|
||||||
import org.apache.solr.core.CoreContainer;
|
|
||||||
import org.apache.solr.core.CoreDescriptor;
|
|
||||||
import org.apache.solr.core.HdfsDirectoryFactory;
|
|
||||||
import org.apache.solr.core.SolrCore;
|
|
||||||
import org.apache.solr.core.SolrResourceLoader;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
class SolrRecordWriter<K, V> extends RecordWriter<K, V> {
|
class SolrRecordWriter<K, V> extends RecordWriter<K, V> {
|
||||||
|
|
||||||
private static final Logger LOG = LoggerFactory.getLogger(SolrRecordWriter.class);
|
private static final Logger LOG = LoggerFactory.getLogger(SolrRecordWriter.class);
|
||||||
|
@ -176,8 +175,6 @@ class SolrRecordWriter<K, V> extends RecordWriter<K, V> {
|
||||||
+ HdfsDirectoryFactory.class.getSimpleName());
|
+ HdfsDirectoryFactory.class.getSimpleName());
|
||||||
}
|
}
|
||||||
|
|
||||||
container.register(core, false);
|
|
||||||
|
|
||||||
EmbeddedSolrServer solr = new EmbeddedSolrServer(container, "core1");
|
EmbeddedSolrServer solr = new EmbeddedSolrServer(container, "core1");
|
||||||
return solr;
|
return solr;
|
||||||
}
|
}
|
||||||
|
|
|
@ -253,33 +253,12 @@ public class CoreContainer {
|
||||||
Callable<SolrCore> task = new Callable<SolrCore>() {
|
Callable<SolrCore> task = new Callable<SolrCore>() {
|
||||||
@Override
|
@Override
|
||||||
public SolrCore call() {
|
public SolrCore call() {
|
||||||
SolrCore c = null;
|
|
||||||
try {
|
try {
|
||||||
if (zkSys.getZkController() != null) {
|
return create(cd, false);
|
||||||
preRegisterInZk(cd);
|
|
||||||
}
|
|
||||||
c = create(cd);
|
|
||||||
registerCore(cd.isTransient(), name, c, false, false);
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
SolrException.log(log, null, e);
|
SolrException.log(log, null, e);
|
||||||
try {
|
return null;
|
||||||
/* if (isZooKeeperAware()) {
|
|
||||||
try {
|
|
||||||
zkSys.zkController.unregister(name, cd);
|
|
||||||
} catch (InterruptedException e2) {
|
|
||||||
Thread.currentThread().interrupt();
|
|
||||||
SolrException.log(log, null, e2);
|
|
||||||
} catch (KeeperException e3) {
|
|
||||||
SolrException.log(log, null, e3);
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
} finally {
|
|
||||||
if (c != null) {
|
|
||||||
c.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return c;
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
pending.add(completionService.submit(task));
|
pending.add(completionService.submit(task));
|
||||||
|
@ -450,12 +429,8 @@ public class CoreContainer {
|
||||||
public CoresLocator getCoresLocator() {
|
public CoresLocator getCoresLocator() {
|
||||||
return coresLocator;
|
return coresLocator;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected SolrCore registerCore(boolean isTransientCore, String name, SolrCore core, boolean returnPrevNotClosed) {
|
|
||||||
return registerCore(isTransientCore, name, core, returnPrevNotClosed, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected SolrCore registerCore(boolean isTransientCore, String name, SolrCore core, boolean returnPrevNotClosed, boolean registerInZk) {
|
protected SolrCore registerCore(String name, SolrCore core, boolean registerInZk) {
|
||||||
if( core == null ) {
|
if( core == null ) {
|
||||||
throw new RuntimeException( "Can not register a null core." );
|
throw new RuntimeException( "Can not register a null core." );
|
||||||
}
|
}
|
||||||
|
@ -480,7 +455,7 @@ public class CoreContainer {
|
||||||
core.close();
|
core.close();
|
||||||
throw new IllegalStateException("This CoreContainer has been shutdown");
|
throw new IllegalStateException("This CoreContainer has been shutdown");
|
||||||
}
|
}
|
||||||
if (isTransientCore) {
|
if (cd.isTransient()) {
|
||||||
old = solrCores.putTransientCore(cfg, name, core, loader);
|
old = solrCores.putTransientCore(cfg, name, core, loader);
|
||||||
} else {
|
} else {
|
||||||
old = solrCores.putCore(name, core);
|
old = solrCores.putCore(name, core);
|
||||||
|
@ -505,9 +480,7 @@ public class CoreContainer {
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
log.info( "replacing core: "+name );
|
log.info( "replacing core: "+name );
|
||||||
if (!returnPrevNotClosed) {
|
old.close();
|
||||||
old.close();
|
|
||||||
}
|
|
||||||
if (registerInZk) {
|
if (registerInZk) {
|
||||||
zkSys.registerInZk(core, false);
|
zkSys.registerInZk(core, false);
|
||||||
}
|
}
|
||||||
|
@ -516,34 +489,23 @@ public class CoreContainer {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers a SolrCore descriptor in the registry using the core's name.
|
* Creates a new core based on a CoreDescriptor, publishing the core state to the cluster
|
||||||
* If returnPrev==false, the old core, if different, is closed.
|
* @param cd the CoreDescriptor
|
||||||
* @return a previous core having the same name if it existed and returnPrev==true
|
* @return the newly created core
|
||||||
*/
|
*/
|
||||||
public SolrCore register(SolrCore core, boolean returnPrev) {
|
public SolrCore create(CoreDescriptor cd) {
|
||||||
return registerCore(core.getCoreDescriptor().isTransient(), core.getName(), core, returnPrev);
|
return create(cd, true);
|
||||||
}
|
|
||||||
|
|
||||||
public SolrCore register(String name, SolrCore core, boolean returnPrev) {
|
|
||||||
return registerCore(core.getCoreDescriptor().isTransient(), name, core, returnPrev);
|
|
||||||
}
|
|
||||||
|
|
||||||
public SolrCore create(String name, String instanceDir, String... properties) {
|
|
||||||
Properties props = new Properties();
|
|
||||||
assert properties.length % 2 == 0;
|
|
||||||
for (int i = 0; i < properties.length; i += 2) {
|
|
||||||
props.setProperty(properties[i], properties[i+1]);
|
|
||||||
}
|
|
||||||
return create(new CoreDescriptor(this, name, instanceDir, props));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new core based on a descriptor but does not register it.
|
* Creates a new core based on a CoreDescriptor.
|
||||||
|
*
|
||||||
|
* @param dcore a core descriptor
|
||||||
|
* @param publishState publish core state to the cluster if true
|
||||||
*
|
*
|
||||||
* @param dcore a core descriptor
|
|
||||||
* @return the newly created core
|
* @return the newly created core
|
||||||
*/
|
*/
|
||||||
public SolrCore create(CoreDescriptor dcore) {
|
public SolrCore create(CoreDescriptor dcore, boolean publishState) {
|
||||||
|
|
||||||
if (isShutDown) {
|
if (isShutDown) {
|
||||||
throw new SolrException(ErrorCode.SERVICE_UNAVAILABLE, "Solr has shutdown.");
|
throw new SolrException(ErrorCode.SERVICE_UNAVAILABLE, "Solr has shutdown.");
|
||||||
|
@ -551,6 +513,10 @@ public class CoreContainer {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
|
if (zkSys.getZkController() != null) {
|
||||||
|
zkSys.getZkController().preRegister(dcore);
|
||||||
|
}
|
||||||
|
|
||||||
ConfigSet coreConfig = coreConfigService.getConfig(dcore);
|
ConfigSet coreConfig = coreConfigService.getConfig(dcore);
|
||||||
log.info("Creating SolrCore '{}' using configuration from {}", dcore.getName(), coreConfig.getName());
|
log.info("Creating SolrCore '{}' using configuration from {}", dcore.getName(), coreConfig.getName());
|
||||||
SolrCore core = new SolrCore(dcore, coreConfig);
|
SolrCore core = new SolrCore(dcore, coreConfig);
|
||||||
|
@ -561,6 +527,8 @@ public class CoreContainer {
|
||||||
core.getUpdateHandler().getUpdateLog().recoverFromLog();
|
core.getUpdateHandler().getUpdateLog().recoverFromLog();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
registerCore(dcore.getName(), core, publishState);
|
||||||
|
|
||||||
return core;
|
return core;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -650,7 +618,7 @@ public class CoreContainer {
|
||||||
SolrCore newCore = core.reload(coreConfig, core);
|
SolrCore newCore = core.reload(coreConfig, core);
|
||||||
// keep core to orig name link
|
// keep core to orig name link
|
||||||
solrCores.removeCoreToOrigName(newCore, core);
|
solrCores.removeCoreToOrigName(newCore, core);
|
||||||
registerCore(false, name, newCore, false, false);
|
registerCore(name, newCore, false);
|
||||||
} finally {
|
} finally {
|
||||||
solrCores.removeFromPendingOps(name);
|
solrCores.removeFromPendingOps(name);
|
||||||
}
|
}
|
||||||
|
@ -694,7 +662,7 @@ public class CoreContainer {
|
||||||
public void rename(String name, String toName) {
|
public void rename(String name, String toName) {
|
||||||
try (SolrCore core = getCore(name)) {
|
try (SolrCore core = getCore(name)) {
|
||||||
if (core != null) {
|
if (core != null) {
|
||||||
registerCore(false, toName, core, false);
|
registerCore(toName, core, true);
|
||||||
name = checkDefault(name);
|
name = checkDefault(name);
|
||||||
SolrCore old = solrCores.remove(name, false);
|
SolrCore old = solrCores.remove(name, false);
|
||||||
coresLocator.rename(this, old.getCoreDescriptor(), core.getCoreDescriptor());
|
coresLocator.rename(this, old.getCoreDescriptor(), core.getCoreDescriptor());
|
||||||
|
@ -765,29 +733,12 @@ public class CoreContainer {
|
||||||
// the wait as a consequence of shutting down.
|
// the wait as a consequence of shutting down.
|
||||||
try {
|
try {
|
||||||
if (core == null) {
|
if (core == null) {
|
||||||
if (zkSys.getZkController() != null) {
|
|
||||||
preRegisterInZk(desc);
|
|
||||||
}
|
|
||||||
core = create(desc); // This should throw an error if it fails.
|
core = create(desc); // This should throw an error if it fails.
|
||||||
core.open();
|
core.open();
|
||||||
registerCore(desc.isTransient(), name, core, false);
|
|
||||||
} else {
|
} else {
|
||||||
core.open();
|
core.open();
|
||||||
}
|
}
|
||||||
} catch(Exception ex){
|
} catch(Exception ex){
|
||||||
// remains to be seen how transient cores and such
|
|
||||||
// will work in SolrCloud mode, but just to be future
|
|
||||||
// proof...
|
|
||||||
/*if (isZooKeeperAware()) {
|
|
||||||
try {
|
|
||||||
getZkController().unregister(name, desc);
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
Thread.currentThread().interrupt();
|
|
||||||
SolrException.log(log, null, e);
|
|
||||||
} catch (KeeperException e) {
|
|
||||||
SolrException.log(log, null, e);
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
throw recordAndThrow(name, "Unable to create core: " + name, ex);
|
throw recordAndThrow(name, "Unable to create core: " + name, ex);
|
||||||
} finally {
|
} finally {
|
||||||
solrCores.removeFromPendingOps(name);
|
solrCores.removeFromPendingOps(name);
|
||||||
|
@ -876,10 +827,6 @@ public class CoreContainer {
|
||||||
return solrCores.getUnloadedCoreDescriptor(cname);
|
return solrCores.getUnloadedCoreDescriptor(cname);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void preRegisterInZk(final CoreDescriptor p) {
|
|
||||||
zkSys.getZkController().preRegister(p);
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getSolrHome() {
|
public String getSolrHome() {
|
||||||
return solrHome;
|
return solrHome;
|
||||||
}
|
}
|
||||||
|
|
|
@ -138,6 +138,19 @@ public class CoreDescriptor {
|
||||||
Properties coreProps) {
|
Properties coreProps) {
|
||||||
this(container, name, instanceDir, coreProps, null);
|
this(container, name, instanceDir, coreProps, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public CoreDescriptor(CoreContainer container, String name, String instanceDir, String... properties) {
|
||||||
|
this(container, name, instanceDir, toProperties(properties));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Properties toProperties(String... properties) {
|
||||||
|
Properties props = new Properties();
|
||||||
|
assert properties.length % 2 == 0;
|
||||||
|
for (int i = 0; i < properties.length; i += 2) {
|
||||||
|
props.setProperty(properties[i], properties[i+1]);
|
||||||
|
}
|
||||||
|
return props;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new CoreDescriptor.
|
* Create a new CoreDescriptor.
|
||||||
|
|
|
@ -565,7 +565,6 @@ public class CoreAdminHandler extends RequestHandlerBase {
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
coreContainer.preRegisterInZk(dcore);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// make sure we can write out the descriptor first
|
// make sure we can write out the descriptor first
|
||||||
|
@ -573,8 +572,6 @@ public class CoreAdminHandler extends RequestHandlerBase {
|
||||||
|
|
||||||
SolrCore core = coreContainer.create(dcore);
|
SolrCore core = coreContainer.create(dcore);
|
||||||
|
|
||||||
coreContainer.register(core, false);
|
|
||||||
|
|
||||||
if (coreContainer.getCoresLocator() instanceof SolrXMLCoresLocator) {
|
if (coreContainer.getCoresLocator() instanceof SolrXMLCoresLocator) {
|
||||||
// hack - in this case we persist once more because a core create race might
|
// hack - in this case we persist once more because a core create race might
|
||||||
// have dropped entries.
|
// have dropped entries.
|
||||||
|
|
|
@ -17,8 +17,6 @@ package org.apache.solr.cloud;
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import org.apache.commons.io.FileUtils;
|
|
||||||
import org.apache.lucene.util.TestUtil;
|
|
||||||
import org.apache.lucene.util.LuceneTestCase.Slow;
|
import org.apache.lucene.util.LuceneTestCase.Slow;
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.common.cloud.ClusterState;
|
import org.apache.solr.common.cloud.ClusterState;
|
||||||
|
@ -161,14 +159,8 @@ public class ClusterStateUpdateTest extends SolrTestCaseJ4 {
|
||||||
CoreDescriptor dcore = buildCoreDescriptor(container1, "testcore", "testcore")
|
CoreDescriptor dcore = buildCoreDescriptor(container1, "testcore", "testcore")
|
||||||
.withDataDir(dataDir4.getAbsolutePath()).build();
|
.withDataDir(dataDir4.getAbsolutePath()).build();
|
||||||
|
|
||||||
if (container1.getZkController() != null) {
|
|
||||||
container1.preRegisterInZk(dcore);
|
|
||||||
}
|
|
||||||
|
|
||||||
SolrCore core = container1.create(dcore);
|
SolrCore core = container1.create(dcore);
|
||||||
|
|
||||||
container1.register(core, false);
|
|
||||||
|
|
||||||
ZkController zkController2 = container2.getZkController();
|
ZkController zkController2 = container2.getZkController();
|
||||||
|
|
||||||
String host = zkController2.getHostName();
|
String host = zkController2.getHostName();
|
||||||
|
|
|
@ -17,11 +17,6 @@
|
||||||
|
|
||||||
package org.apache.solr.core;
|
package org.apache.solr.core;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
import org.apache.commons.io.FileUtils;
|
import org.apache.commons.io.FileUtils;
|
||||||
import org.apache.lucene.util.IOUtils;
|
import org.apache.lucene.util.IOUtils;
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
|
@ -29,6 +24,11 @@ import org.apache.solr.common.SolrException;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.xml.sax.SAXParseException;
|
import org.xml.sax.SAXParseException;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
public class CoreContainerCoreInitFailuresTest extends SolrTestCaseJ4 {
|
public class CoreContainerCoreInitFailuresTest extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
File solrHome = null;
|
File solrHome = null;
|
||||||
|
@ -188,7 +188,7 @@ public class CoreContainerCoreInitFailuresTest extends SolrTestCaseJ4 {
|
||||||
FileUtils.copyFile(getFile("solr/collection1/conf/solrconfig-defaults.xml"),
|
FileUtils.copyFile(getFile("solr/collection1/conf/solrconfig-defaults.xml"),
|
||||||
FileUtils.getFile(solrHome, "col_bad", "conf", "solrconfig.xml"));
|
FileUtils.getFile(solrHome, "col_bad", "conf", "solrconfig.xml"));
|
||||||
final CoreDescriptor fixed = new CoreDescriptor(cc, "col_bad", "col_bad");
|
final CoreDescriptor fixed = new CoreDescriptor(cc, "col_bad", "col_bad");
|
||||||
cc.register("col_bad", cc.create(fixed), false);
|
cc.create(fixed);
|
||||||
|
|
||||||
// check that we have the cores we expect
|
// check that we have the cores we expect
|
||||||
cores = cc.getCoreNames();
|
cores = cc.getCoreNames();
|
||||||
|
@ -246,24 +246,6 @@ public class CoreContainerCoreInitFailuresTest extends SolrTestCaseJ4 {
|
||||||
0 < cause.indexOf("bogus_path"));
|
0 < cause.indexOf("bogus_path"));
|
||||||
}
|
}
|
||||||
|
|
||||||
// -----
|
|
||||||
// register bogus as an alias for col_ok and confirm failure goes away
|
|
||||||
cc.register("bogus", cc.getCore("col_ok"), false);
|
|
||||||
|
|
||||||
// check that we have the cores we expect
|
|
||||||
cores = cc.getCoreNames();
|
|
||||||
assertNotNull("core names is null", cores);
|
|
||||||
assertEquals("wrong number of cores", 3, cores.size());
|
|
||||||
assertTrue("col_ok not found", cores.contains("col_ok"));
|
|
||||||
assertTrue("col_bad not found", cores.contains("col_bad"));
|
|
||||||
assertTrue("bogus not found", cores.contains("bogus"));
|
|
||||||
|
|
||||||
// check that we have the failures we expect
|
|
||||||
failures = cc.getCoreInitFailures();
|
|
||||||
assertNotNull("core failures is a null map", failures);
|
|
||||||
assertEquals("wrong number of core failures", 0, failures.size());
|
|
||||||
|
|
||||||
|
|
||||||
// -----
|
// -----
|
||||||
// break col_bad's config and try to RELOAD to add failure
|
// break col_bad's config and try to RELOAD to add failure
|
||||||
|
|
||||||
|
@ -294,15 +276,14 @@ public class CoreContainerCoreInitFailuresTest extends SolrTestCaseJ4 {
|
||||||
// check that we have the cores we expect
|
// check that we have the cores we expect
|
||||||
cores = cc.getCoreNames();
|
cores = cc.getCoreNames();
|
||||||
assertNotNull("core names is null", cores);
|
assertNotNull("core names is null", cores);
|
||||||
assertEquals("wrong number of cores", 3, cores.size());
|
assertEquals("wrong number of cores", 2, cores.size());
|
||||||
assertTrue("col_ok not found", cores.contains("col_ok"));
|
assertTrue("col_ok not found", cores.contains("col_ok"));
|
||||||
assertTrue("col_bad not found", cores.contains("col_bad"));
|
assertTrue("col_bad not found", cores.contains("col_bad"));
|
||||||
assertTrue("bogus not found", cores.contains("bogus"));
|
|
||||||
|
|
||||||
// check that we have the failures we expect
|
// check that we have the failures we expect
|
||||||
failures = cc.getCoreInitFailures();
|
failures = cc.getCoreInitFailures();
|
||||||
assertNotNull("core failures is a null map", failures);
|
assertNotNull("core failures is a null map", failures);
|
||||||
assertEquals("wrong number of core failures", 1, failures.size());
|
assertEquals("wrong number of core failures", 2, failures.size());
|
||||||
Throwable ex = getWrappedException(failures.get("col_bad"));
|
Throwable ex = getWrappedException(failures.get("col_bad"));
|
||||||
assertNotNull("null failure for test core", ex);
|
assertNotNull("null failure for test core", ex);
|
||||||
assertTrue("init failure isn't SAXParseException",
|
assertTrue("init failure isn't SAXParseException",
|
||||||
|
@ -323,15 +304,14 @@ public class CoreContainerCoreInitFailuresTest extends SolrTestCaseJ4 {
|
||||||
// check that we have the cores we expect
|
// check that we have the cores we expect
|
||||||
cores = cc.getCoreNames();
|
cores = cc.getCoreNames();
|
||||||
assertNotNull("core names is null", cores);
|
assertNotNull("core names is null", cores);
|
||||||
assertEquals("wrong number of cores", 3, cores.size());
|
assertEquals("wrong number of cores", 2, cores.size());
|
||||||
assertTrue("col_ok not found", cores.contains("col_ok"));
|
assertTrue("col_ok not found", cores.contains("col_ok"));
|
||||||
assertTrue("col_bad not found", cores.contains("col_bad"));
|
assertTrue("col_bad not found", cores.contains("col_bad"));
|
||||||
assertTrue("bogus not found", cores.contains("bogus"));
|
|
||||||
|
|
||||||
// check that we have the failures we expect
|
// check that we have the failures we expect
|
||||||
failures = cc.getCoreInitFailures();
|
failures = cc.getCoreInitFailures();
|
||||||
assertNotNull("core failures is a null map", failures);
|
assertNotNull("core failures is a null map", failures);
|
||||||
assertEquals("wrong number of core failures", 0, failures.size());
|
assertEquals("wrong number of core failures", 1, failures.size());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,17 @@
|
||||||
|
|
||||||
package org.apache.solr.core;
|
package org.apache.solr.core;
|
||||||
|
|
||||||
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
|
import org.apache.solr.handler.RequestHandlerBase;
|
||||||
|
import org.apache.solr.handler.component.QueryComponent;
|
||||||
|
import org.apache.solr.handler.component.SpellCheckComponent;
|
||||||
|
import org.apache.solr.request.SolrQueryRequest;
|
||||||
|
import org.apache.solr.request.SolrRequestHandler;
|
||||||
|
import org.apache.solr.response.SolrQueryResponse;
|
||||||
|
import org.apache.solr.util.DefaultSolrThreadFactory;
|
||||||
|
import org.apache.solr.util.plugin.SolrCoreAware;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -26,18 +37,6 @@ import java.util.concurrent.Executors;
|
||||||
import java.util.concurrent.Future;
|
import java.util.concurrent.Future;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
|
||||||
import org.apache.solr.handler.RequestHandlerBase;
|
|
||||||
import org.apache.solr.handler.component.QueryComponent;
|
|
||||||
import org.apache.solr.handler.component.SpellCheckComponent;
|
|
||||||
import org.apache.solr.request.SolrQueryRequest;
|
|
||||||
import org.apache.solr.request.SolrRequestHandler;
|
|
||||||
import org.apache.solr.response.SolrQueryResponse;
|
|
||||||
import org.apache.solr.schema.IndexSchema;
|
|
||||||
import org.apache.solr.util.DefaultSolrThreadFactory;
|
|
||||||
import org.apache.solr.util.plugin.SolrCoreAware;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class SolrCoreTest extends SolrTestCaseJ4 {
|
public class SolrCoreTest extends SolrTestCaseJ4 {
|
||||||
private static final String COLLECTION1 = "collection1";
|
private static final String COLLECTION1 = "collection1";
|
||||||
|
|
||||||
|
@ -58,18 +57,16 @@ public class SolrCoreTest extends SolrTestCaseJ4 {
|
||||||
final CoreContainer cores = h.getCoreContainer();
|
final CoreContainer cores = h.getCoreContainer();
|
||||||
SolrCore core = cores.getCore("");
|
SolrCore core = cores.getCore("");
|
||||||
|
|
||||||
IndexSchema schema = h.getCore().getLatestSchema();
|
|
||||||
assertEquals(COLLECTION1, cores.getDefaultCoreName());
|
assertEquals(COLLECTION1, cores.getDefaultCoreName());
|
||||||
|
|
||||||
cores.remove("");
|
cores.remove("");
|
||||||
core.close();
|
core.close();
|
||||||
core.close();
|
core.close();
|
||||||
|
|
||||||
|
CoreDescriptor cd = new CoreDescriptor(cores, COLLECTION1, "collection1",
|
||||||
|
CoreDescriptor.CORE_DATADIR, createTempDir("dataDir2").getAbsolutePath());
|
||||||
|
|
||||||
|
cores.create(cd);
|
||||||
SolrCore newCore = new SolrCore(COLLECTION1, createTempDir("dataDir2").getAbsolutePath(), new SolrConfig("solr/collection1", "solrconfig.xml", null), schema,
|
|
||||||
new CoreDescriptor(cores, COLLECTION1, "solr/collection1"));
|
|
||||||
|
|
||||||
cores.register(newCore, false);
|
|
||||||
|
|
||||||
assertEquals(COLLECTION1, cores.getDefaultCoreName());
|
assertEquals(COLLECTION1, cores.getDefaultCoreName());
|
||||||
|
|
||||||
|
|
|
@ -69,19 +69,15 @@ public class TestConfigSets extends SolrTestCaseJ4 {
|
||||||
@Test
|
@Test
|
||||||
public void testConfigSetServiceFindsConfigSets() {
|
public void testConfigSetServiceFindsConfigSets() {
|
||||||
CoreContainer container = null;
|
CoreContainer container = null;
|
||||||
SolrCore core1 = null;
|
|
||||||
try {
|
try {
|
||||||
container = setupContainer(getFile("solr/configsets").getAbsolutePath());
|
container = setupContainer(getFile("solr/configsets").getAbsolutePath());
|
||||||
String testDirectory = new File(container.getResourceLoader().getInstanceDir()).getAbsolutePath();
|
String testDirectory = new File(container.getResourceLoader().getInstanceDir()).getAbsolutePath();
|
||||||
|
|
||||||
core1 = container.create("core1", testDirectory + "core1", "configSet", "configset-2");
|
SolrCore core1 = container.create(new CoreDescriptor(container, "core1", testDirectory + "core1", "configSet", "configset-2"));
|
||||||
assertThat(core1.getCoreDescriptor().getName(), is("core1"));
|
assertThat(core1.getCoreDescriptor().getName(), is("core1"));
|
||||||
assertThat(core1.getDataDir(), is(testDirectory + "core1" + File.separator + "data" + File.separator));
|
assertThat(core1.getDataDir(), is(testDirectory + "core1" + File.separator + "data" + File.separator));
|
||||||
}
|
}
|
||||||
finally {
|
finally {
|
||||||
if (core1 != null) {
|
|
||||||
core1.close();
|
|
||||||
}
|
|
||||||
if (container != null)
|
if (container != null)
|
||||||
container.shutdown();
|
container.shutdown();
|
||||||
}
|
}
|
||||||
|
@ -94,7 +90,7 @@ public class TestConfigSets extends SolrTestCaseJ4 {
|
||||||
container = setupContainer(getFile("solr/configsets").getAbsolutePath());
|
container = setupContainer(getFile("solr/configsets").getAbsolutePath());
|
||||||
String testDirectory = container.getResourceLoader().getInstanceDir();
|
String testDirectory = container.getResourceLoader().getInstanceDir();
|
||||||
|
|
||||||
container.create("core1", testDirectory + "/core1", "configSet", "nonexistent");
|
container.create(new CoreDescriptor(container, "core1", testDirectory + "/core1", "configSet", "nonexistent"));
|
||||||
fail("Expected core creation to fail");
|
fail("Expected core creation to fail");
|
||||||
}
|
}
|
||||||
catch (Exception e) {
|
catch (Exception e) {
|
||||||
|
@ -123,8 +119,7 @@ public class TestConfigSets extends SolrTestCaseJ4 {
|
||||||
container.load();
|
container.load();
|
||||||
|
|
||||||
// We initially don't have a /get handler defined
|
// We initially don't have a /get handler defined
|
||||||
SolrCore core = container.create("core1", testDirectory + "/core", "configSet", "configset-2");
|
SolrCore core = container.create(new CoreDescriptor(container, "core1", testDirectory + "/core", "configSet", "configset-2"));
|
||||||
container.register(core, false);
|
|
||||||
assertThat("No /get handler should be defined in the initial configuration",
|
assertThat("No /get handler should be defined in the initial configuration",
|
||||||
core.getRequestHandler("/get"), is(nullValue()));
|
core.getRequestHandler("/get"), is(nullValue()));
|
||||||
|
|
||||||
|
|
|
@ -17,9 +17,17 @@
|
||||||
|
|
||||||
package org.apache.solr.core;
|
package org.apache.solr.core;
|
||||||
|
|
||||||
import static org.hamcrest.core.Is.is;
|
import org.apache.commons.io.FileUtils;
|
||||||
import static org.hamcrest.core.IsInstanceOf.instanceOf;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
|
import org.apache.solr.handler.admin.CollectionsHandler;
|
||||||
|
import org.apache.solr.handler.admin.CoreAdminHandler;
|
||||||
|
import org.apache.solr.handler.admin.InfoHandler;
|
||||||
|
import org.junit.AfterClass;
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
|
import javax.xml.parsers.ParserConfigurationException;
|
||||||
import java.io.BufferedWriter;
|
import java.io.BufferedWriter;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
|
@ -31,18 +39,8 @@ import java.util.List;
|
||||||
import java.util.jar.JarEntry;
|
import java.util.jar.JarEntry;
|
||||||
import java.util.jar.JarOutputStream;
|
import java.util.jar.JarOutputStream;
|
||||||
|
|
||||||
import javax.xml.parsers.ParserConfigurationException;
|
import static org.hamcrest.core.Is.is;
|
||||||
|
import static org.hamcrest.core.IsInstanceOf.instanceOf;
|
||||||
import org.apache.commons.io.FileUtils;
|
|
||||||
import org.apache.lucene.util.TestUtil;
|
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
|
||||||
import org.apache.solr.handler.admin.CollectionsHandler;
|
|
||||||
import org.apache.solr.handler.admin.CoreAdminHandler;
|
|
||||||
import org.apache.solr.handler.admin.InfoHandler;
|
|
||||||
import org.junit.AfterClass;
|
|
||||||
import org.junit.BeforeClass;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.xml.sax.SAXException;
|
|
||||||
|
|
||||||
|
|
||||||
public class TestCoreContainer extends SolrTestCaseJ4 {
|
public class TestCoreContainer extends SolrTestCaseJ4 {
|
||||||
|
@ -91,9 +89,7 @@ public class TestCoreContainer extends SolrTestCaseJ4 {
|
||||||
SolrCore core2 = cores.create(descriptor2);
|
SolrCore core2 = cores.create(descriptor2);
|
||||||
|
|
||||||
assertSame(core1.getLatestSchema(), core2.getLatestSchema());
|
assertSame(core1.getLatestSchema(), core2.getLatestSchema());
|
||||||
|
|
||||||
core1.close();
|
|
||||||
core2.close();
|
|
||||||
} finally {
|
} finally {
|
||||||
cores.shutdown();
|
cores.shutdown();
|
||||||
System.clearProperty("shareSchema");
|
System.clearProperty("shareSchema");
|
||||||
|
@ -163,8 +159,7 @@ public class TestCoreContainer extends SolrTestCaseJ4 {
|
||||||
//add a new core
|
//add a new core
|
||||||
CoreDescriptor coreDescriptor = new CoreDescriptor(cores, "core1", solrHomeDirectory.getAbsolutePath());
|
CoreDescriptor coreDescriptor = new CoreDescriptor(cores, "core1", solrHomeDirectory.getAbsolutePath());
|
||||||
SolrCore newCore = cores.create(coreDescriptor);
|
SolrCore newCore = cores.create(coreDescriptor);
|
||||||
cores.register(newCore, false);
|
|
||||||
|
|
||||||
//assert one registered core
|
//assert one registered core
|
||||||
|
|
||||||
assertEquals("There core registered", 1, cores.getCores().size());
|
assertEquals("There core registered", 1, cores.getCores().size());
|
||||||
|
@ -225,7 +220,6 @@ public class TestCoreContainer extends SolrTestCaseJ4 {
|
||||||
ClassLoader coreLoader = core1.getResourceLoader().getClassLoader();
|
ClassLoader coreLoader = core1.getResourceLoader().getClassLoader();
|
||||||
assertSame(sharedLoader, coreLoader.getParent());
|
assertSame(sharedLoader, coreLoader.getParent());
|
||||||
|
|
||||||
core1.close();
|
|
||||||
} finally {
|
} finally {
|
||||||
cc.shutdown();
|
cc.shutdown();
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,26 +17,11 @@
|
||||||
|
|
||||||
package org.apache.solr.core;
|
package org.apache.solr.core;
|
||||||
|
|
||||||
import static org.hamcrest.core.Is.is;
|
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.xml.parsers.DocumentBuilder;
|
|
||||||
import javax.xml.parsers.DocumentBuilderFactory;
|
|
||||||
import javax.xml.parsers.ParserConfigurationException;
|
|
||||||
|
|
||||||
import com.carrotsearch.randomizedtesting.rules.SystemPropertiesRestoreRule;
|
import com.carrotsearch.randomizedtesting.rules.SystemPropertiesRestoreRule;
|
||||||
import org.apache.commons.io.FileUtils;
|
import org.apache.commons.io.FileUtils;
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
import org.apache.lucene.util.IOUtils;
|
import org.apache.lucene.util.IOUtils;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.TestUtil;
|
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.common.params.CoreAdminParams;
|
import org.apache.solr.common.params.CoreAdminParams;
|
||||||
import org.apache.solr.handler.admin.CoreAdminHandler;
|
import org.apache.solr.handler.admin.CoreAdminHandler;
|
||||||
|
@ -53,8 +38,19 @@ import org.w3c.dom.Node;
|
||||||
import org.w3c.dom.NodeList;
|
import org.w3c.dom.NodeList;
|
||||||
import org.xml.sax.SAXException;
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
import com.google.common.base.Charsets;
|
import javax.xml.parsers.DocumentBuilder;
|
||||||
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
import javax.xml.parsers.ParserConfigurationException;
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.hamcrest.core.Is.is;
|
||||||
|
|
||||||
public class TestSolrXmlPersistence extends SolrTestCaseJ4 {
|
public class TestSolrXmlPersistence extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
|
@ -446,8 +442,6 @@ public class TestSolrXmlPersistence extends SolrTestCaseJ4 {
|
||||||
try {
|
try {
|
||||||
x = cores.create(xd);
|
x = cores.create(xd);
|
||||||
y = cores.create(yd);
|
y = cores.create(yd);
|
||||||
cores.register(x, false);
|
|
||||||
cores.register(y, false);
|
|
||||||
|
|
||||||
assertEquals("cores not added?", 3, cores.getCoreNames().size());
|
assertEquals("cores not added?", 3, cores.getCoreNames().size());
|
||||||
|
|
||||||
|
|
|
@ -17,11 +17,7 @@ package org.apache.solr.update;
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.io.File;
|
import com.google.common.collect.Lists;
|
||||||
import java.io.UnsupportedEncodingException;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
|
|
||||||
import org.apache.lucene.index.DirectoryReader;
|
import org.apache.lucene.index.DirectoryReader;
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
|
@ -40,8 +36,10 @@ import org.junit.Before;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import java.io.File;
|
||||||
|
import java.io.UnsupportedEncodingException;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class SolrIndexSplitterTest extends SolrTestCaseJ4 {
|
public class SolrIndexSplitterTest extends SolrTestCaseJ4 {
|
||||||
File indexDir1 = null, indexDir2 = null, indexDir3 = null;
|
File indexDir1 = null, indexDir2 = null, indexDir3 = null;
|
||||||
|
@ -165,19 +163,11 @@ public class SolrIndexSplitterTest extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
CoreDescriptor dcore1 = buildCoreDescriptor(h.getCoreContainer(), "split1", instanceDir)
|
CoreDescriptor dcore1 = buildCoreDescriptor(h.getCoreContainer(), "split1", instanceDir)
|
||||||
.withDataDir(indexDir1.getAbsolutePath()).withSchema("schema12.xml").build();
|
.withDataDir(indexDir1.getAbsolutePath()).withSchema("schema12.xml").build();
|
||||||
if (h.getCoreContainer().getZkController() != null) {
|
|
||||||
h.getCoreContainer().preRegisterInZk(dcore1);
|
|
||||||
}
|
|
||||||
core1 = h.getCoreContainer().create(dcore1);
|
core1 = h.getCoreContainer().create(dcore1);
|
||||||
h.getCoreContainer().register(core1, false);
|
|
||||||
|
|
||||||
CoreDescriptor dcore2 = buildCoreDescriptor(h.getCoreContainer(), "split2", instanceDir)
|
CoreDescriptor dcore2 = buildCoreDescriptor(h.getCoreContainer(), "split2", instanceDir)
|
||||||
.withDataDir(indexDir2.getAbsolutePath()).withSchema("schema12.xml").build();
|
.withDataDir(indexDir2.getAbsolutePath()).withSchema("schema12.xml").build();
|
||||||
if (h.getCoreContainer().getZkController() != null) {
|
|
||||||
h.getCoreContainer().preRegisterInZk(dcore2);
|
|
||||||
}
|
|
||||||
core2 = h.getCoreContainer().create(dcore2);
|
core2 = h.getCoreContainer().create(dcore2);
|
||||||
h.getCoreContainer().register(core2, false);
|
|
||||||
|
|
||||||
LocalSolrQueryRequest request = null;
|
LocalSolrQueryRequest request = null;
|
||||||
try {
|
try {
|
||||||
|
|
Loading…
Reference in New Issue