Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
慢慢CG
TDengine
提交
24164655
T
TDengine
项目概览
慢慢CG
/
TDengine
与 Fork 源项目一致
Fork自
taosdata / TDengine
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
24164655
编写于
5月 24, 2020
作者:
S
Steven Li
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fixed a few bugs in state transition checks
上级
a7221837
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
22 addition
and
10 deletion
+22
-10
tests/pytest/crash_gen.py
tests/pytest/crash_gen.py
+22
-10
未找到文件。
tests/pytest/crash_gen.py
浏览文件 @
24164655
...
...
@@ -480,7 +480,7 @@ class DbState():
def
getTasksAtState
(
self
):
tasks
=
[]
tasks
.
append
(
ReadFixedDataTask
(
self
))
# always
tasks
.
append
(
ReadFixedDataTask
(
self
))
# always
for everybody
if
(
self
.
_state
==
self
.
STATE_EMPTY
):
tasks
.
append
(
CreateDbTask
(
self
))
tasks
.
append
(
CreateFixedTableTask
(
self
))
...
...
@@ -535,11 +535,15 @@ class DbState():
self
.
_state
=
self
.
STATE_TABLE_ONLY
else
:
self
.
_state
=
self
.
STATE_HAS_DATA
else
:
# no success in dropping db tasks, no success in create fixed table, not acceptable
raise
RuntimeError
(
"Unexpected no-success scenario"
)
# What about AddFixedData?
elif
(
self
.
hasSuccess
(
tasks
,
AddFixedDataTask
)
):
self
.
_state
=
self
.
STATE_HAS_DATA
else
:
# no success in dropping db tasks, no success in create fixed table? read data should also fail
# raise RuntimeError("Unexpected no-success scenario") # We might just landed all failure tasks,
self
.
_state
=
self
.
STATE_DB_ONLY
# no change
elif
(
self
.
_state
==
self
.
STATE_TABLE_ONLY
):
if
(
self
.
hasSuccess
(
tasks
,
DropFixedTableTask
)
):
if
(
self
.
hasSuccess
(
tasks
,
DropFixedTableTask
)
):
# we are able to drop the table
self
.
assertAtMostOneSuccess
(
tasks
,
DropFixedTableTask
)
self
.
_state
=
self
.
STATE_DB_ONLY
elif
(
self
.
hasSuccess
(
tasks
,
AddFixedDataTask
)
):
# no success dropping the table, but added data
...
...
@@ -556,11 +560,19 @@ class DbState():
if
(
self
.
hasSuccess
(
tasks
,
DropFixedTableTask
)
):
self
.
assertAtMostOneSuccess
(
tasks
,
DropFixedTableTask
)
self
.
_state
=
self
.
STATE_DB_ONLY
elif
(
self
.
hasSuccess
(
tasks
,
AddFixedDataTask
)
):
# no success dropping the table
self
.
assertNoTask
(
tasks
,
DropFixedTableTask
)
self
.
_state
=
self
.
STATE_HAS_DATA
else
:
# did not drop table, did not insert data, that is impossible
raise
RuntimeError
(
"Unexpected no-success scenarios"
)
else
:
# no success dropping the table, table remains intact in this step
self
.
assertNoTask
(
tasks
,
DropFixedTableTask
)
# we should not have had such a task
if
(
self
.
hasSuccess
(
tasks
,
AddFixedDataTask
)
):
# added data
self
.
_state
=
self
.
STATE_HAS_DATA
else
:
self
.
assertNoTask
(
tasks
,
AddFixedDataTask
)
if
(
self
.
hasSuccess
(
tasks
,
ReadFixedDataTask
)
):
# simple able to read some data
# which is ok, then no state change
self
.
_state
=
self
.
STATE_HAS_DATA
# no change
else
:
# did not drop table, did not insert data, that is impossible? yeah, we might only had ReadData task
raise
RuntimeError
(
"Unexpected no-success scenarios"
)
else
:
raise
RuntimeError
(
"Unexpected DbState state: {}"
.
format
(
self
.
_state
))
...
...
@@ -741,7 +753,7 @@ class AddDataTask(Task):
class
AddFixedDataTask
(
Task
):
def
_executeInternal
(
self
,
te
:
TaskExecutor
,
wt
:
WorkerThread
):
ds
=
self
.
_dbState
sql
=
"insert into db.
table_
{} values ('{}', {});"
.
format
(
ds
.
getFixedTableName
(),
ds
.
getNextTick
(),
ds
.
getNextInt
())
sql
=
"insert into db.{} values ('{}', {});"
.
format
(
ds
.
getFixedTableName
(),
ds
.
getNextTick
(),
ds
.
getNextInt
())
wt
.
execSql
(
sql
)
# Deterministic random number generator
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录