Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
9e47c5e8
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22017
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
9e47c5e8
编写于
6月 24, 2020
作者:
S
Shengliang Guan
提交者:
GitHub
6月 24, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #2437 from taosdata/feature/sangshuduo/multi-thread-random-test
Feature/sangshuduo/multi thread random test
上级
d26d41e7
9c288084
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
316 addition
and
93 deletion
+316
-93
tests/pytest/random-test/random-test-multi-threading-3.py
tests/pytest/random-test/random-test-multi-threading-3.py
+104
-21
tests/pytest/random-test/random-test-multi-threading.py
tests/pytest/random-test/random-test-multi-threading.py
+123
-32
tests/pytest/random-test/random-test.py
tests/pytest/random-test/random-test.py
+88
-33
tests/pytest/stable/query_after_reset.py
tests/pytest/stable/query_after_reset.py
+1
-1
tests/pytest/util/sql.py
tests/pytest/util/sql.py
+0
-6
未找到文件。
tests/pytest/random-test/random-test-multi-threading-3.py
浏览文件 @
9e47c5e8
...
...
@@ -24,19 +24,23 @@ last_tb = ""
last_stb
=
""
written
=
0
last_timestamp
=
0
colAdded
=
False
killed
=
False
class
Test
(
Thread
):
def
__init__
(
self
,
threadId
,
name
,
events
):
def
__init__
(
self
,
threadId
,
name
,
events
,
q
):
Thread
.
__init__
(
self
)
self
.
threadId
=
threadId
self
.
name
=
name
self
.
dataEvent
,
self
.
dbEvent
,
self
.
queryEvent
=
events
self
.
q
=
q
def
create_table
(
self
):
tdLog
.
info
(
"create_table"
)
global
last_tb
global
written
global
killed
current_tb
=
"tb%d"
%
int
(
round
(
time
.
time
()
*
1000
))
...
...
@@ -51,8 +55,14 @@ class Test (Thread):
current_tb
)
last_tb
=
current_tb
written
=
0
killed
=
False
except
Exception
as
e
:
tdLog
.
info
(
repr
(
e
))
tdLog
.
info
(
"killed: %d error: %s"
%
(
killed
,
e
.
args
[
0
]))
if
killed
and
(
e
.
args
[
0
]
==
'network unavailable'
):
tdLog
.
info
(
"database killed, expect failed"
)
return
0
return
-
1
return
0
def
insert_data
(
self
):
tdLog
.
info
(
"insert_data"
)
...
...
@@ -74,22 +84,33 @@ class Test (Thread):
for
j
in
range
(
0
,
insertRows
):
if
(
last_tb
==
""
):
tdLog
.
info
(
"no table, return"
)
return
tdSql
.
execute
(
'insert into %s values (%d + %da, %d, "test")'
%
(
last_tb
,
start_time
,
last_timestamp
,
last_timestamp
))
written
=
written
+
1
last_timestamp
=
last_timestamp
+
1
return
0
try
:
tdSql
.
execute
(
'insert into %s values (%d + %da, %d, "test")'
%
(
last_tb
,
start_time
,
last_timestamp
,
last_timestamp
))
written
=
written
+
1
last_timestamp
=
last_timestamp
+
1
except
Exception
as
e
:
if
killed
:
tdLog
.
info
(
"database killed, expect failed %s"
%
e
.
args
[
0
])
return
0
tdLog
.
info
(
repr
(
e
))
return
-
1
return
0
def
query_data
(
self
):
tdLog
.
info
(
"query_data"
)
global
last_tb
global
written
global
killed
if
(
written
>
0
)
:
if
not
killed
and
last_tb
!=
""
:
tdLog
.
info
(
"query data from table"
)
tdSql
.
query
(
"select * from %s"
%
last_tb
)
tdSql
.
checkRows
(
written
)
return
0
def
create_stable
(
self
):
tdLog
.
info
(
"create_stable"
)
...
...
@@ -123,6 +144,7 @@ class Test (Thread):
(
last_tb
,
start_time
,
last_timestamp
))
written
=
written
+
1
last_timestamp
=
last_timestamp
+
1
return
0
def
drop_stable
(
self
):
tdLog
.
info
(
"drop_stable"
)
...
...
@@ -139,22 +161,57 @@ class Test (Thread):
last_stb
=
""
last_tb
=
""
written
=
0
return
0
def
alter_table_to_add_col
(
self
):
tdLog
.
info
(
"alter_table_to_add_col"
)
global
last_stb
global
colAdded
if
last_stb
!=
""
and
colAdded
==
False
:
tdSql
.
execute
(
"alter table %s add column col binary(20)"
%
last_stb
)
colAdded
=
True
return
0
def
alter_table_to_drop_col
(
self
):
tdLog
.
info
(
"alter_table_to_drop_col"
)
global
last_stb
global
colAdded
if
last_stb
!=
""
and
colAdded
:
tdSql
.
execute
(
"alter table %s drop column col"
%
last_stb
)
colAdded
=
False
return
0
def
restart_database
(
self
):
tdLog
.
info
(
"restart_database"
)
global
last_tb
global
written
global
killed
tdDnodes
.
stop
(
1
)
killed
=
True
tdDnodes
.
start
(
1
)
tdLog
.
sleep
(
10
)
killed
=
False
return
0
def
force_restart_database
(
self
):
tdLog
.
info
(
"force_restart_database"
)
global
last_tb
global
written
global
killed
tdDnodes
.
forcestop
(
1
)
last_tb
=
""
written
=
0
killed
=
True
tdDnodes
.
start
(
1
)
# tdLog.sleep(10)
killed
=
False
return
0
def
drop_table
(
self
):
tdLog
.
info
(
"drop_table"
)
...
...
@@ -167,6 +224,7 @@ class Test (Thread):
tdSql
.
execute
(
"drop table %s"
%
last_tb
)
last_tb
=
""
written
=
0
return
0
def
query_data_from_stable
(
self
):
tdLog
.
info
(
"query_data_from_stable"
)
...
...
@@ -178,6 +236,7 @@ class Test (Thread):
else
:
tdLog
.
info
(
"will query data from super table"
)
tdSql
.
execute
(
'select * from %s'
%
last_stb
)
return
0
def
reset_query_cache
(
self
):
tdLog
.
info
(
"reset_query_cache"
)
...
...
@@ -187,39 +246,45 @@ class Test (Thread):
tdLog
.
info
(
"reset query cache"
)
tdSql
.
execute
(
"reset query cache"
)
tdLog
.
sleep
(
1
)
return
0
def
reset_database
(
self
):
tdLog
.
info
(
"reset_database"
)
global
last_tb
global
last_stb
global
written
global
killed
tdDnodes
.
forcestop
(
1
)
killed
=
True
tdDnodes
.
deploy
(
1
)
tdDnodes
.
start
(
1
)
tdSql
.
prepare
()
last_tb
=
""
last_stb
=
""
written
=
0
killed
=
False
return
0
def
delete_datafiles
(
self
):
tdLog
.
info
(
"delete_data_files"
)
global
last_tb
global
last_stb
global
written
global
killed
dnodesDir
=
tdDnodes
.
getDnodesRootDir
()
tdDnodes
.
forcestop
(
1
)
killed
=
True
dataDir
=
dnodesDir
+
'/dnode1/data/*'
deleteCmd
=
'rm -rf %s'
%
dataDir
os
.
system
(
deleteCmd
)
tdDnodes
.
start
(
1
)
tdSql
.
prepare
()
last_tb
=
""
last_stb
=
""
written
=
0
tdDnodes
.
start
(
1
)
tdSql
.
prepare
()
killed
=
False
return
0
def
run
(
self
):
dataOp
=
{
1
:
self
.
insert_data
,
...
...
@@ -235,6 +300,8 @@ class Test (Thread):
7
:
self
.
reset_database
,
8
:
self
.
delete_datafiles
,
9
:
self
.
drop_stable
,
10
:
self
.
alter_table_to_add_col
,
11
:
self
.
alter_table_to_drop_col
,
}
queryOp
=
{
...
...
@@ -247,16 +314,28 @@ class Test (Thread):
self
.
dataEvent
.
wait
()
tdLog
.
notice
(
"first thread"
)
randDataOp
=
random
.
randint
(
1
,
1
)
dataOp
.
get
(
randDataOp
,
lambda
:
"ERROR"
)()
self
.
dataEvent
.
clear
()
self
.
queryEvent
.
clear
()
self
.
dbEvent
.
set
()
ret1
=
dataOp
.
get
(
randDataOp
,
lambda
:
"ERROR"
)()
if
ret1
==
-
1
:
self
.
q
.
put
(
-
1
)
tdLog
.
exit
(
"first thread failed"
)
else
:
self
.
q
.
put
(
1
)
if
(
self
.
q
.
get
()
!=
-
2
):
self
.
dataEvent
.
clear
()
self
.
queryEvent
.
clear
()
self
.
dbEvent
.
set
()
else
:
self
.
q
.
put
(
-
1
)
tdLog
.
exit
(
"second thread failed, first thread exit too"
)
elif
(
self
.
threadId
==
2
):
while
True
:
self
.
dbEvent
.
wait
()
tdLog
.
notice
(
"second thread"
)
randDbOp
=
random
.
randint
(
1
,
9
)
randDbOp
=
random
.
randint
(
1
,
11
)
dbOp
.
get
(
randDbOp
,
lambda
:
"ERROR"
)()
self
.
dbEvent
.
clear
()
self
.
dataEvent
.
clear
()
...
...
@@ -298,6 +377,10 @@ class TDTestCase:
test2
.
join
()
test3
.
join
()
while
not
q
.
empty
():
if
(
q
.
get
()
!=
0
):
tdLog
.
exit
(
"failed to end of test"
)
tdLog
.
info
(
"end of test"
)
def
stop
(
self
):
...
...
tests/pytest/random-test/random-test-multi-threading.py
浏览文件 @
9e47c5e8
...
...
@@ -14,6 +14,7 @@
import
sys
import
random
import
threading
import
queue
from
util.log
import
*
from
util.cases
import
*
...
...
@@ -24,13 +25,16 @@ last_tb = ""
last_stb
=
""
written
=
0
last_timestamp
=
0
colAdded
=
False
killed
=
False
class
Test
(
threading
.
Thread
):
def
__init__
(
self
,
threadId
,
name
):
def
__init__
(
self
,
threadId
,
name
,
q
):
threading
.
Thread
.
__init__
(
self
)
self
.
threadId
=
threadId
self
.
name
=
name
self
.
q
=
q
self
.
threadLock
=
threading
.
Lock
()
...
...
@@ -38,11 +42,12 @@ class Test (threading.Thread):
tdLog
.
info
(
"create_table"
)
global
last_tb
global
written
global
killed
current_tb
=
"tb%d"
%
int
(
round
(
time
.
time
()
*
1000
))
if
(
current_tb
==
last_tb
):
return
return
0
else
:
tdLog
.
info
(
"will create table %s"
%
current_tb
)
...
...
@@ -52,8 +57,14 @@ class Test (threading.Thread):
current_tb
)
last_tb
=
current_tb
written
=
0
killed
=
False
except
Exception
as
e
:
tdLog
.
info
(
repr
(
e
))
tdLog
.
info
(
"killed: %d error: %s"
%
(
killed
,
e
.
args
[
0
]))
if
killed
and
(
e
.
args
[
0
]
==
'network unavailable'
):
tdLog
.
info
(
"database killed, expect failed"
)
return
0
return
-
1
return
0
def
insert_data
(
self
):
tdLog
.
info
(
"insert_data"
)
...
...
@@ -75,22 +86,34 @@ class Test (threading.Thread):
for
j
in
range
(
0
,
insertRows
):
if
(
last_tb
==
""
):
tdLog
.
info
(
"no table, return"
)
return
tdSql
.
execute
(
'insert into %s values (%d + %da, %d, "test")'
%
(
last_tb
,
start_time
,
last_timestamp
,
last_timestamp
))
written
=
written
+
1
last_timestamp
=
last_timestamp
+
1
return
0
try
:
tdSql
.
execute
(
'insert into %s values (%d + %da, %d, "test")'
%
(
last_tb
,
start_time
,
last_timestamp
,
last_timestamp
))
written
=
written
+
1
last_timestamp
=
last_timestamp
+
1
except
Exception
as
e
:
if
killed
:
tdLog
.
info
(
"database killed, expect failed %s"
%
e
.
args
[
0
])
return
0
tdLog
.
info
(
repr
(
e
))
return
-
1
return
0
def
query_data
(
self
):
tdLog
.
info
(
"query_data"
)
global
last_tb
global
written
global
killed
if
(
written
>
0
)
:
if
not
killed
and
last_tb
!=
""
:
tdLog
.
info
(
"query data from table"
)
tdSql
.
query
(
"select * from %s"
%
last_tb
)
tdSql
.
checkRows
(
written
)
return
0
def
create_stable
(
self
):
tdLog
.
info
(
"create_stable"
)
...
...
@@ -101,9 +124,7 @@ class Test (threading.Thread):
current_stb
=
"stb%d"
%
int
(
round
(
time
.
time
()
*
1000
))
if
(
current_stb
==
last_stb
):
return
else
:
if
(
current_stb
!=
last_stb
):
tdLog
.
info
(
"will create stable %s"
%
current_stb
)
tdLog
.
info
(
'create table %s(ts timestamp, c1 int, c2 nchar(10)) tags (t1 int, t2 nchar(10))'
%
...
...
@@ -131,6 +152,8 @@ class Test (threading.Thread):
written
=
written
+
1
last_timestamp
=
last_timestamp
+
1
return
0
def
drop_stable
(
self
):
tdLog
.
info
(
"drop_stable"
)
global
last_stb
...
...
@@ -139,31 +162,63 @@ class Test (threading.Thread):
if
(
last_stb
==
""
):
tdLog
.
info
(
"no super table"
)
return
else
:
tdLog
.
info
(
"will drop last super table
"
)
tdLog
.
info
(
"will drop last super table
%s"
%
last_stb
)
tdSql
.
execute
(
'drop table %s'
%
last_stb
)
last_stb
=
""
last_tb
=
""
written
=
0
return
0
def
alter_table_to_add_col
(
self
):
tdLog
.
info
(
"alter_table_to_add_col"
)
global
last_stb
global
colAdded
if
last_stb
!=
""
and
not
colAdded
:
tdSql
.
execute
(
"alter table %s add column col binary(20)"
%
last_stb
)
colAdded
=
True
return
0
def
alter_table_to_drop_col
(
self
):
tdLog
.
info
(
"alter_table_to_drop_col"
)
global
last_stb
global
colAdded
if
last_stb
!=
""
and
colAdded
:
tdSql
.
execute
(
"alter table %s drop column col"
%
last_stb
)
colAdded
=
False
return
0
def
restart_database
(
self
):
tdLog
.
info
(
"restart_database"
)
global
last_tb
global
written
global
killed
tdDnodes
.
stop
(
1
)
killed
=
True
tdDnodes
.
start
(
1
)
# tdLog.sleep(5)
tdLog
.
sleep
(
10
)
killed
=
False
return
0
def
force_restart_database
(
self
):
tdLog
.
info
(
"force_restart_database"
)
global
last_tb
global
written
global
killed
tdDnodes
.
forcestop
(
1
)
last_tb
=
""
written
=
0
killed
=
True
tdDnodes
.
start
(
1
)
# tdLog.sleep(10)
killed
=
False
return
0
def
drop_table
(
self
):
tdLog
.
info
(
"drop_table"
)
...
...
@@ -176,6 +231,7 @@ class Test (threading.Thread):
tdSql
.
execute
(
"drop table %s"
%
last_tb
)
last_tb
=
""
written
=
0
return
0
def
query_data_from_stable
(
self
):
tdLog
.
info
(
"query_data_from_stable"
)
...
...
@@ -183,10 +239,10 @@ class Test (threading.Thread):
if
(
last_stb
==
""
):
tdLog
.
info
(
"no super table"
)
return
else
:
tdLog
.
info
(
"will query data from super table"
)
tdSql
.
execute
(
'select * from %s'
%
last_stb
)
return
0
def
reset_query_cache
(
self
):
tdLog
.
info
(
"reset_query_cache"
)
...
...
@@ -196,39 +252,45 @@ class Test (threading.Thread):
tdLog
.
info
(
"reset query cache"
)
tdSql
.
execute
(
"reset query cache"
)
# tdLog.sleep(1)
return
0
def
reset_database
(
self
):
tdLog
.
info
(
"reset_database"
)
global
last_tb
global
last_stb
global
written
global
killed
tdDnodes
.
forcestop
(
1
)
killed
=
True
tdDnodes
.
deploy
(
1
)
tdDnodes
.
start
(
1
)
tdSql
.
prepare
()
last_tb
=
""
last_stb
=
""
written
=
0
killed
=
False
return
0
def
delete_datafiles
(
self
):
tdLog
.
info
(
"delete_data_files"
)
global
last_tb
global
last_stb
global
written
global
killed
dnodesDir
=
tdDnodes
.
getDnodesRootDir
()
tdDnodes
.
forcestop
(
1
)
killed
=
True
dataDir
=
dnodesDir
+
'/dnode1/data/*'
deleteCmd
=
'rm -rf %s'
%
dataDir
os
.
system
(
deleteCmd
)
tdDnodes
.
start
(
1
)
tdSql
.
prepare
()
last_tb
=
""
last_stb
=
""
written
=
0
tdDnodes
.
start
(
1
)
tdSql
.
prepare
()
killed
=
False
return
0
def
run
(
self
):
dataOp
=
{
1
:
self
.
insert_data
,
...
...
@@ -246,6 +308,8 @@ class Test (threading.Thread):
7
:
self
.
reset_database
,
8
:
self
.
delete_datafiles
,
9
:
self
.
drop_stable
,
10
:
self
.
alter_table_to_add_col
,
11
:
self
.
alter_table_to_drop_col
,
}
if
(
self
.
threadId
==
1
):
...
...
@@ -253,16 +317,38 @@ class Test (threading.Thread):
self
.
threadLock
.
acquire
()
tdLog
.
notice
(
"first thread"
)
randDataOp
=
random
.
randint
(
1
,
3
)
dataOp
.
get
(
randDataOp
,
lambda
:
"ERROR"
)()
self
.
threadLock
.
release
()
ret1
=
dataOp
.
get
(
randDataOp
,
lambda
:
"ERROR"
)()
if
ret1
==
-
1
:
self
.
q
.
put
(
-
1
)
tdLog
.
exit
(
"first thread failed"
)
else
:
self
.
q
.
put
(
1
)
if
(
self
.
q
.
get
()
!=
-
2
):
self
.
threadLock
.
release
()
else
:
self
.
q
.
put
(
-
1
)
tdLog
.
exit
(
"second thread failed, first thread exit too"
)
elif
(
self
.
threadId
==
2
):
while
True
:
tdLog
.
notice
(
"second thread"
)
self
.
threadLock
.
acquire
()
randDbOp
=
random
.
randint
(
1
,
9
)
dbOp
.
get
(
randDbOp
,
lambda
:
"ERROR"
)()
self
.
threadLock
.
release
()
tdLog
.
notice
(
"second thread"
)
randDbOp
=
random
.
randint
(
1
,
11
)
ret2
=
dbOp
.
get
(
randDbOp
,
lambda
:
"ERROR"
)()
if
ret2
==
-
1
:
self
.
q
.
put
(
-
2
)
tdLog
.
exit
(
"second thread failed"
)
else
:
self
.
q
.
put
(
2
)
if
(
self
.
q
.
get
()
!=
-
1
):
self
.
threadLock
.
release
()
else
:
self
.
q
.
put
(
-
2
)
tdLog
.
exit
(
"first thread failed, second exit too"
)
class
TDTestCase
:
...
...
@@ -273,14 +359,19 @@ class TDTestCase:
def
run
(
self
):
tdSql
.
prepare
()
test1
=
Test
(
1
,
"data operation"
)
test2
=
Test
(
2
,
"db operation"
)
q
=
queue
.
Queue
()
test1
=
Test
(
1
,
"data operation"
,
q
)
test2
=
Test
(
2
,
"db operation"
,
q
)
test1
.
start
()
test2
.
start
()
test1
.
join
()
test2
.
join
()
while
not
q
.
empty
():
if
(
q
.
get
()
!=
0
):
tdLog
.
exit
(
"failed to end of test"
)
tdLog
.
info
(
"end of test"
)
def
stop
(
self
):
...
...
tests/pytest/random-test/random-test.py
浏览文件 @
9e47c5e8
...
...
@@ -25,6 +25,7 @@ class Test:
self
.
last_tb
=
""
self
.
last_stb
=
""
self
.
written
=
0
self
.
colAdded
=
False
def
create_table
(
self
):
tdLog
.
info
(
"create_table"
)
...
...
@@ -39,6 +40,7 @@ class Test:
current_tb
)
self
.
last_tb
=
current_tb
self
.
written
=
0
self
.
colAdded
=
False
def
insert_data
(
self
):
tdLog
.
info
(
"insert_data"
)
...
...
@@ -50,28 +52,52 @@ class Test:
insertRows
=
10
tdLog
.
info
(
"insert %d rows to %s"
%
(
insertRows
,
self
.
last_tb
))
for
i
in
range
(
0
,
insertRows
):
ret
=
tdSql
.
execute
(
'insert into %s values (now + %dm, %d, "%s")'
%
(
self
.
last_tb
,
i
,
i
,
"->"
+
str
(
i
)))
if
self
.
colAdded
:
ret
=
tdSql
.
execute
(
'insert into %s values (now + %dm, %d, "%s", "%s")'
%
(
self
.
last_tb
,
i
,
i
,
"->"
+
str
(
i
)),
"col"
)
else
:
ret
=
tdSql
.
execute
(
'insert into %s values (now + %dm, %d, "%s")'
%
(
self
.
last_tb
,
i
,
i
,
"->"
+
str
(
i
)))
self
.
written
=
self
.
written
+
1
tdLog
.
info
(
"insert earlier data"
)
tdSql
.
execute
(
'insert into %s values (now - 5m , 10, " - 5m")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 6m , 10, " - 6m")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 7m , 10, " - 7m")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 8m , 10, " - 8m")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
if
self
.
colAdded
:
tdSql
.
execute
(
'insert into %s values (now - 5m , 10, " - 5m", "col")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 6m , 10, " - 6m", "col")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 7m , 10, " - 7m", "col")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 8m , 10, " - 8m", "col")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
else
:
tdSql
.
execute
(
'insert into %s values (now - 5m , 10, " - 5m")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 6m , 10, " - 6m")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 7m , 10, " - 7m")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
tdSql
.
execute
(
'insert into %s values (now - 8m , 10, " - 8m")'
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
def
query_data
(
self
):
tdLog
.
info
(
"query_data"
)
...
...
@@ -88,21 +114,48 @@ class Test:
return
else
:
tdLog
.
info
(
"will create stable %s"
%
current_stb
)
db
=
"db"
tdSql
.
execute
(
"drop database if exists %s"
%
(
db
))
tdSql
.
execute
(
"reset query cache"
)
tdSql
.
execute
(
"create database %s maxrows 200 maxtables 30"
%
(
db
))
tdSql
.
execute
(
"use %s"
%
(
db
))
tdSql
.
execute
(
'create table %s(ts timestamp, c1 int, c2 nchar(10)) tags (t1 int, t2 nchar(10))'
%
current_stb
)
self
.
last_stb
=
current_stb
self
.
colAdded
=
False
for
k
in
range
(
1
,
300
):
current_tb
=
"tb%d"
%
int
(
round
(
time
.
time
()
*
1000
))
sqlcmd
=
"create table %s using %s tags (1, 'test')"
%
(
current_tb
,
self
.
last_stb
)
tdSql
.
execute
(
sqlcmd
)
self
.
last_tb
=
current_tb
self
.
written
=
0
for
j
in
range
(
1
,
100
):
tdSql
.
execute
(
"insert into %s values (now + %da, 27, 'wsnchar')"
%
(
self
.
last_tb
,
j
))
self
.
written
=
self
.
written
+
1
def
alter_table_to_add_col
(
self
):
tdLog
.
info
(
"alter_table_to_add_col"
)
if
self
.
last_stb
!=
""
and
not
self
.
colAdded
:
tdSql
.
execute
(
"alter table %s add column col binary(20)"
%
self
.
last_stb
)
self
.
colAdded
=
True
current_tb
=
"tb%d"
%
int
(
round
(
time
.
time
()
*
1000
))
sqlcmd
=
"create table %s using %s tags (1, 'test')"
%
(
current_tb
,
self
.
last_stb
)
tdSql
.
execute
(
sqlcmd
)
self
.
last_tb
=
current_tb
self
.
written
=
0
def
alter_table_to_drop_col
(
self
):
tdLog
.
info
(
"alter_table_to_drop_col"
)
tdSql
.
execute
(
"insert into %s values (now, 27, 'wsnchar')"
%
self
.
last_tb
)
self
.
written
=
self
.
written
+
1
if
self
.
last_stb
!=
""
and
self
.
colAdded
:
tdSql
.
execute
(
"alter table %s drop column col"
%
self
.
last_stb
)
self
.
colAdded
=
False
def
drop_stable
(
self
):
tdLog
.
info
(
"drop_stable"
)
...
...
@@ -126,16 +179,16 @@ class Test:
tdSql
.
execute
(
'select * from %s'
%
self
.
last_stb
)
def
restart_database
(
self
):
tdLog
.
info
(
"restart_databae"
)
tdLog
.
info
(
"restart_databa
s
e"
)
tdDnodes
.
stop
(
1
)
tdDnodes
.
start
(
1
)
tdLog
.
sleep
(
5
)
tdLog
.
sleep
(
10
)
def
force_restart_database
(
self
):
tdLog
.
info
(
"force_restart_database"
)
tdDnodes
.
forcestop
(
1
)
tdDnodes
.
start
(
1
)
tdLog
.
sleep
(
5
)
tdLog
.
sleep
(
10
)
tdSql
.
prepare
()
self
.
last_tb
=
""
self
.
last_stb
=
""
...
...
@@ -161,7 +214,7 @@ class Test:
self
.
last_tb
=
""
self
.
written
=
0
tdDnodes
.
start
(
1
)
tdLog
.
sleep
(
5
)
tdLog
.
sleep
(
10
)
tdSql
.
prepare
()
self
.
last_tb
=
""
self
.
last_stb
=
""
...
...
@@ -209,10 +262,12 @@ class TDTestCase:
10
:
test
.
delete_datafiles
,
11
:
test
.
query_data_from_stable
,
12
:
test
.
drop_stable
,
13
:
test
.
alter_table_to_add_col
,
14
:
test
.
alter_table_to_drop_col
,
}
for
x
in
range
(
1
,
1000
):
r
=
random
.
randint
(
1
,
1
2
)
r
=
random
.
randint
(
1
,
1
4
)
tdLog
.
notice
(
"iteration %d run func %d"
%
(
x
,
r
))
switch
.
get
(
r
,
lambda
:
"ERROR"
)()
...
...
tests/pytest/stable/query_after_reset.py
浏览文件 @
9e47c5e8
...
...
@@ -126,7 +126,7 @@ class Test:
def
delete_datafiles
(
self
):
tdLog
.
info
(
"delete data files"
)
dnodesDir
=
tdDnodes
.
getDnodesRootDir
()
dataDir
=
dnodesDir
+
'/dnode1/*'
dataDir
=
dnodesDir
+
'/dnode1/
data/
*'
deleteCmd
=
'rm -rf %s'
%
dataDir
os
.
system
(
deleteCmd
)
...
...
tests/pytest/util/sql.py
浏览文件 @
9e47c5e8
...
...
@@ -41,16 +41,12 @@ class TDSql:
def
prepare
(
self
):
tdLog
.
info
(
"prepare database:db"
)
s
=
'reset query cache'
print
(
s
)
self
.
cursor
.
execute
(
s
)
s
=
'drop database if exists db'
print
(
s
)
self
.
cursor
.
execute
(
s
)
s
=
'create database db'
print
(
s
)
self
.
cursor
.
execute
(
s
)
s
=
'use db'
print
(
s
)
self
.
cursor
.
execute
(
s
)
def
error
(
self
,
sql
):
...
...
@@ -74,7 +70,6 @@ class TDSql:
def
query
(
self
,
sql
):
self
.
sql
=
sql
print
(
sql
)
self
.
cursor
.
execute
(
sql
)
self
.
queryResult
=
self
.
cursor
.
fetchall
()
self
.
queryRows
=
len
(
self
.
queryResult
)
...
...
@@ -191,7 +186,6 @@ class TDSql:
def
execute
(
self
,
sql
):
self
.
sql
=
sql
print
(
sql
)
self
.
affectedRows
=
self
.
cursor
.
execute
(
sql
)
return
self
.
affectedRows
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录