tmqConsFromTsdb.py 11.3 KB
Newer Older
P
plum-lihui 已提交
1 2 3 4 5 6 7

import taos
import sys
import time
import socket
import os
import threading
P
plum-lihui 已提交
8
import math
P
plum-lihui 已提交
9 10 11 12 13 14 15 16 17 18

from util.log import *
from util.sql import *
from util.cases import *
from util.dnodes import *
from util.common import *
sys.path.append("./7-tmq")
from tmqCommon import *

class TDTestCase:
P
plum-lihui 已提交
19
    def __init__(self):
P
plum-lihui 已提交
20 21 22 23
        self.vgroups    = 1
        self.ctbNum     = 10
        self.rowsPerTbl = 10000
        
P
plum-lihui 已提交
24 25 26 27
    def init(self, conn, logSql):
        tdLog.debug(f"start to excute {__file__}")
        tdSql.init(conn.cursor(), False)

P
plum-lihui 已提交
28
    def prepareTestEnv(self):
P
plum-lihui 已提交
29
        tdLog.printNoPrefix("======== test case 1: ")
P
plum-lihui 已提交
30
        paraDict = {'dbName':     'dbt',
P
plum-lihui 已提交
31 32
                    'dropFlag':   1,
                    'event':      '',
P
plum-lihui 已提交
33
                    'vgroups':    1,
P
plum-lihui 已提交
34 35 36
                    'stbName':    'stb',
                    'colPrefix':  'c',
                    'tagPrefix':  't',
P
plum-lihui 已提交
37 38
                    'colSchema':   [{'type': 'INT', 'count':1},{'type': 'BIGINT', 'count':1},{'type': 'DOUBLE', 'count':1},{'type': 'BINARY', 'len':32, 'count':1},{'type': 'NCHAR', 'len':32, 'count':1},{'type': 'TIMESTAMP', 'count':1}],
                    'tagSchema':   [{'type': 'INT', 'count':1},{'type': 'BIGINT', 'count':1},{'type': 'DOUBLE', 'count':1},{'type': 'BINARY', 'len':32, 'count':1},{'type': 'NCHAR', 'len':32, 'count':1}],
P
plum-lihui 已提交
39
                    'ctbPrefix':  'ctb',
P
plum-lihui 已提交
40 41
                    'ctbStartIdx': 0,
                    'ctbNum':     10,
P
plum-lihui 已提交
42 43 44
                    'rowsPerTbl': 10000,
                    'batchNum':   10,
                    'startTs':    1640966400000,  # 2022-01-01 00:00:00.000
P
plum-lihui 已提交
45
                    'pollDelay':  3,
P
plum-lihui 已提交
46 47 48 49
                    'showMsg':    1,
                    'showRow':    1,
                    'snapshot':   1}

P
plum-lihui 已提交
50 51 52 53
        paraDict['vgroups'] = self.vgroups
        paraDict['ctbNum'] = self.ctbNum
        paraDict['rowsPerTbl'] = self.rowsPerTbl
        
P
plum-lihui 已提交
54
        tmqCom.initConsumerTable()
P
plum-lihui 已提交
55
        tdCom.create_database(tdSql, paraDict["dbName"],paraDict["dropFlag"], vgroups=paraDict["vgroups"],replica=1)
P
plum-lihui 已提交
56
        tdLog.info("create stb")
P
plum-lihui 已提交
57
        tmqCom.create_stable(tdSql, dbName=paraDict["dbName"],stbName=paraDict["stbName"])
P
plum-lihui 已提交
58
        tdLog.info("create ctb")
P
plum-lihui 已提交
59 60
        tmqCom.create_ctable(tdSql, dbName=paraDict["dbName"],stbName=paraDict["stbName"],ctbPrefix=paraDict['ctbPrefix'],
                             ctbNum=paraDict["ctbNum"],ctbStartIdx=paraDict['ctbStartIdx'])
P
plum-lihui 已提交
61
        tdLog.info("insert data")
P
plum-lihui 已提交
62 63 64
        tmqCom.insert_data_interlaceByMultiTbl(tsql=tdSql,dbName=paraDict["dbName"],ctbPrefix=paraDict["ctbPrefix"],
                                               ctbNum=paraDict["ctbNum"],rowsPerTbl=paraDict["rowsPerTbl"],batchNum=paraDict["batchNum"],
                                               startTs=paraDict["startTs"],ctbStartIdx=paraDict['ctbStartIdx'])
P
plum-lihui 已提交
65
        
P
plum-lihui 已提交
66
        tdLog.info("restart taosd to ensure that the data falls into the disk")
P
plum-lihui 已提交
67 68
        tdDnodes.stop(1)
        tdDnodes.start(1)
P
plum-lihui 已提交
69
        return
P
plum-lihui 已提交
70

P
plum-lihui 已提交
71 72
    def tmqCase1(self):
        tdLog.printNoPrefix("======== test case 1: ")
P
plum-lihui 已提交
73 74 75 76 77 78 79
        paraDict = {'dbName':     'dbt',
                    'dropFlag':   1,
                    'event':      '',
                    'vgroups':    1,
                    'stbName':    'stb',
                    'colPrefix':  'c',
                    'tagPrefix':  't',
P
plum-lihui 已提交
80 81
                    'colSchema':   [{'type': 'INT', 'count':1},{'type': 'BIGINT', 'count':1},{'type': 'DOUBLE', 'count':1},{'type': 'BINARY', 'len':32, 'count':1},{'type': 'NCHAR', 'len':32, 'count':1},{'type': 'TIMESTAMP', 'count':1}],
                    'tagSchema':   [{'type': 'INT', 'count':1},{'type': 'BIGINT', 'count':1},{'type': 'DOUBLE', 'count':1},{'type': 'BINARY', 'len':32, 'count':1},{'type': 'NCHAR', 'len':32, 'count':1}],
P
plum-lihui 已提交
82
                    'ctbPrefix':  'ctb',
P
plum-lihui 已提交
83 84
                    'ctbStartIdx': 0,
                    'ctbNum':     10,
P
plum-lihui 已提交
85 86 87 88 89 90 91 92
                    'rowsPerTbl': 10000,
                    'batchNum':   10,
                    'startTs':    1640966400000,  # 2022-01-01 00:00:00.000
                    'pollDelay':  3,
                    'showMsg':    1,
                    'showRow':    1,
                    'snapshot':   1}

P
plum-lihui 已提交
93 94 95 96
        paraDict['vgroups'] = self.vgroups
        paraDict['ctbNum'] = self.ctbNum
        paraDict['rowsPerTbl'] = self.rowsPerTbl
        
P
plum-lihui 已提交
97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
        topicNameList = ['topic1']
        expectRowsList = []
        tmqCom.initConsumerTable()
        
        tdLog.info("create topics from stb with filter")
        queryString = "select * from %s.%s"%(paraDict['dbName'], paraDict['stbName'])
        # sqlString = "create topic %s as stable %s" %(topicNameList[0], paraDict['stbName'])
        sqlString = "create topic %s as %s" %(topicNameList[0], queryString)
        tdLog.info("create topic sql: %s"%sqlString)
        tdSql.execute(sqlString)
        tdSql.query(queryString)        
        expectRowsList.append(tdSql.getRows())

        # init consume info, and start tmq_sim, then check consume result
        tdLog.info("insert consume info to consume processor")
P
plum-lihui 已提交
112 113
        consumerId   = 0
        expectrowcnt = paraDict["rowsPerTbl"] * paraDict["ctbNum"]
P
plum-lihui 已提交
114 115 116 117 118 119
        topicList    = topicNameList[0]
        ifcheckdata  = 1
        ifManualCommit = 1
        keyList      = 'group.id:cgrp1, enable.auto.commit:true, auto.commit.interval.ms:1000, auto.offset.reset:earliest'
        tmqCom.insertConsumerInfo(consumerId, expectrowcnt,topicList,keyList,ifcheckdata,ifManualCommit)

P
plum-lihui 已提交
120
        tdLog.info("start consume processor")
P
plum-lihui 已提交
121 122 123 124 125 126
        tmqCom.startTmqSimProcess(pollDelay=paraDict['pollDelay'],dbName=paraDict["dbName"],showMsg=paraDict['showMsg'], showRow=paraDict['showRow'],snapshot=paraDict['snapshot'])
        tdLog.info("wait the consume result") 
        
        expectRows = 1
        resultList = tmqCom.selectConsumeResult(expectRows)
        
P
plum-lihui 已提交
127 128
        if expectRowsList[0] != resultList[0]:
            tdLog.info("expect consume rows: %d, act consume rows: %d"%(expectRowsList[0], resultList[0]))
P
plum-lihui 已提交
129 130
            tdLog.exit("%d tmq consume rows error!"%consumerId)

P
plum-lihui 已提交
131
        tmqCom.checkFileContent(consumerId, queryString)     
P
plum-lihui 已提交
132 133 134 135 136

        time.sleep(10)        
        for i in range(len(topicNameList)):
            tdSql.query("drop topic %s"%topicNameList[i])

P
plum-lihui 已提交
137
        tdLog.printNoPrefix("======== test case 1 end ...... ")
P
plum-lihui 已提交
138

P
plum-lihui 已提交
139 140
    def tmqCase2(self):
        tdLog.printNoPrefix("======== test case 2: ")
P
plum-lihui 已提交
141 142 143 144 145 146 147
        paraDict = {'dbName':     'dbt',
                    'dropFlag':   1,
                    'event':      '',
                    'vgroups':    1,
                    'stbName':    'stb',
                    'colPrefix':  'c',
                    'tagPrefix':  't',
P
plum-lihui 已提交
148 149
                    'colSchema':   [{'type': 'INT', 'count':1},{'type': 'BIGINT', 'count':1},{'type': 'DOUBLE', 'count':1},{'type': 'BINARY', 'len':32, 'count':1},{'type': 'NCHAR', 'len':32, 'count':1},{'type': 'TIMESTAMP', 'count':1}],
                    'tagSchema':   [{'type': 'INT', 'count':1},{'type': 'BIGINT', 'count':1},{'type': 'DOUBLE', 'count':1},{'type': 'BINARY', 'len':32, 'count':1},{'type': 'NCHAR', 'len':32, 'count':1}],
P
plum-lihui 已提交
150
                    'ctbPrefix':  'ctb',
P
plum-lihui 已提交
151 152
                    'ctbStartIdx': 0,
                    'ctbNum':     10,
P
plum-lihui 已提交
153 154 155
                    'rowsPerTbl': 10000,
                    'batchNum':   10,
                    'startTs':    1640966400000,  # 2022-01-01 00:00:00.000
P
plum-lihui 已提交
156
                    'pollDelay':  3,
P
plum-lihui 已提交
157 158 159 160
                    'showMsg':    1,
                    'showRow':    1,
                    'snapshot':   1}

P
plum-lihui 已提交
161 162 163 164
        paraDict['vgroups'] = self.vgroups
        paraDict['ctbNum'] = self.ctbNum
        paraDict['rowsPerTbl'] = self.rowsPerTbl
        
P
plum-lihui 已提交
165 166 167 168 169 170 171 172 173 174 175 176
        topicNameList = ['topic1']
        expectRowsList = []
        tmqCom.initConsumerTable()
        
        tdLog.info("create topics from stb with filter")
        queryString = "select * from %s.%s"%(paraDict['dbName'], paraDict['stbName'])
        # sqlString = "create topic %s as stable %s" %(topicNameList[0], paraDict['stbName'])
        sqlString = "create topic %s as %s" %(topicNameList[0], queryString)
        tdLog.info("create topic sql: %s"%sqlString)
        tdSql.execute(sqlString)
        tdSql.query(queryString)        
        expectRowsList.append(tdSql.getRows())
P
plum-lihui 已提交
177
        totalRowsInserted = expectRowsList[0]
P
plum-lihui 已提交
178 179 180

        # init consume info, and start tmq_sim, then check consume result
        tdLog.info("insert consume info to consume processor")
P
plum-lihui 已提交
181
        consumerId   = 1
P
plum-lihui 已提交
182
        expectrowcnt = math.ceil(paraDict["rowsPerTbl"] * paraDict["ctbNum"] / 3)
P
plum-lihui 已提交
183 184 185 186 187 188
        topicList    = topicNameList[0]
        ifcheckdata  = 1
        ifManualCommit = 1
        keyList      = 'group.id:cgrp1, enable.auto.commit:true, auto.commit.interval.ms:1000, auto.offset.reset:earliest'
        tmqCom.insertConsumerInfo(consumerId, expectrowcnt,topicList,keyList,ifcheckdata,ifManualCommit)

P
plum-lihui 已提交
189
        tdLog.info("start consume processor 0")
P
plum-lihui 已提交
190 191 192
        tmqCom.startTmqSimProcess(pollDelay=paraDict['pollDelay'],dbName=paraDict["dbName"],showMsg=paraDict['showMsg'], showRow=paraDict['showRow'],snapshot=paraDict['snapshot'])
        tdLog.info("wait the consume result") 
        
P
plum-lihui 已提交
193
        expectRows = 1
P
plum-lihui 已提交
194 195
        resultList = tmqCom.selectConsumeResult(expectRows)
        
P
plum-lihui 已提交
196 197
        if not (expectrowcnt <= resultList[0] and totalRowsInserted >= resultList[0]):
            tdLog.info("act consume rows: %d, expect consume rows between %d and %d"%(resultList[0], expectrowcnt, totalRowsInserted))
P
plum-lihui 已提交
198
            tdLog.exit("%d tmq consume rows error!"%consumerId)
P
plum-lihui 已提交
199 200
            
        firstConsumeRows = resultList[0]
P
plum-lihui 已提交
201

P
plum-lihui 已提交
202 203
        # reinit consume info, and start tmq_sim, then check consume result
        tmqCom.initConsumerTable()
P
plum-lihui 已提交
204 205
        consumerId   = 2
        expectrowcnt = math.ceil(paraDict["rowsPerTbl"] * paraDict["ctbNum"] * 2/3)
P
plum-lihui 已提交
206 207 208 209
        tmqCom.insertConsumerInfo(consumerId, expectrowcnt,topicList,keyList,ifcheckdata,ifManualCommit)
        
        tdLog.info("start consume processor 1")
        tmqCom.startTmqSimProcess(pollDelay=paraDict['pollDelay'],dbName=paraDict["dbName"],showMsg=paraDict['showMsg'], showRow=paraDict['showRow'],snapshot=paraDict['snapshot'])
P
plum-lihui 已提交
210
        tdLog.info("wait the consume result") 
P
plum-lihui 已提交
211 212 213 214
        
        expectRows = 1
        resultList = tmqCom.selectConsumeResult(expectRows)
        
P
plum-lihui 已提交
215
        actConsumeTotalRows = firstConsumeRows + resultList[0]
P
plum-lihui 已提交
216
        
P
plum-lihui 已提交
217 218 219
        if not (expectrowcnt >= resultList[0] and totalRowsInserted == actConsumeTotalRows):
            tdLog.info("act consume rows, first: %d, second: %d "%(firstConsumeRows, resultList[0]))            
            tdLog.info("and sum of two consume rows: %d should be equal to total inserted rows: %d"%(actConsumeTotalRows, totalRowsInserted))
P
plum-lihui 已提交
220 221 222 223 224 225
            tdLog.exit("%d tmq consume rows error!"%consumerId)

        time.sleep(10)        
        for i in range(len(topicNameList)):
            tdSql.query("drop topic %s"%topicNameList[i])

P
plum-lihui 已提交
226
        tdLog.printNoPrefix("======== test case 2 end ...... ")
P
plum-lihui 已提交
227

P
plum-lihui 已提交
228 229
    def run(self):
        tdSql.prepare()
P
plum-lihui 已提交
230
        self.prepareTestEnv()
P
plum-lihui 已提交
231
        self.tmqCase1()
P
plum-lihui 已提交
232
        self.tmqCase2()
P
plum-lihui 已提交
233 234 235 236 237 238 239 240 241

    def stop(self):
        tdSql.close()
        tdLog.success(f"{__file__} successfully executed")

event = threading.Event()

tdCases.addLinux(__file__, TDTestCase())
tdCases.addWindows(__file__, TDTestCase())