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

io.hyperfoil.api.config.Benchmark Maven / Gradle / Ivy

There is a newer version: 0.27
Show newest version
/*
 * Copyright 2018 Red Hat Inc. and/or its affiliates and other contributors
 * as indicated by the @authors tag. All rights reserved.
 * See the copyright.txt in the distribution for a
 * full listing of individual contributors.
 *
 * 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 io.hyperfoil.api.config;

import java.io.Serializable;
import java.util.Arrays;
import java.util.Collection;
import java.util.Map;
import java.util.stream.Stream;

/**
 * A benchmark is a collection of simulation, user,
 * SLA and scaling strategy (Ramp up, Steady State, Ramp Down, steady state variance)
 * that are to be run against the target environment.
 */
public class Benchmark implements Serializable {

    private final String name;
    private final String originalSource;
    private final Map files;
    private final Agent[] agents;
    private final int threads;
    private final Ergonomics ergonomics;
    private final Map http;
    private final Http defaultHttp;
    private final Collection phases;
    private final Map tags;
    private final long statisticsCollectionPeriod;

    public Benchmark(String name, String originalSource, Map files, Agent[] agents, int threads, Ergonomics ergonomics,
                     Map http, Collection phases,
                     Map tags, long statisticsCollectionPeriod) {
        this.name = name;
        this.originalSource = originalSource;
        this.files = files;
        this.agents = agents;
        this.threads = threads;
        this.ergonomics = ergonomics;
        this.http = http;
        this.defaultHttp = http.values().stream().filter(Http::isDefault).findFirst().orElse(null);
        this.phases = phases;
        this.tags = tags;
        this.statisticsCollectionPeriod = statisticsCollectionPeriod;
    }

    public String name() {
        return name;
    }

    public Agent[] agents() {
        return agents;
    }

    /**
     *  As the transformation from YAML is one-way (due to forks and iterations)
     *  here we store the original source (be it YAML or JSON)
     */
    public String source() {
        return originalSource;
    }

    public Map files() {
        return files;
    }

    public int threads() {
        return threads;
    }

    public Collection phases() {
        return phases;
    }

    public Map tags() {
        return tags;
    }

    public Map http() {
        return http;
    }

    public Http defaultHttp() {
        return defaultHttp;
    }

    public long statisticsCollectionPeriod() {
        return statisticsCollectionPeriod;
    }

    @Override
    public String toString() {
        return "Benchmark{name='" + name + '\'' +
            ", originalSource='" + originalSource + '\'' +
            ", agents=" + Arrays.toString(agents) +
            ", threads=" + threads +
            ", http=" + http +
            ", phases=" + phases +
            ", tags=" + tags +
            ", statisticsCollectionPeriod=" + statisticsCollectionPeriod +
        '}';
    }

    public Stream steps() {
        return phases().stream()
             .flatMap(phase -> Stream.of(phase.scenario().sequences()))
             .flatMap(sequence -> Stream.of(sequence.steps()));
    }

    public Phase[] phasesById() {
        Phase[] phases = new Phase[this.phases.size()];
        this.phases.forEach(p -> phases[p.id()] = p);
        return phases;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy