com.graphaware.test.performance.PerformanceTestSuite Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tests Show documentation
Show all versions of tests Show documentation
Tools for testing Neo4j-related and GraphAware-related code
/*
* Copyright (c) 2014 GraphAware
*
* This file is part of GraphAware.
*
* GraphAware is free software: you can redistribute it and/or modify it under the terms of
* the GNU General Public License as published by the Free Software Foundation, either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details. You should have received a copy of
* the GNU General Public License along with this program. If not, see
* .
*/
package com.graphaware.test.performance;
import org.junit.Test;
import org.junit.rules.TemporaryFolder;
import org.neo4j.graphdb.GraphDatabaseService;
import org.neo4j.graphdb.factory.GraphDatabaseBuilder;
import org.neo4j.graphdb.factory.GraphDatabaseFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.util.*;
import static com.graphaware.common.util.DatabaseUtils.registerShutdownHook;
/**
* Base class for suites of {@link PerformanceTest}s.
*/
public abstract class PerformanceTestSuite {
private static final Logger LOG = LoggerFactory.getLogger(PerformanceTestSuite.class);
protected TemporaryFolder temporaryFolder;
protected GraphDatabaseService database;
/**
* Get the performance tests run as a part of this test suite.
*
* @return performance tests, which will be run in this order.
*/
protected abstract PerformanceTest[] getPerfTests();
/**
* Perform the actual measurements and report results.
*/
@Test
public void measurePerformance() {
LOG.info("Performance test suite started.");
for (PerformanceTest performanceTest : getPerfTests()) {
LOG.info("Started performance test: " + performanceTest.longName());
TestResults testResults = run(performanceTest);
testResults.printToFile(performanceTest.longName(), getFileName(performanceTest));
LOG.info("Finished performance test: " + performanceTest.longName());
}
LOG.info("Performance test suite finished.");
}
/**
* Get the name of the file into which the results of this test will be written.
*
* @param performanceTest test.
* @return file name.
*/
protected String getFileName(PerformanceTest performanceTest) {
return performanceTest.shortName() + "-" + System.currentTimeMillis() + ".txt";
}
/**
* Run the performance test a number of times (specified by the test itself) for each combination of parameters.
*
* @param performanceTest to run.
* @return test results.
*/
private TestResults run(PerformanceTest performanceTest) {
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy