Search in sources :

Example 1 with QueueLoaderListener

use of com.axway.ats.agent.core.threading.listeners.QueueLoaderListener in project ats-framework by Axway.

the class LoadQueueFactory method createLoadQueue.

/**
     * Create an action task load queue based on the threading pattern selected
     * 
     * @param queueName name of the queue
     * @param actionRequests the action requests to execute with this queue
     * @param threadingPattern the threading pattern
     * @return
     * @throws NoSuchComponentException there is no registered component for one of the requested actions
     * @throws NoSuchActionException one of the actions requested does not exist
     * @throws NoCompatibleMethodFoundException if no action method is found, which corresponds to this request
     * @throws ThreadingPatternNotSupportedException if the supplied threading pattern is not supported
     */
public static final QueueLoader createLoadQueue(String queueName, List<ActionRequest> actionRequests, ThreadingPattern threadingPattern, List<ParameterDataProvider> parameterDataProviders, List<QueueLoaderListener> listeners) throws NoSuchComponentException, NoSuchActionException, NoCompatibleMethodFoundException, ThreadingPatternNotSupportedException {
    if (listeners == null) {
        listeners = new ArrayList<QueueLoaderListener>();
    }
    if (threadingPattern.getClass() == AllAtOncePattern.class) {
        //convert the "all at once" to "ramp up pattern"
        AllAtOncePattern allAtOncePattern = (AllAtOncePattern) threadingPattern;
        RampUpPattern rampUpPattern = new RampUpPattern(allAtOncePattern.getThreadCount(), allAtOncePattern.isBlockUntilCompletion(), allAtOncePattern.getIterationCount(), allAtOncePattern.getIntervalBetweenIterations());
        rampUpPattern.setMinIntervalBetweenIterations(allAtOncePattern.getMinIntervalBetweenIterations());
        rampUpPattern.setMaxIntervalBetweenIterations(allAtOncePattern.getMaxIntervalBetweenIterations());
        rampUpPattern.setIterationTimeout(allAtOncePattern.getIterationTimeout());
        return new RampUpQueueLoader(queueName, actionRequests, rampUpPattern, allAtOncePattern, parameterDataProviders, listeners);
    } else if (threadingPattern.getClass() == FixedDurationAllAtOncePattern.class) {
        //convert the "fixed duration all at once" to "fixed duration ramp up pattern"
        FixedDurationAllAtOncePattern allAtOncePattern = (FixedDurationAllAtOncePattern) threadingPattern;
        FixedDurationRampUpPattern rampUpPattern = new FixedDurationRampUpPattern(allAtOncePattern.getThreadCount(), allAtOncePattern.isBlockUntilCompletion(), allAtOncePattern.getDuration(), allAtOncePattern.getIntervalBetweenIterations());
        rampUpPattern.setMinIntervalBetweenIterations(allAtOncePattern.getMinIntervalBetweenIterations());
        rampUpPattern.setMaxIntervalBetweenIterations(allAtOncePattern.getMaxIntervalBetweenIterations());
        rampUpPattern.setIterationTimeout(threadingPattern.getIterationTimeout());
        return new RampUpQueueLoader(queueName, actionRequests, rampUpPattern, allAtOncePattern, parameterDataProviders, listeners);
    } else if (threadingPattern.getClass() == RampUpPattern.class || threadingPattern.getClass() == FixedDurationRampUpPattern.class) {
        //this is a real ramp-up pattern
        return new RampUpQueueLoader(queueName, actionRequests, (RampUpStartPattern) threadingPattern, (ExecutionPattern) threadingPattern, parameterDataProviders, listeners);
    } else {
        throw new ThreadingPatternNotSupportedException(threadingPattern.getClass().getSimpleName());
    }
}
Also used : ThreadingPatternNotSupportedException(com.axway.ats.agent.core.threading.exceptions.ThreadingPatternNotSupportedException) QueueLoaderListener(com.axway.ats.agent.core.threading.listeners.QueueLoaderListener) AllAtOncePattern(com.axway.ats.agent.core.threading.patterns.AllAtOncePattern) FixedDurationAllAtOncePattern(com.axway.ats.agent.core.threading.patterns.FixedDurationAllAtOncePattern) FixedDurationRampUpPattern(com.axway.ats.agent.core.threading.patterns.FixedDurationRampUpPattern) RampUpPattern(com.axway.ats.agent.core.threading.patterns.RampUpPattern) FixedDurationRampUpPattern(com.axway.ats.agent.core.threading.patterns.FixedDurationRampUpPattern) FixedDurationAllAtOncePattern(com.axway.ats.agent.core.threading.patterns.FixedDurationAllAtOncePattern)

Example 2 with QueueLoaderListener

use of com.axway.ats.agent.core.threading.listeners.QueueLoaderListener in project ats-framework by Axway.

the class AbstractQueueLoader method callOnFinish.

/**
     * Call "on finish" for all listeners
     */
protected final synchronized void callOnFinish() {
    //set the state
    state = ActionTaskLoaderState.FINISHED;
    //notify all listeners
    for (QueueLoaderListener listener : listeners) {
        listener.onFinish(queueName);
    }
    //notify the main thread that we are done
    this.notifyAll();
}
Also used : QueueLoaderListener(com.axway.ats.agent.core.threading.listeners.QueueLoaderListener)

Aggregations

QueueLoaderListener (com.axway.ats.agent.core.threading.listeners.QueueLoaderListener)2 ThreadingPatternNotSupportedException (com.axway.ats.agent.core.threading.exceptions.ThreadingPatternNotSupportedException)1 AllAtOncePattern (com.axway.ats.agent.core.threading.patterns.AllAtOncePattern)1 FixedDurationAllAtOncePattern (com.axway.ats.agent.core.threading.patterns.FixedDurationAllAtOncePattern)1 FixedDurationRampUpPattern (com.axway.ats.agent.core.threading.patterns.FixedDurationRampUpPattern)1 RampUpPattern (com.axway.ats.agent.core.threading.patterns.RampUpPattern)1