com.nordstrom.automation.junit.JUnitConfig Maven / Gradle / Ivy
package com.nordstrom.automation.junit;
import java.io.IOException;
import org.apache.commons.configuration2.ex.ConfigurationException;
import com.nordstrom.automation.settings.SettingsCore;
import com.nordstrom.common.base.UncheckedThrow;
/**
* This class declares the settings and methods related to JUnit configuration.
*
* @see JUnitSettings
*/
public class JUnitConfig extends SettingsCore {
private static final String SETTINGS_FILE = "junit.properties";
/**
* This enumeration declares the settings that enable you to control the parameters
* used by JUnit Foundation.
*
* Each setting is defined by a constant name and System property key. Many settings
* also define default values. Note that all of these settings can be overridden via
* the {@code junit.properties} file and System property declarations.
*/
public enum JUnitSettings implements SettingsCore.SettingsAPI {
/** name: junit.rule.chain.list
default: {@code rulesStartingWithInnerMost} */
RULE_CHAIN_LIST("junit.rule.chain.list", "rulesStartingWithInnerMost"),
/** name: junit.timeout.test
default: {@code null} */
TEST_TIMEOUT("junit.timeout.test", null),
/** name: junit.max.retry
default: 0 */
MAX_RETRY("junit.max.retry", "0");
private String propertyName;
private String defaultValue;
JUnitSettings(String propertyName, String defaultValue) {
this.propertyName = propertyName;
this.defaultValue = defaultValue;
}
@Override
public String key() {
return propertyName;
}
@Override
public String val() {
return defaultValue;
}
}
private static final ThreadLocal junitConfig = new InheritableThreadLocal() {
@Override
protected JUnitConfig initialValue() {
try {
return new JUnitConfig();
} catch (ConfigurationException | IOException e) {
throw UncheckedThrow.throwUnchecked(e);
}
}
};
/**
* Instantiate a JUnit Foundation configuration object.
*
* @throws ConfigurationException If a failure is encountered while initializing this configuration object.
* @throws IOException If a failure is encountered while reading from a configuration input stream.
*/
public JUnitConfig() throws ConfigurationException, IOException {
super(JUnitSettings.class);
}
/**
* Get the JUnit configuration object for the specified context.
*
* @return JUnit configuration object
*/
public static JUnitConfig getConfig() {
return junitConfig.get();
}
@Override
public String getSettingsPath() {
return SETTINGS_FILE;
}
}