forked from cmu-db/benchbase
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAbstractTestWorker.java
110 lines (94 loc) · 3.25 KB
/
AbstractTestWorker.java
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/*
* Copyright 2015 by OLTPBenchmark Project
*
* 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.oltpbenchmark.api;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import com.oltpbenchmark.api.Procedure.UserAbortException;
import java.io.IOException;
import java.util.List;
import java.util.concurrent.TimeUnit;
import org.apache.commons.lang3.time.StopWatch;
import org.junit.Test;
public abstract class AbstractTestWorker<T extends BenchmarkModule> extends AbstractTestCase<T> {
protected static final int NUM_TERMINALS = 1;
protected List<Worker<? extends BenchmarkModule>> workers;
public AbstractTestWorker() {
super(true, true);
}
public AbstractTestWorker(String ddlOverridePath) {
super(true, true, ddlOverridePath);
}
public AbstractTestWorker(String ddlOverridePath, String sessionSetupFile) {
super(true, true, ddlOverridePath, sessionSetupFile);
}
@Override
public List<String> ignorableTables() {
return null;
}
@Override
protected void postCreateDatabaseSetup() throws IOException {
this.workers = this.benchmark.makeWorkers();
assertNotNull(this.workers);
assertEquals(NUM_TERMINALS, this.workers.size());
}
/** testGetProcedure */
@Test
public void testGetProcedure() {
// Make sure that we can get a Procedure handle for each TransactionType
Worker<?> w = workers.get(0);
assertNotNull(w);
for (Class<? extends Procedure> procClass : this.procedures()) {
assertNotNull(procClass);
Procedure proc = w.getProcedure(procClass);
assertNotNull("Failed to get procedure " + procClass.getSimpleName(), proc);
assertEquals(procClass, proc.getClass());
}
}
/* testExecuteWork
* Similar to Worker.run()
*/
@Test
public void testExecuteWork() throws Exception {
Worker<?> w = workers.get(0);
assertNotNull(w);
w.setupSession();
w.initialize();
assertFalse(this.conn.isReadOnly());
for (TransactionType txnType : this.workConf.getTransTypes()) {
if (txnType.isSupplemental()) {
continue;
}
StopWatch sw = new StopWatch(txnType.toString());
try {
LOG.info("starting execution of [{}]", txnType);
sw.start();
w.executeWork(this.conn, txnType);
sw.stop();
} catch (UserAbortException ex) {
// These are expected, so they can be ignored
// Anything else is a serious error
} catch (Throwable ex) {
throw new RuntimeException("Failed to execute " + txnType, ex);
} finally {
LOG.info(
"completed execution of [{}] in {} ms",
txnType.toString(),
sw.getTime(TimeUnit.MILLISECONDS));
}
}
}
}