All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy