Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
11cd588d
提交
11cd588d
authored
17 年前
作者:
Thomas Mueller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
--no commit message
--no commit message
上级
bc5a2a8e
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
112 行增加
和
0 行删除
+112
-0
TestTimer.java
h2/src/test/org/h2/test/synth/TestTimer.java
+112
-0
没有找到文件。
h2/src/test/org/h2/test/synth/TestTimer.java
0 → 100644
浏览文件 @
11cd588d
/*
* Copyright 2004-2006 H2 Group. Licensed under the H2 License, Version 1.0 (http://h2database.com/html/license.html).
* 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
;
public
class
TestTimer
extends
TestBase
{
public
void
test
()
throws
Exception
{
validateOld
();
DeleteDbFiles
.
execute
(
BASE_DIR
,
"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"
);
int
todoValidateTransactions
;
Statement
stat
=
conn
.
createStatement
();
ResultSet
rs
=
stat
.
executeQuery
(
"SELECT COUNT(*) FROM TEST"
);
rs
.
next
();
int
count
=
rs
.
getInt
(
1
);
conn
.
close
();
println
(
"done, rows: "
+
count
);
}
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
,
BASE_DIR
,
"timer"
,
true
);
}
catch
(
SQLException
e
)
{
logError
(
"backup"
,
e
);
}
break
;
}
}
}
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论