229 lines
7.5 KiB
Plaintext
229 lines
7.5 KiB
Plaintext
#### test scenario, please refer to https://jira.taosdata.com:18090/pages/viewpage.action?pageId=135120406
|
|
# scene1: vgroups=1, one topic for one consumer, include: columns from stb/ctb/ntb, * from stb/ctb/ntb, Scalar function from stb/ctb/ntb
|
|
# scene2: vgroups=1, multi topics for one consumer, include: columns from stb/ctb/ntb, * from stb/ctb/ntb, Scalar function from stb/ctb/ntb
|
|
# scene3: vgroups=4, one topic for one consumer, include: columns from stb/ctb/ntb, * from stb/ctb/ntb, Scalar function from stb/ctb/ntb
|
|
# scene4: vgroups=4, multi topics for one consumer, include: columns from stb/ctb/ntb, * from stb/ctb/ntb, Scalar function from stb/ctb/ntb
|
|
# notes1: Scalar function: ABS/ACOS/ASIN/ATAN/CEIL/COS/FLOOR/LOG/POW/ROUND/SIN/SQRT/TAN
|
|
# The above use cases are combined with where filter conditions, such as: where ts > "2017-08-12 18:25:58.128Z" and sin(a) > 0.5;
|
|
#
|
|
# notes2: not support aggregate functions(such as sum/count/min/max) and time-windows(interval).
|
|
#
|
|
######## ######## ######## ######## ######## ######## ######## ######## ######## ########
|
|
######## This test case include scene2 and scene4
|
|
######## ######## ######## ######## ######## ######## ######## ######## ######## ########
|
|
|
|
system sh/stop_dnodes.sh
|
|
system sh/deploy.sh -n dnode1 -i 1
|
|
system sh/exec.sh -n dnode1 -s start
|
|
|
|
$loop_cnt = 0
|
|
check_dnode_ready:
|
|
$loop_cnt = $loop_cnt + 1
|
|
sleep 200
|
|
if $loop_cnt == 10 then
|
|
print ====> dnode not ready!
|
|
return -1
|
|
endi
|
|
sql show dnodes
|
|
print ===> $rows $data00 $data01 $data02 $data03 $data04 $data05
|
|
if $data00 != 1 then
|
|
return -1
|
|
endi
|
|
if $data04 != ready then
|
|
goto check_dnode_ready
|
|
endi
|
|
|
|
sql connect
|
|
|
|
$loop_cnt = 0
|
|
$vgroups = 1
|
|
$dbNamme = d0
|
|
loop_vgroups:
|
|
print =============== create database $dbNamme vgroups $vgroups
|
|
sql create database $dbNamme vgroups $vgroups
|
|
sql show databases
|
|
print $data00 $data01 $data02 $data03 $data04 $data05 $data06 $data07 $data08 $data09
|
|
print $data10 $data11 $data12 $data13 $data14 $data15 $data16 $data17 $data18 $data19
|
|
print $data20 $data21 $data22 $data23 $data24 $data25 $data26 $data27 $data28 $data29
|
|
|
|
if $loop_cnt == 0 then
|
|
if $rows != 3 then
|
|
return -1
|
|
endi
|
|
if $data22 != 1 then # vgroups
|
|
print vgroups: $data02
|
|
return -1
|
|
endi
|
|
else
|
|
if $rows != 4 then
|
|
return -1
|
|
endi
|
|
if $data20 == d1 then
|
|
if $data22 != 4 then # vgroups
|
|
print vgroups: $data02
|
|
return -1
|
|
endi
|
|
else
|
|
if $data32 != 4 then # vgroups
|
|
print vgroups: $data12
|
|
return -1
|
|
endi
|
|
endi
|
|
endi
|
|
|
|
sql use $dbNamme
|
|
|
|
print =============== create super table
|
|
sql create table if not exists stb (ts timestamp, c1 int, c2 float, c3 binary(10)) tags (t1 int)
|
|
|
|
sql show stables
|
|
if $rows != 1 then
|
|
return -1
|
|
endi
|
|
|
|
print =============== create child table
|
|
$tbPrefix = ct
|
|
$tbNum = 100
|
|
|
|
$i = 0
|
|
while $i < $tbNum
|
|
$tb = $tbPrefix . $i
|
|
sql create table $tb using stb tags( $i )
|
|
$i = $i + 1
|
|
endw
|
|
|
|
print =============== create normal table
|
|
sql create table ntb (ts timestamp, c1 int, c2 float, c3 binary(10))
|
|
|
|
print =============== create multi topics. notes: now only support:
|
|
print =============== 1. columns from stb/ctb/ntb; 2. * from ctb/ntb; 3. function from stb/ctb/ntb
|
|
print =============== will support: * from stb
|
|
|
|
sql create topic topic_stb_column as select ts, c1, c3 from stb
|
|
#sql create topic topic_stb_all as select * from stb
|
|
sql create topic topic_stb_function as select ts, abs(c1), sin(c2) from stb
|
|
|
|
sql create topic topic_ctb_column as select ts, c1, c3 from ct0
|
|
sql create topic topic_ctb_all as select * from ct0
|
|
sql create topic topic_ctb_function as select ts, abs(c1), sin(c2) from ct0
|
|
|
|
sql create topic topic_ntb_column as select ts, c1, c3 from ntb
|
|
sql create topic topic_ntb_all as select * from ntb
|
|
sql create topic topic_ntb_function as select ts, abs(c1), sin(c2) from ntb
|
|
|
|
sql show tables
|
|
if $rows != 101 then
|
|
return -1
|
|
endi
|
|
|
|
print =============== insert data
|
|
$rowNum = 100
|
|
$tstart = 1640966400000 # 2022-01-01 00:00:00.000
|
|
|
|
$i = 0
|
|
while $i < $tbNum
|
|
$tb = $tbPrefix . $i
|
|
|
|
$x = 0
|
|
while $x < $rowNum
|
|
$c = $x / 10
|
|
$c = $c * 10
|
|
$c = $x - $c
|
|
|
|
$binary = ' . binary
|
|
$binary = $binary . $c
|
|
$binary = $binary . '
|
|
|
|
sql insert into $tb values ($tstart , $c , $x , $binary )
|
|
sql insert into ntb values ($tstart , $c , $x , $binary )
|
|
$tstart = $tstart + 1
|
|
$x = $x + 1
|
|
endw
|
|
|
|
$i = $i + 1
|
|
$tstart = 1640966400000
|
|
endw
|
|
|
|
#root@trd02 /home $ tmq_sim --help
|
|
# -c Configuration directory, default is
|
|
# -d The name of the database for cosumer, no default
|
|
# -t The topic string for cosumer, no default
|
|
# -k The key-value string for cosumer, no default
|
|
# -g showMsgFlag, default is 0
|
|
#
|
|
|
|
$totalMsgCnt = $rowNum * $tbNum
|
|
print inserted totalMsgCnt: $totalMsgCnt
|
|
|
|
# supported key:
|
|
# group.id:<xxx>
|
|
# enable.auto.commit:<true | false>
|
|
# auto.offset.reset:<earliest | latest | none>
|
|
# td.connect.ip:<fqdn | ipaddress>
|
|
# td.connect.user:root
|
|
# td.connect.pass:taosdata
|
|
# td.connect.port:6030
|
|
# td.connect.db:db
|
|
|
|
$numOfTopics = 2
|
|
$totalMsgCntOfmultiTopics = $totalMsgCnt * $numOfTopics
|
|
$expect_result = @{consume success: @
|
|
$expect_result = $expect_result . $totalMsgCntOfmultiTopics
|
|
$expect_result = $expect_result . @, @
|
|
$expect_result = $expect_result . 0}
|
|
print expect_result----> $expect_result
|
|
|
|
system_content echo -n \$BUILD_DIR
|
|
$tmq_sim = $system_content . /build/bin/tmq_sim
|
|
$tsim_cfg = $system_content . /tsim/cfg
|
|
|
|
#print cmd===> system_content $tmq_sim -c $tsim_cfg -d $dbNamme -t "topic_stb_column, topic_stb_function, topic_stb_all" -k "group.id:tg2"
|
|
#system_content $tmq_sim -c $tsim_cfg -d $dbNamme -t "topic_stb_column, topic_stb_function, topic_stb_all" -k "group.id:tg2"
|
|
print cmd===> system_content $tmq_sim -c $tsim_cfg -d $dbNamme -t "topic_stb_column, topic_stb_function" -k "group.id:tg2"
|
|
system_content $tmq_sim -c $tsim_cfg -d $dbNamme -t "topic_stb_column, topic_stb_function" -k "group.id:tg2"
|
|
print cmd result----> $system_content
|
|
#if $system_content != @{consume success: 20000, 0}@ then
|
|
if $system_content != $expect_result then
|
|
return -1
|
|
endi
|
|
|
|
$numOfTopics = 3
|
|
$totalMsgCntOfmultiTopics = $rowNum * $numOfTopics
|
|
$expect_result = @{consume success: @
|
|
$expect_result = $expect_result . $totalMsgCntOfmultiTopics
|
|
$expect_result = $expect_result . @, @
|
|
$expect_result = $expect_result . 0}
|
|
print expect_result----> $expect_result
|
|
print cmd===> system_content $tmq_sim -c $tsim_cfg -d $dbNamme -t "topic_ctb_column, topic_ctb_function, topic_ctb_all" -k "group.id:tg2"
|
|
system_content $tmq_sim -c $tsim_cfg -d $dbNamme -t "topic_ctb_column, topic_ctb_function, topic_ctb_all" -k "group.id:tg2"
|
|
print cmd result----> $system_content
|
|
#if $system_content != @{consume success: 300, 0}@ then
|
|
if $system_content != $expect_result then
|
|
return -1
|
|
endi
|
|
|
|
$numOfTopics = 3
|
|
$totalMsgCntOfmultiTopics = $totalMsgCnt * $numOfTopics
|
|
$expect_result = @{consume success: @
|
|
$expect_result = $expect_result . $totalMsgCntOfmultiTopics
|
|
$expect_result = $expect_result . @, @
|
|
$expect_result = $expect_result . 0}
|
|
print expect_result----> $expect_result
|
|
print cmd===> system_content $tmq_sim -c $tsim_cfg -d $dbNamme -t "topic_ntb_column, topic_ntb_all, topic_ntb_function" -k "group.id:tg2"
|
|
system_content $tmq_sim -c $tsim_cfg -d $dbNamme -t "topic_ntb_column, topic_ntb_all, topic_ntb_function" -k "group.id:tg2"
|
|
print cmd result----> $system_content
|
|
#if $system_content != @{consume success: 30000, 0}@ then
|
|
if $system_content != $expect_result then
|
|
return -1
|
|
endi
|
|
|
|
if $loop_cnt == 0 then
|
|
$loop_cnt = 1
|
|
$vgroups = 4
|
|
$dbNamme = d1
|
|
goto loop_vgroups
|
|
endi
|
|
|
|
|
|
system sh/exec.sh -n dnode1 -s stop -x SIGINT
|