private void testStatement(ConnectionSource connectionSource, DatabaseType databaseType, String statement,
String queryAfter, int rowN, boolean throwExecute, Callable<Integer> callable) throws Exception {
DatabaseConnection conn = createMock(DatabaseConnection.class);
CompiledStatement stmt = createMock(CompiledStatement.class);
DatabaseResults results = null;
final AtomicInteger rowC = new AtomicInteger(1);
if (throwExecute) {
expect(conn.compileStatement(isA(String.class), isA(StatementType.class), isA(FieldType[].class), anyInt())).andThrow(
new SQLException("you asked us to!!"));
} else {
expect(conn.compileStatement(isA(String.class), isA(StatementType.class), isA(FieldType[].class), anyInt())).andReturn(
stmt);
expect(stmt.runExecute()).andReturn(rowN);
stmt.close();
if (queryAfter != null) {
expect(
conn.compileStatement(isA(String.class), isA(StatementType.class), isA(FieldType[].class),
anyInt())).andReturn(stmt);
results = createMock(DatabaseResults.class);
expect(results.first()).andReturn(false);
expect(stmt.runQuery(null)).andReturn(results);
stmt.close();
replay(results);
rowC.incrementAndGet();
}