Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
慢慢CG
TDengine
提交
404797b5
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看板
提交
404797b5
编写于
5月 28, 2020
作者:
S
Steven Li
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Re-created TD-437
上级
d536eb56
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
39 addition
and
17 deletion
+39
-17
tests/pytest/crash_gen.py
tests/pytest/crash_gen.py
+39
-17
未找到文件。
tests/pytest/crash_gen.py
浏览文件 @
404797b5
...
@@ -115,7 +115,7 @@ class WorkerThread:
...
@@ -115,7 +115,7 @@ class WorkerThread:
logger
.
debug
(
"[TRD] Worker thread [{}] about to fetch task"
.
format
(
self
.
_tid
))
logger
.
debug
(
"[TRD] Worker thread [{}] about to fetch task"
.
format
(
self
.
_tid
))
task
=
tc
.
fetchTask
()
task
=
tc
.
fetchTask
()
logger
.
debug
(
"[TRD] Worker thread [{}] about to execute task
"
.
format
(
self
.
_tid
))
logger
.
debug
(
"[TRD] Worker thread [{}] about to execute task
: {}"
.
format
(
self
.
_tid
,
task
.
__class__
.
__name__
))
task
.
execute
(
self
)
task
.
execute
(
self
)
tc
.
saveExecutedTask
(
task
)
tc
.
saveExecutedTask
(
task
)
logger
.
debug
(
"[TRD] Worker thread [{}] finished executing task"
.
format
(
self
.
_tid
))
logger
.
debug
(
"[TRD] Worker thread [{}] finished executing task"
.
format
(
self
.
_tid
))
...
@@ -553,6 +553,12 @@ class AnyState:
...
@@ -553,6 +553,12 @@ class AnyState:
return
True
return
True
return
False
return
False
def
hasTask
(
self
,
tasks
,
cls
):
for
task
in
tasks
:
if
isinstance
(
task
,
cls
):
return
True
return
False
class
StateInvalid
(
AnyState
):
class
StateInvalid
(
AnyState
):
def
getInfo
(
self
):
def
getInfo
(
self
):
return
[
return
[
...
@@ -573,9 +579,10 @@ class StateEmpty(AnyState):
...
@@ -573,9 +579,10 @@ class StateEmpty(AnyState):
False
,
False
,
# can insert/read data with fixed table
False
,
False
,
# can insert/read data with fixed table
]
]
def
verifyTasksToState
(
self
,
tasks
,
newState
):
def
verifyTasksToState
(
self
,
tasks
,
newState
):
if
(
self
.
hasSuccess
(
tasks
,
CreateDbTask
)
):
if
(
self
.
hasSuccess
(
tasks
,
CreateDbTask
)
):
# at EMPTY, if there's succes in creating DB
self
.
assertAtMostOneSuccess
(
tasks
,
CreateDbTask
)
# not really valid for massively parrallel tasks
if
(
not
self
.
hasTask
(
tasks
,
DropDbTask
)
)
:
# and no drop_db tasks
self
.
assertAtMostOneSuccess
(
tasks
,
CreateDbTask
)
# we must have at most one. TODO: compare numbers
class
StateDbOnly
(
AnyState
):
class
StateDbOnly
(
AnyState
):
def
getInfo
(
self
):
def
getInfo
(
self
):
...
@@ -589,7 +596,7 @@ class StateDbOnly(AnyState):
...
@@ -589,7 +596,7 @@ class StateDbOnly(AnyState):
def
verifyTasksToState
(
self
,
tasks
,
newState
):
def
verifyTasksToState
(
self
,
tasks
,
newState
):
self
.
assertAtMostOneSuccess
(
tasks
,
DropDbTask
)
# not true in massively parralel cases
self
.
assertAtMostOneSuccess
(
tasks
,
DropDbTask
)
# not true in massively parralel cases
self
.
assertIfExistThenSuccess
(
tasks
,
DropDbTask
)
self
.
assertIfExistThenSuccess
(
tasks
,
DropDbTask
)
self
.
assertAtMostOneSuccess
(
tasks
,
CreateFixedTableTask
)
# self.assertAtMostOneSuccess(tasks, CreateFixedTableTask) # not true in massively parrallel cases
# Nothing to be said about adding data task
# Nothing to be said about adding data task
if
(
self
.
hasSuccess
(
tasks
,
DropDbTask
)
):
# dropped the DB
if
(
self
.
hasSuccess
(
tasks
,
DropDbTask
)
):
# dropped the DB
# self.assertHasTask(tasks, DropDbTask) # implied by hasSuccess
# self.assertHasTask(tasks, DropDbTask) # implied by hasSuccess
...
@@ -624,12 +631,12 @@ class StateTableOnly(AnyState):
...
@@ -624,12 +631,12 @@ class StateTableOnly(AnyState):
if
(
self
.
hasSuccess
(
tasks
,
DropFixedTableTask
)
):
# we are able to drop the table
if
(
self
.
hasSuccess
(
tasks
,
DropFixedTableTask
)
):
# we are able to drop the table
self
.
assertAtMostOneSuccess
(
tasks
,
DropFixedTableTask
)
self
.
assertAtMostOneSuccess
(
tasks
,
DropFixedTableTask
)
# self._state = self.STATE_DB_ONLY
# self._state = self.STATE_DB_ONLY
elif
(
self
.
hasSuccess
(
tasks
,
AddFixedDataTask
)
):
# no success dropping the table, but added data
#
elif ( self.hasSuccess(tasks, AddFixedDataTask) ): # no success dropping the table, but added data
self
.
assertNoTask
(
tasks
,
DropFixedTableTask
)
# self.assertNoTask(tasks, DropFixedTableTask) # not true in massively parrallel cases
# self._state = self.STATE_HAS_DATA
# self._state = self.STATE_HAS_DATA
elif
(
self
.
hasSuccess
(
tasks
,
ReadFixedDataTask
)
):
# no success in prev cases, but was able to read data
#
elif ( self.hasSuccess(tasks, ReadFixedDataTask) ): # no success in prev cases, but was able to read data
self
.
assertNoTask
(
tasks
,
DropFixedTableTask
)
#
self.assertNoTask(tasks, DropFixedTableTask)
self
.
assertNoTask
(
tasks
,
AddFixedDataTask
)
#
self.assertNoTask(tasks, AddFixedDataTask)
# self._state = self.STATE_TABLE_ONLY # no change
# self._state = self.STATE_TABLE_ONLY # no change
# else: # did not drop table, did not insert data, did not read successfully, that is impossible
# else: # did not drop table, did not insert data, did not read successfully, that is impossible
# raise RuntimeError("Unexpected no-success scenarios")
# raise RuntimeError("Unexpected no-success scenarios")
...
@@ -648,8 +655,9 @@ class StateHasData(AnyState):
...
@@ -648,8 +655,9 @@ class StateHasData(AnyState):
if
(
newState
.
equals
(
AnyState
.
STATE_EMPTY
)
):
if
(
newState
.
equals
(
AnyState
.
STATE_EMPTY
)
):
self
.
hasSuccess
(
tasks
,
DropDbTask
)
self
.
hasSuccess
(
tasks
,
DropDbTask
)
self
.
assertAtMostOneSuccess
(
tasks
,
DropDbTask
)
# TODO: dicy
self
.
assertAtMostOneSuccess
(
tasks
,
DropDbTask
)
# TODO: dicy
elif
(
newState
.
equals
(
AnyState
.
STATE_DB_ONLY
)
):
elif
(
newState
.
equals
(
AnyState
.
STATE_DB_ONLY
)
):
# in DB only
self
.
assertNoTask
(
tasks
,
DropDbTask
)
if
(
not
self
.
hasTask
(
tasks
,
CreateDbTask
)):
# without a create_db task
self
.
assertNoTask
(
tasks
,
DropDbTask
)
# we must have drop_db task
self
.
hasSuccess
(
tasks
,
DropFixedTableTask
)
self
.
hasSuccess
(
tasks
,
DropFixedTableTask
)
self
.
assertAtMostOneSuccess
(
tasks
,
DropFixedTableTask
)
# TODO: dicy
self
.
assertAtMostOneSuccess
(
tasks
,
DropFixedTableTask
)
# TODO: dicy
elif
(
newState
.
equals
(
AnyState
.
STATE_TABLE_ONLY
)
):
# data deleted
elif
(
newState
.
equals
(
AnyState
.
STATE_TABLE_ONLY
)
):
# data deleted
...
@@ -791,18 +799,23 @@ class DbState():
...
@@ -791,18 +799,23 @@ class DbState():
def
_findCurrentState
(
self
):
def
_findCurrentState
(
self
):
dbc
=
self
.
_dbConn
dbc
=
self
.
_dbConn
ts
=
time
.
time
()
if
dbc
.
query
(
"show databases"
)
==
0
:
# no database?!
if
dbc
.
query
(
"show databases"
)
==
0
:
# no database?!
# logger.debug("Found EMPTY state")
# logger.debug("Found EMPTY state")
logger
.
debug
(
"[STT] empty database found, between {} and {}"
.
format
(
ts
,
time
.
time
()))
return
StateEmpty
()
return
StateEmpty
()
dbc
.
execute
(
"use db"
)
# did not do this when openning connection
dbc
.
execute
(
"use db"
)
# did not do this when openning connection
if
dbc
.
query
(
"show tables"
)
==
0
:
# no tables
if
dbc
.
query
(
"show tables"
)
==
0
:
# no tables
# logger.debug("Found DB ONLY state")
# logger.debug("Found DB ONLY state")
logger
.
debug
(
"[STT] DB_ONLY found, between {} and {}"
.
format
(
ts
,
time
.
time
()))
return
StateDbOnly
()
return
StateDbOnly
()
if
dbc
.
query
(
"SELECT * FROM db.{}"
.
format
(
self
.
getFixedTableName
())
)
==
0
:
# no data
if
dbc
.
query
(
"SELECT * FROM db.{}"
.
format
(
self
.
getFixedTableName
())
)
==
0
:
# no data
# logger.debug("Found TABLE_ONLY state")
# logger.debug("Found TABLE_ONLY state")
logger
.
debug
(
"[STT] TABLE_ONLY found, between {} and {}"
.
format
(
ts
,
time
.
time
()))
return
StateTableOnly
()
return
StateTableOnly
()
else
:
else
:
# logger.debug("Found HAS_DATA state")
# logger.debug("Found HAS_DATA state")
logger
.
debug
(
"[STT] HAS_DATA found, between {} and {}"
.
format
(
ts
,
time
.
time
()))
return
StateHasData
()
return
StateHasData
()
def
transition
(
self
,
tasks
):
def
transition
(
self
,
tasks
):
...
@@ -835,10 +848,9 @@ class DbState():
...
@@ -835,10 +848,9 @@ class DbState():
# Nothing for sure
# Nothing for sure
newState
=
self
.
_findCurrentState
()
newState
=
self
.
_findCurrentState
()
logger
.
debug
(
"[STT] New DB state determined: {}"
.
format
(
newState
))
self
.
_state
.
verifyTasksToState
(
tasks
,
newState
)
# can old state move to new state through the tasks?
self
.
_state
.
verifyTasksToState
(
tasks
,
newState
)
# can old state move to new state through the tasks?
self
.
_state
=
newState
self
.
_state
=
newState
logger
.
debug
(
"New DB state is: {}"
.
format
(
self
.
_state
))
class
TaskExecutor
():
class
TaskExecutor
():
def
__init__
(
self
,
curStep
):
def
__init__
(
self
,
curStep
):
...
@@ -1039,6 +1051,7 @@ class DropDbTask(StateTransitionTask):
...
@@ -1039,6 +1051,7 @@ class DropDbTask(StateTransitionTask):
def
_executeInternal
(
self
,
te
:
TaskExecutor
,
wt
:
WorkerThread
):
def
_executeInternal
(
self
,
te
:
TaskExecutor
,
wt
:
WorkerThread
):
wt
.
execSql
(
"drop database db"
)
wt
.
execSql
(
"drop database db"
)
logger
.
debug
(
"[OPS] database dropped at {}"
.
format
(
time
.
time
()))
class
CreateFixedTableTask
(
StateTransitionTask
):
class
CreateFixedTableTask
(
StateTransitionTask
):
@
classmethod
@
classmethod
...
@@ -1207,8 +1220,11 @@ class LoggingFilter(logging.Filter):
...
@@ -1207,8 +1220,11 @@ class LoggingFilter(logging.Filter):
msg
=
record
.
msg
msg
=
record
.
msg
# print("type = {}, value={}".format(type(msg), msg))
# print("type = {}, value={}".format(type(msg), msg))
# sys.exit()
# sys.exit()
if
msg
.
startswith
(
"[TRD]"
):
return
False
# Commenting out below to adjust...
# if msg.startswith("[TRD]"):
# return False
return
True
return
True
...
@@ -1241,7 +1257,7 @@ def main():
...
@@ -1241,7 +1257,7 @@ def main():
global
logger
global
logger
logger
=
logging
.
getLogger
(
'CrashGen'
)
logger
=
logging
.
getLogger
(
'CrashGen'
)
#
logger.addFilter(LoggingFilter())
logger
.
addFilter
(
LoggingFilter
())
if
(
gConfig
.
debug
):
if
(
gConfig
.
debug
):
logger
.
setLevel
(
logging
.
DEBUG
)
# default seems to be INFO
logger
.
setLevel
(
logging
.
DEBUG
)
# default seems to be INFO
else
:
else
:
...
@@ -1256,6 +1272,12 @@ def main():
...
@@ -1256,6 +1272,12 @@ def main():
# WorkDispatcher(dbState), # Obsolete?
# WorkDispatcher(dbState), # Obsolete?
dbState
dbState
)
)
# Sandbox testing code
# dbc = dbState.getDbConn()
# while True:
# rows = dbc.query("show databases")
# print("Rows: {}, time={}".format(rows, time.time()))
tc
.
run
()
tc
.
run
()
tc
.
logStats
()
tc
.
logStats
()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录