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

com.consol.citrus.actions.StopTimeAction Maven / Gradle / Ivy

/*
 * Copyright 2006-2010 the original author or authors.
 *
 * Licensed 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 com.consol.citrus.actions;

import com.consol.citrus.context.TestContext;
import com.consol.citrus.exceptions.CitrusRuntimeException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.HashMap;
import java.util.Map;

/**
 * Action used for time measurement during test. User can define a time line that is followed
 * during the test case. Action can print out the watched time to the console/logger.
 * 
 * @author Christoph Deppisch
 * @since 2006
 */
public class StopTimeAction extends AbstractTestAction {

    /** Static member to hold all time stamps */
    private static Map timeStamps = new HashMap<>();

    /** Current time line id */
    private String id = "CITRUS_TIMELINE";

    /** Logger */
    private static Logger log = LoggerFactory.getLogger(StopTimeAction.class);

    /**
     * Default constructor.
     */
    public StopTimeAction() {
        setName("stop-time");
    }

    @Override
    public void doExecute(TestContext context) {
        try {
            if (timeStamps.containsKey(id)) {
                if (description != null) {
                    log.info("TimeWatcher " + id + " after " + (System.currentTimeMillis() - timeStamps.get(id).longValue()) + " ms (" + description + ")");
                } else {
                    log.info("TimeWatcher " + id + " after " + (System.currentTimeMillis() - timeStamps.get(id).longValue()) + " ms");
                }
            } else {
                log.info("Starting TimeWatcher: " + id);
                timeStamps.put(id, System.currentTimeMillis());
            }
        } catch (Exception e) {
            throw new CitrusRuntimeException(e);
        }
    }

    /**
     * Setter for timeline id.
     * @param period
     */
    public StopTimeAction setId(String period) {
        this.id = period;
        return this;
    }

    /**
     * Get the current time stamps.
     * @return the timeStamps
     */
    public static Map getTimeStamps() {
        return timeStamps;
    }

    /**
     * Gets the id.
     * @return the id
     */
    public String getId() {
        return id;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy