-
Notifications
You must be signed in to change notification settings - Fork 398
Expand file tree
/
Copy pathArangoDBOptions.java
More file actions
47 lines (36 loc) · 1.79 KB
/
ArangoDBOptions.java
File metadata and controls
47 lines (36 loc) · 1.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package sqlancer.arangodb;
import static sqlancer.arangodb.ArangoDBOptions.ArangoDBOracleFactory.QUERY_PARTITIONING;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import com.beust.jcommander.Parameter;
import sqlancer.DBMSSpecificOptions;
import sqlancer.OracleFactory;
import sqlancer.arangodb.test.ArangoDBQueryPartitioningWhereTester;
import sqlancer.common.oracle.CompositeTestOracle;
import sqlancer.common.oracle.TestOracle;
public class ArangoDBOptions implements DBMSSpecificOptions<ArangoDBOptions.ArangoDBOracleFactory> {
@Parameter(names = "--oracle")
public List<ArangoDBOracleFactory> oracles = Arrays.asList(QUERY_PARTITIONING);
@Parameter(names = "--test-random-type-inserts", description = "Insert random types instead of schema types.")
public boolean testRandomTypeInserts;
@Parameter(names = "--max-number-indexes", description = "The maximum number of indexes used.", arity = 1)
public int maxNumberIndexes = 15;
@Parameter(names = "--with-optimizer-rule-tests", description = "Adds an additional query, where a random set"
+ "of optimizer rules are disabled.", arity = 1)
public boolean withOptimizerRuleTests;
@Override
public List<ArangoDBOracleFactory> getTestOracleFactory() {
return oracles;
}
public enum ArangoDBOracleFactory implements OracleFactory<ArangoDBProvider.ArangoDBGlobalState> {
QUERY_PARTITIONING {
@Override
public TestOracle create(ArangoDBProvider.ArangoDBGlobalState globalState) throws Exception {
List<TestOracle> oracles = new ArrayList<>();
oracles.add(new ArangoDBQueryPartitioningWhereTester(globalState));
return new CompositeTestOracle(oracles, globalState);
}
}
}
}