testtimer.java
来自「非常棒的java数据库」· Java 代码 · 共 133 行
JAVA
133 行
/*
* Copyright 2004-2008 H2 Group. Licensed under the H2 License, Version 1.0
* (license2)
* Initial Developer: H2 Group
*/
package org.h2.test.synth;
import java.io.File;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Random;
import org.h2.test.TestBase;
import org.h2.tools.Backup;
import org.h2.tools.DeleteDbFiles;
/**
* A recovery test that checks the consistency of a database (if it exists),
* then deletes everything and runs in an endless loop executing random
* operations. This loop is usually stopped by switching off the computer.
*/
public class TestTimer extends TestBase {
public void test() throws Exception {
validateOld();
DeleteDbFiles.execute(baseDir, "timer", true);
loop();
}
private void loop() throws Exception {
println("loop");
Connection conn = getConnection("timer");
Statement stat = conn.createStatement();
stat.execute("CREATE TABLE TEST(ID IDENTITY, NAME VARCHAR)");
Random random = new Random();
int max = 0;
int count = 0;
long start = System.currentTimeMillis();
while (true) {
int action = random.nextInt(10);
int x = max == 0 ? 0 : random.nextInt(max);
switch (action) {
case 0:
case 1:
case 2:
stat.execute("INSERT INTO TEST VALUES(NULL, 'Hello')");
ResultSet rs = stat.getGeneratedKeys();
rs.next();
int i = rs.getInt(1);
max = i;
count++;
break;
case 3:
case 4:
if (count == 0) {
break;
}
stat.execute("UPDATE TEST SET NAME=NAME||'+' WHERE ID=" + x);
break;
case 5:
case 6:
if (count == 0) {
break;
}
count -= stat.executeUpdate("DELETE FROM TEST WHERE ID=" + x);
break;
case 7:
rs = stat.executeQuery("SELECT COUNT(*) FROM TEST");
rs.next();
int c = rs.getInt(1);
check(c, count);
long time = System.currentTimeMillis();
if (time > start + 5000) {
println("rows: " + count);
start = time;
}
break;
}
}
}
private void validateOld() {
println("validate");
try {
Connection conn = getConnection("timer");
// TODO validate transactions
Statement stat = conn.createStatement();
stat.execute("CREATE TABLE IF NOT EXISTS TEST(ID IDENTITY, NAME VARCHAR)");
ResultSet rs = stat.executeQuery("SELECT COUNT(*) FROM TEST");
rs.next();
int count = rs.getInt(1);
println("row count: " + count);
int real = 0;
rs = stat.executeQuery("SELECT * FROM TEST");
while (rs.next()) {
real++;
}
if (real != count) {
println("real count: " + real);
throw new Error("COUNT(*)=" + count + " SELECT=" + real);
}
rs = stat.executeQuery("SCRIPT");
while (rs.next()) {
rs.getString(1);
}
conn.close();
} catch (Throwable e) {
logError("validate", e);
backup();
}
}
private void backup() {
println("backup");
for (int i = 0;; i++) {
String s = "timer." + i + ".zip";
File f = new File(s);
if (f.exists()) {
continue;
}
try {
Backup.execute(s, baseDir, "timer", true);
} catch (SQLException e) {
logError("backup", e);
}
break;
}
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?