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

com.graphaware.test.performance.PerformanceTest Maven / Gradle / Ivy

/*
 * 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.neo4j.graphdb.GraphDatabaseService;

import java.util.List;
import java.util.Map;
import java.util.Random;

/**
 * A performance test. Each implementation should represent one type of test, e.g.:
 * - write throughput when creating relationships
 * - typical shortest path query
 * - ...
 */
public interface PerformanceTest {

    static final Random RANDOM = new Random(System.currentTimeMillis());

    /**
     * Get the name of this test. Will be used in the name of the results file.
     *
     * @return test name.
     */
    String shortName();

    /**
     * Get the name of this test. Will be used in descriptions.
     *
     * @return test name.
     */
    String longName();

    /**
     * Get all the parameters (variables) of this test. They are tried in the order they are returned from this method.
     *
     * @return test parameters.
     */
    List parameters();

    /**
     * How many dry runs of this test should be executed before measured runs start. This could be used, for example,
     * to warm up caches.
     *
     * @param params for current sequence of runs.
     * @return how many dry runs to execute, 0 for none.
     */
    int dryRuns(Map params);

    /**
     * How many measured runs of this test should be executed.
     *
     * @return the number of measured runs.
     */
    int measuredRuns();

    /**
     * Get the parameters for Neo4j (esp. cache config) for the current sequence of runs, based on the test parameters.
     *
     * @param params test parameters.
     * @return Neo4j database params.
     */
    Map databaseParameters(Map params);

    /**
     * Prepare the database for performance test, for instance, register the runtime, pre-populate with data, etc.
     *
     * @param database to prepare.
     * @param params   test parameters.
     */
    void prepareDatabase(GraphDatabaseService database, Map params);

    /**
     * Run the performance test.
     *
     * @param params test parameters.
     * @return measurement result in microseconds.
     */
    long run(GraphDatabaseService database, Map params);

    /**
     * When should the database be rebuilt?
     */
    enum RebuildDatabase {
        /**
         * Database created once for all runs of the test.
         */
        NEVER,
        /**
         * New database created (and prepared) for each new set of parameters.
         */
        AFTER_PARAM_CHANGE,
        /**
         * New database created (and prepared) for each run.
         */
        AFTER_EVERY_RUN,
        /**
         * New database created (and prepared) when the test says so.
         */
        TEST_DECIDES
    }

    /**
     * When should the database be rebuilt?
     *
     * @return when the database should be rebuilt.
     */
    RebuildDatabase rebuildDatabase();

    /**
     * Should the database be rebuilt before a run with the given parameters? Never called unless
     * {@link #rebuildDatabase()} returns {@link RebuildDatabase#TEST_DECIDES}.
     *
     * @param params with which the next test will be run.
     * @return true for db rebuild.
     */
    boolean rebuildDatabase(Map params);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy