basic1.sim 8.4 KB
Newer Older
P
plum-lihui 已提交
1
#### test scenario, please refer to https://jira.taosdata.com:18090/pages/viewpage.action?pageId=135120406
P
plum-lihui 已提交
2 3 4 5
# vgroups=1, one topic for one consumer, include: columns from stb/ctb/ntb, * from stb/ctb/ntb, Scalar function from stb/ctb/ntb
# vgroups=1, multi topics for one consumer, include: columns from stb/ctb/ntb, * from stb/ctb/ntb, Scalar function from stb/ctb/ntb
# vgroups=4, one topic for one consumer, include: columns from stb/ctb/ntb, * from stb/ctb/ntb, Scalar function from stb/ctb/ntb
# vgroups=4, multi topics for one consumer, include: columns from stb/ctb/ntb, * from stb/ctb/ntb, Scalar function from stb/ctb/ntb
P
plum-lihui 已提交
6
# notes1: Scalar function: ABS/ACOS/ASIN/ATAN/CEIL/COS/FLOOR/LOG/POW/ROUND/SIN/SQRT/TAN
P
plum-lihui 已提交
7 8
# 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;
#
P
plum-lihui 已提交
9
# notes2: not support aggregate functions(such as sum/count/min/max) and time-windows(interval).
P
plum-lihui 已提交
10
#
P
plum-lihui 已提交
11

P
plum-lihui 已提交
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
run tsim/tmq/prepareBasicEnv.sim

#---- global parameters start ----#
$dbName    = db
$vgroups    = 1
$stbPrefix  = stb
$ctbPrefix  = ctb
$ntbPrefix  = ntb
$stbNum     = 1
$ctbNum     = 10
$ntbNum     = 10
$rowsPerCtb = 100
$tstart     = 1640966400000  # 2022-01-01 00:00:00.000
#---- global parameters end ----#

$pullDelay    = 3
$ifcheckdata  = 1
$showMsg      = 1
$showRow      = 0
P
plum-lihui 已提交
31 32

sql connect
P
plum-lihui 已提交
33
sql use $dbName
P
plum-lihui 已提交
34

P
plum-lihui 已提交
35 36 37 38
print == create topics from super table
sql create topic topic_stb_column as select ts, c3 from stb
sql create topic topic_stb_all as select ts, c1, c2, c3 from stb
sql create topic topic_stb_function as select ts, abs(c1), sin(c2) from stb
P
plum-lihui 已提交
39

P
plum-lihui 已提交
40 41 42 43
print == create topics from child table
sql create topic topic_ctb_column as select ts, c3 from ctb0
sql create topic topic_ctb_all as select * from ctb0
sql create topic topic_ctb_function as select ts, abs(c1), sin(c2) from ctb0
P
plum-lihui 已提交
44

P
plum-lihui 已提交
45 46 47 48
print == create topics from normal table
sql create topic topic_ntb_column as select ts, c3 from ntb0
sql create topic topic_ntb_all as select * from ntb0
sql create topic topic_ntb_function as select ts, abs(c1), sin(c2) from ntb0
P
plum-lihui 已提交
49

P
plum-lihui 已提交
50 51 52 53
#sql show topics
#if $rows != 9 then 
#  return -1
#endi
P
plum-lihui 已提交
54

P
plum-lihui 已提交
55 56
$keyList = ' . group.id:cgrp1
$keyList = $keyList . '
P
plum-lihui 已提交
57

P
plum-lihui 已提交
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
print ================ test consume from stb
$loop_cnt = 0
loop_consume_diff_topic_from_stb:
if $loop_cnt == 0 then
  print == scenario 1: topic_stb_column
  $topicList = ' . topic_stb_column
  $topicList = $topicList . '
elif $loop_cnt == 1 then
  print == scenario 2: topic_stb_all
  $topicList = ' . topic_stb_all
  $topicList = $topicList . '
elif $loop_cnt == 2 then
  print == scenario 3: topic_stb_function
  $topicList = ' . topic_stb_function
  $topicList = $topicList . '
else
  goto loop_consume_diff_topic_from_stb_end
endi
P
plum-lihui 已提交
76

P
plum-lihui 已提交
77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
$consumerId    = 0
$totalMsgOfStb = $ctbNum * $rowsPerCtb
#$expectmsgcnt  = $totalMsgOfStb + 1
$expectmsgcnt  = 110
sql insert into consumeinfo values (now , $consumerId , $topicList , $keyList , $expectmsgcnt , $ifcheckdata )

print == start consumer to pull msgs from stb
print == tsim/tmq/consume.sh -d $dbName -y $pullDelay -g $showMsg -r $showRow -w $dbName -s start
system tsim/tmq/consume.sh -d $dbName -y $pullDelay -g $showMsg -r $showRow -w $dbName -s start

print == check consume result
wait_consumer_end_from_stb:
sql select * from consumeresult
print ==> rows: $rows 
print ==> rows[0]: $data[0][0] $data[0][1] $data[0][2] $data[0][3] $data[0][4] $data[0][5] $data[0][6]
if $rows != 1 then
  sleep 1000
  goto wait_consumer_end_from_stb
endi
if $data[0][1] != $consumerId then
  return -1
endi
if $data[0][2] != $expectmsgcnt then
P
plum-lihui 已提交
100 101
  return -1
endi
P
plum-lihui 已提交
102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
if $data[0][3] != $expectmsgcnt then
  return -1
endi
$loop_cnt = $loop_cnt + 1
goto loop_consume_diff_topic_from_stb
loop_consume_diff_topic_from_stb_end:

#######################################################################################
# clear consume info and consume result 
#run tsim/tmq/clearConsume.sim
# because drop table function no stable, so by create new db for consume info and result. Modify it later
$cdbName = cdb1
sql create database $cdbName vgroups 1
sleep 500
sql use $cdbName

print == create consume info table and consume result table
sql create table consumeinfo (ts timestamp, consumerid int, topiclist binary(1024), keylist binary(1024), expectmsgcnt bigint, ifcheckdata int)
sql create table consumeresult (ts timestamp, consumerid int, consummsgcnt bigint, consumrowcnt bigint, checkresult int)
P
plum-lihui 已提交
121

P
plum-lihui 已提交
122 123
sql show tables
if $rows != 2 then 
P
plum-lihui 已提交
124 125
  return -1
endi
P
plum-lihui 已提交
126
#######################################################################################
P
plum-lihui 已提交
127 128


P
plum-lihui 已提交
129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145
print ================ test consume from ctb
$loop_cnt = 0
loop_consume_diff_topic_from_ctb:
if $loop_cnt == 0 then
  print == scenario 1: topic_ctb_column
  $topicList = ' . topic_ctb_column
  $topicList = $topicList . '
elif $loop_cnt == 1 then
  print == scenario 2: topic_ctb_all
  $topicList = ' . topic_ctb_all
  $topicList = $topicList . '
elif $loop_cnt == 2 then
  print == scenario 3: topic_ctb_function
  $topicList = ' . topic_ctb_function
  $topicList = $topicList . '
else
  goto loop_consume_diff_topic_from_ctb_end
P
plum-lihui 已提交
146 147
endi

P
plum-lihui 已提交
148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166
$consumerId    = 0
$totalMsgOfCtb = $rowsPerCtb
$expectmsgcnt  = $totalMsgOfCtb + 1
sql insert into consumeinfo values (now , $consumerId , $topicList , $keyList , $expectmsgcnt , $ifcheckdata )

print == start consumer to pull msgs from stb
print == tsim/tmq/consume.sh -d $dbName -y $pullDelay -g $showMsg -r $showRow -s start
system tsim/tmq/consume.sh -d $dbName -y $pullDelay -g $showMsg -r $showRow -w $cdbName -s start

print == check consume result
wait_consumer_end_from_ctb:
sql select * from consumeresult
print ==> rows: $rows 
print ==> rows[0]: $data[0][0] $data[0][1] $data[0][2] $data[0][3] $data[0][4] $data[0][5] $data[0][6]
if $rows != 1 then
  sleep 1000
  goto wait_consumer_end_from_ctb
endi
if $data[0][1] != $consumerId then
P
plum-lihui 已提交
167 168
  return -1
endi
P
plum-lihui 已提交
169
if $data[0][2] != $totalMsgOfCtb then
L
Liu Jicong 已提交
170 171
  return -1
endi
P
plum-lihui 已提交
172
if $data[0][3] != $totalMsgOfCtb then
P
plum-lihui 已提交
173 174
  return -1
endi
P
plum-lihui 已提交
175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190
$loop_cnt = $loop_cnt + 1
goto loop_consume_diff_topic_from_ctb
loop_consume_diff_topic_from_ctb_end:

#######################################################################################
# clear consume info and consume result 
#run tsim/tmq/clearConsume.sim
# because drop table function no stable, so by create new db for consume info and result. Modify it later
$cdbName = cdb2
sql create database $cdbName vgroups 1
sleep 500
sql use $cdbName

print == create consume info table and consume result table
sql create table consumeinfo (ts timestamp, consumerid int, topiclist binary(1024), keylist binary(1024), expectmsgcnt bigint, ifcheckdata int)
sql create table consumeresult (ts timestamp, consumerid int, consummsgcnt bigint, consumrowcnt bigint, checkresult int)
P
plum-lihui 已提交
191

P
plum-lihui 已提交
192 193
sql show tables
if $rows != 2 then 
P
plum-lihui 已提交
194 195
  return -1
endi
P
plum-lihui 已提交
196
#######################################################################################
P
plum-lihui 已提交
197

P
plum-lihui 已提交
198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215

print ================ test consume from ntb
$loop_cnt = 0
loop_consume_diff_topic_from_ntb:
if $loop_cnt == 0 then
  print == scenario 1: topic_ntb_column
  $topicList = ' . topic_ntb_column
  $topicList = $topicList . '
elif $loop_cnt == 1 then
  print == scenario 2: topic_ntb_all
  $topicList = ' . topic_ntb_all
  $topicList = $topicList . '
elif $loop_cnt == 2 then
  print == scenario 3: topic_ntb_function
  $topicList = ' . topic_ntb_function
  $topicList = $topicList . '
else
  goto loop_consume_diff_topic_from_ntb_end
L
Liu Jicong 已提交
216
endi
P
plum-lihui 已提交
217

P
plum-lihui 已提交
218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236
$consumerId    = 0
$totalMsgOfNtb = $rowsPerCtb
$expectmsgcnt  = $totalMsgOfNtb + 1
sql insert into consumeinfo values (now , $consumerId , $topicList , $keyList , $expectmsgcnt , $ifcheckdata )

print == start consumer to pull msgs from stb
print == tsim/tmq/consume.sh -d $dbName -y $pullDelay -g $showMsg -r $showRow -s start
system tsim/tmq/consume.sh -d $dbName -y $pullDelay -g $showMsg -r $showRow -w $cdbName -s start

print == check consume result from ntb
wait_consumer_end_from_ntb:
sql select * from consumeresult
print ==> rows: $rows 
print ==> rows[0]: $data[0][0] $data[0][1] $data[0][2] $data[0][3] $data[0][4] $data[0][5] $data[0][6]
if $rows != 1 then
  sleep 1000
  goto wait_consumer_end_from_ntb
endi
if $data[0][1] != $consumerId then
P
plum-lihui 已提交
237 238
  return -1
endi
P
plum-lihui 已提交
239 240 241 242 243 244 245 246 247
if $data[0][2] != $totalMsgOfNtb then
  return -1
endi
if $data[0][3] != $totalMsgOfNtb then
  return -1
endi
$loop_cnt = $loop_cnt + 1
goto loop_consume_diff_topic_from_ntb
loop_consume_diff_topic_from_ntb_end:
P
plum-lihui 已提交
248

P
plum-lihui 已提交
249 250
#------ not need stop consumer, because it exit after pull msg overthan expect msg
#system tsim/tmq/consume.sh -s stop -x SIGINT
P
plum-lihui 已提交
251

252
system sh/exec.sh -n dnode1 -s stop -x SIGINT