package sqlancer;
import sqlancer.common.log.LoggableFactory;
public interface DatabaseProvider, O extends DBMSSpecificOptions>, C extends SQLancerDBConnection> {
/**
* Gets the the {@link GlobalState} class.
*
* @return the class extending {@link GlobalState}
*/
Class getGlobalStateClass();
/**
* Gets the JCommander option class.
*
* @return the class representing the DBMS-specific options.
*/
Class getOptionClass();
/**
* Generates a single database and executes a test oracle a given number of times.
*
* @param globalState
* the state created and is valid for this method call.
*
* @return Reproducer if a bug is found and a reproducer is available.
*
* @throws Exception
* if creating the database fails.
*
*/
Reproducer generateAndTestDatabase(G globalState) throws Exception;
/**
* The experimental feature: Query Plan Guidance.
*
* @param globalState
* the state created and is valid for this method call.
*
* @throws Exception
* if testing fails.
*
*/
void generateAndTestDatabaseWithQueryPlanGuidance(G globalState) throws Exception;
C createDatabase(G globalState) throws Exception;
/**
* The DBMS name is used to name the log directory and command to test the respective DBMS.
*
* @return the DBMS' name
*/
String getDBMSName();
LoggableFactory getLoggableFactory();
StateToReproduce getStateToReproduce(String databaseName);
}