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

nl.hsac.fitnesse.fixture.slim.TimerFixture Maven / Gradle / Ivy

package nl.hsac.fitnesse.fixture.slim;

import org.apache.commons.lang3.time.StopWatch;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.LinkedHashMap;
import java.util.Locale;
import java.util.Map;

/**
 * Fixture to track time during a test.
 */
public class TimerFixture extends SlimFixture {
    private final static Map STOP_WATCHES = new LinkedHashMap<>();
    private final static String DEFAULT_STOP_WATCH = "default";

    /**
     * Starts (possibly replacing) default timer.
     */
    public void startTimer() {
        startTimer(DEFAULT_STOP_WATCH);
    }

    /**
     * Starts (possibly replacing) named timer.
     * @param name name to timer to create.
     */
    public void startTimer(String name) {
        StopWatch sw = new StopWatch();
        sw.start();
        STOP_WATCHES.put(name, sw);
    }

    /**
     * Stops default timer.
     * @return time in milliseconds since timer was started.
     */
    public long stopTimer() {
        return stopTimer(DEFAULT_STOP_WATCH);
    }

    /**
     * Stops named timer.
     * @param name name of timer to stop.
     * @return time in milliseconds since timer was started.
     */
    public long stopTimer(String name) {
        StopWatch sw = getStopWatch(name);
        sw.stop();
        STOP_WATCHES.remove(name);
        return sw.getTime();
    }

    /**
     * @return time in milliseconds since timer was started.
     */
    public long timeOnTimer() {
        return timeOnTimer(DEFAULT_STOP_WATCH);
    }

    /**
     * @param name name of timer to get time from.
     * @return time in milliseconds since timer was started.
     */
    public long timeOnTimer(String name) {
        return getStopWatch(name).getTime();
    }

    /**
     * Pauses default timer (stopping measurement), can be resumed later.
     * @return time in milliseconds since timer was started.
     */
    public long pauseTimer() {
        return pauseTimer(DEFAULT_STOP_WATCH);
    }

    /**
     * Pauses named timer (stopping measurement), can be resumed later.
     * @param name name of timer to pause.
     * @return time in milliseconds since timer was started.
     */
    public long pauseTimer(String name) {
        StopWatch sw = getStopWatch(name);
        sw.suspend();
        return sw.getTime();
    }

    /**
     * Resumes default timer (after it was paused).
     */
    public void resumeTimer() {
        resumeTimer(DEFAULT_STOP_WATCH);
    }

    /**
     * Resumes named timer (after it was paused).
     * @param name name of timer to resume.
     */
    public void resumeTimer(String name) {
        StopWatch sw = getStopWatch(name);
        sw.resume();
    }

    /**
     * @return all running timers and their current times (in ms).
     */
    public Map allTimerTimes() {
        Map result = new LinkedHashMap<>();
        for (Map.Entry entry: STOP_WATCHES.entrySet()) {
            String key = entry.getKey();
            long time = entry.getValue().getTime();
            result.put(key, time);
        }
        return result;
    }

    /**
     * Stops all running timers.
     * @return all stopped timers and their current times (in ms).
     */
    public Map stopAllTimers() {
        Map result = allTimerTimes();
        STOP_WATCHES.clear();
        return result;
    }

    protected StopWatch getStopWatch(String name) {
        StopWatch stopWatch = STOP_WATCHES.get(name);
        if (stopWatch == null) {
            throw new SlimFixtureException(false, "No timer found with name: " + name);
        }
        return stopWatch;
    }

    /**
     * @return current system time.
     */
    public String currentSystemTime() {
        return currentSystemTimeAs("HH:mm:ss.SSS");
    }

    /**
     * @param format to return time (and possibly date) in.
     * @return current system time formatted according to format.
     */
    public String currentSystemTimeAs(String format) {
        Locale locale = Locale.getDefault();
        return formatCurrentSystemTime(format, locale);
    }

    /**
     * @param format to return time (and possibly date) in.
     * @param languageTag language to use when formatting.
     * @return current system time formatted according to format.
     */
    public String currentSystemTimeAsIn(String format, String languageTag) {
        Locale locale = Locale.forLanguageTag(languageTag);
        return formatCurrentSystemTime(format, locale);
    }

    private String formatCurrentSystemTime(String format, Locale locale) {
        Date now = new Date();
        try {
            return new SimpleDateFormat(format, locale).format(now);
        } catch (IllegalArgumentException e) {
            throw new SlimFixtureException(false, "Bad date format: " + format);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy