/*
* Copyright (c) 2010-2012 Grid Dynamics Consulting Services, Inc, All Rights Reserved
* http://www.griddynamics.com
*
* This library is free software; you can redistribute it and/or modify it under the terms of
* the Apache License; either
* version 2.0 of the License, or any later version.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package com.griddynamics.jagger.tpspolygon;
import com.griddynamics.jagger.engine.e1.scenario.DefaultWorkloadSuggestionMaker;
import com.griddynamics.jagger.engine.e1.scenario.NodeTpsRecorder;
import com.griddynamics.jagger.engine.e1.scenario.WorkloadConfiguration;
import com.griddynamics.jagger.util.Pair;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.Map;
public class TpsTest {
public static void main(String[] args) {
DefaultWorkloadSuggestionMaker workloadSuggestionMaker = new DefaultWorkloadSuggestionMaker(10);
BigDecimal desired = new BigDecimal(1000000000);
int maxThreads = 100;
NodeTpsRecorder stats = new NodeTpsRecorder(5);
// TpsGenerator tpsGenerator = new PowTpsGenerator(3);
TpsGenerator tpsGenerator = new RandomFactor(new PowTpsGenerator(2));
StubCreator stubCreator = new StubCreator(100L, tpsGenerator);
stats.recordStatus(0, 0, 0, 0);
for (int i = 0; i < 2000; i++) {
WorkloadConfiguration suggest = workloadSuggestionMaker.suggest(desired, stats, maxThreads);
Pair<Long, Long> generate = stubCreator.create(suggest);
stats.recordStatus(suggest.getThreads(), suggest.getDelay(), generate.getFirst(), generate.getSecond());
}
Map<Long, Pair<WorkloadConfiguration, BigDecimal>> tpsHistory = stats.getTpsHistory();
BigDecimal total = BigDecimal.ZERO;
int count = 0;
for (Pair<WorkloadConfiguration, BigDecimal> pair : tpsHistory.values()) {
count++;
BigDecimal second = pair.getSecond();
total = total.add(second);
}
BigDecimal avg = total.divide(new BigDecimal(count), 3, RoundingMode.HALF_UP);
System.out.println("avg " + avg);
}
}