blob: 7e619cb55c09048cace125b428d9439447593dd4 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.solr.util;
import java.io.File;
/**
* Some tests need to reach outside the classpath to get certain resources (e.g. the example configuration).
* This class provides some paths to allow them to do this.
* @lucene.internal
*/
public class ExternalPaths {
/**
* <p>
* The main directory path for the solr source being built if it can be determined. If it
* can not be determined -- possily because the current context is a client code base
* using hte test frameowrk -- then this variable will be null.
* </p>
* <p>
* Note that all other static paths available in this class are derived from the source
* home, and if it is null, those paths will just be relative to 'null' and may not be
* meaningful.
*/
public static final String SOURCE_HOME = determineSourceHome();
/** @see #SOURCE_HOME */
public static String WEBAPP_HOME = new File(SOURCE_HOME, "webapp/web").getAbsolutePath();
/** @see #SOURCE_HOME */
public static String DEFAULT_CONFIGSET =
new File(SOURCE_HOME, "server/solr/configsets/_default/conf").getAbsolutePath();
/** @see #SOURCE_HOME */
public static String TECHPRODUCTS_CONFIGSET =
new File(SOURCE_HOME, "server/solr/configsets/sample_techproducts_configs/conf").getAbsolutePath();
/** @see #SOURCE_HOME */
public static String SERVER_HOME = new File(SOURCE_HOME, "server/solr").getAbsolutePath();
/**
* Ugly, ugly hack to determine the example home without depending on the CWD
* this is needed for example/multicore tests which reside outside the classpath.
* if the source home can't be determined, this method returns null.
*/
static String determineSourceHome() {
try {
File file;
try {
file = new File("solr/conf");
if (!file.exists()) {
file = new File(ExternalPaths.class.getClassLoader().getResource("solr/conf").toURI());
}
} catch (Exception e) {
// If there is no "solr/conf" in the classpath, fall back to searching from the current directory.
file = new File(System.getProperty("tests.src.home", "."));
}
File base = file.getAbsoluteFile();
while (!(new File(base, "solr/CHANGES.txt").exists()) && null != base) {
base = base.getParentFile();
}
return (null == base) ? null : new File(base, "solr/").getAbsolutePath();
} catch (RuntimeException e) {
// all bets are off
return null;
}
}
}