com.teradata.benchto.driver.loader.BenchmarkDescriptor Maven / Gradle / Ivy
/*
* 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.teradata.benchto.driver.loader;
import com.facebook.presto.jdbc.internal.guava.collect.ImmutableSet;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import static com.teradata.benchto.driver.utils.YamlUtils.asStringList;
/**
* Wrapper class around benchmark variables map with helper access methods.
*/
public class BenchmarkDescriptor
{
public static final String DATA_SOURCE_KEY = "datasource";
public static final String QUERY_NAMES_KEY = "query-names";
public static final String RUNS_KEY = "runs";
public static final String PREWARM_RUNS_KEY = "prewarm-runs";
public static final String CONCURRENCY_KEY = "concurrency";
public static final String BEFORE_BENCHMARK_MACROS_KEY = "before-benchmark";
public static final String AFTER_BENCHMARK_MACROS_KEY = "after-benchmark";
public static final String BEFORE_EXECUTION_MACROS_KEY = "before-execution";
public static final String AFTER_EXECUTION_MACROS_KEY = "after-execution";
public static final String VARIABLES_KEY = "variables";
public static final String QUARANTINE_KEY = "quarantine";
public static final String FREQUENCY_KEY = "frequency";
public static final Set RESERVED_KEYWORDS = ImmutableSet.of(
DATA_SOURCE_KEY,
QUERY_NAMES_KEY,
RUNS_KEY,
PREWARM_RUNS_KEY,
CONCURRENCY_KEY,
BEFORE_BENCHMARK_MACROS_KEY,
AFTER_BENCHMARK_MACROS_KEY,
BEFORE_EXECUTION_MACROS_KEY,
AFTER_EXECUTION_MACROS_KEY,
VARIABLES_KEY,
QUARANTINE_KEY,
FREQUENCY_KEY
);
private final Map variables;
public BenchmarkDescriptor(Map variables)
{
this.variables = variables;
this.variables.putIfAbsent(QUARANTINE_KEY, "false");
}
public Map getVariables()
{
return variables;
}
public String getDataSource()
{
return variables.get(DATA_SOURCE_KEY);
}
public List getQueryNames()
{
return asStringList(variables.get(QUERY_NAMES_KEY));
}
public Optional getRuns()
{
return getIntegerOptional(RUNS_KEY);
}
public Optional getPrewarmRepeats()
{
return getIntegerOptional(PREWARM_RUNS_KEY);
}
public Optional getConcurrency()
{
return getIntegerOptional(CONCURRENCY_KEY);
}
public Optional getFrequency()
{
return getIntegerOptional(FREQUENCY_KEY);
}
public List getBeforeBenchmarkMacros()
{
return asStringList(variables.getOrDefault(BEFORE_BENCHMARK_MACROS_KEY, ""));
}
public List getAfterBenchmarkMacros()
{
return asStringList(variables.getOrDefault(AFTER_BENCHMARK_MACROS_KEY, ""));
}
public List getBeforeExecutionMacros()
{
return asStringList(variables.getOrDefault(BEFORE_EXECUTION_MACROS_KEY, ""));
}
public List getAfterExecutionMacros()
{
return asStringList(variables.getOrDefault(AFTER_EXECUTION_MACROS_KEY, ""));
}
private Optional getIntegerOptional(String key)
{
if (variables.containsKey(key)) {
return Optional.of(Integer.valueOf(variables.get(key)));
}
return Optional.empty();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy