tmqConsFromTsdb.py 11.2 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
        self.vgroups    = 1
        self.ctbNum     = 10
        self.rowsPerTbl = 10000
G
Ganlin Zhao 已提交
23

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("======== prepare test env include database, stable, ctables, and insert data: ")
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
        paraDict['vgroups'] = self.vgroups
        paraDict['ctbNum'] = self.ctbNum
        paraDict['rowsPerTbl'] = self.rowsPerTbl
G
Ganlin Zhao 已提交
53

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'])
G
Ganlin Zhao 已提交
65

P
plum-lihui 已提交
66
        tdLog.info("restart taosd to ensure that the data falls into the disk")
67 68 69
        # tdDnodes.stop(1)
        # tdDnodes.start(1)
        tdSql.query("flush database %s"%(paraDict['dbName']))
P
plum-lihui 已提交
70
        return
P
plum-lihui 已提交
71

P
plum-lihui 已提交
72 73
    def tmqCase1(self):
        tdLog.printNoPrefix("======== test case 1: ")
P
plum-lihui 已提交
74 75 76 77 78 79 80
        paraDict = {'dbName':     'dbt',
                    'dropFlag':   1,
                    'event':      '',
                    'vgroups':    1,
                    'stbName':    'stb',
                    'colPrefix':  'c',
                    'tagPrefix':  't',
P
plum-lihui 已提交
81 82
                    '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 已提交
83
                    'ctbPrefix':  'ctb',
P
plum-lihui 已提交
84 85
                    'ctbStartIdx': 0,
                    'ctbNum':     10,
P
plum-lihui 已提交
86 87 88 89 90 91 92 93
                    'rowsPerTbl': 10000,
                    'batchNum':   10,
                    'startTs':    1640966400000,  # 2022-01-01 00:00:00.000
                    'pollDelay':  3,
                    'showMsg':    1,
                    'showRow':    1,
                    'snapshot':   1}

P
plum-lihui 已提交
94 95 96
        paraDict['vgroups'] = self.vgroups
        paraDict['ctbNum'] = self.ctbNum
        paraDict['rowsPerTbl'] = self.rowsPerTbl
G
Ganlin Zhao 已提交
97

P
plum-lihui 已提交
98 99 100
        topicNameList = ['topic1']
        expectRowsList = []
        tmqCom.initConsumerTable()
G
Ganlin Zhao 已提交
101

P
plum-lihui 已提交
102 103 104 105 106 107
        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)
G
Ganlin Zhao 已提交
108
        tdSql.query(queryString)
P
plum-lihui 已提交
109 110 111 112
        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 已提交
113 114
        consumerId   = 0
        expectrowcnt = paraDict["rowsPerTbl"] * paraDict["ctbNum"]
P
plum-lihui 已提交
115 116 117 118 119 120
        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 已提交
121
        tdLog.info("start consume processor")
P
plum-lihui 已提交
122
        tmqCom.startTmqSimProcess(pollDelay=paraDict['pollDelay'],dbName=paraDict["dbName"],showMsg=paraDict['showMsg'], showRow=paraDict['showRow'],snapshot=paraDict['snapshot'])
G
Ganlin Zhao 已提交
123 124
        tdLog.info("wait the consume result")

P
plum-lihui 已提交
125 126
        expectRows = 1
        resultList = tmqCom.selectConsumeResult(expectRows)
G
Ganlin Zhao 已提交
127

P
plum-lihui 已提交
128 129
        if expectRowsList[0] != resultList[0]:
            tdLog.info("expect consume rows: %d, act consume rows: %d"%(expectRowsList[0], resultList[0]))
P
plum-lihui 已提交
130 131
            tdLog.exit("%d tmq consume rows error!"%consumerId)

G
Ganlin Zhao 已提交
132
        tmqCom.checkFileContent(consumerId, queryString)
P
plum-lihui 已提交
133

G
Ganlin Zhao 已提交
134
        time.sleep(10)
P
plum-lihui 已提交
135 136 137
        for i in range(len(topicNameList)):
            tdSql.query("drop topic %s"%topicNameList[i])

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

P
plum-lihui 已提交
140 141
    def tmqCase2(self):
        tdLog.printNoPrefix("======== test case 2: ")
P
plum-lihui 已提交
142 143 144 145 146 147 148
        paraDict = {'dbName':     'dbt',
                    'dropFlag':   1,
                    'event':      '',
                    'vgroups':    1,
                    'stbName':    'stb',
                    'colPrefix':  'c',
                    'tagPrefix':  't',
P
plum-lihui 已提交
149 150
                    '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 已提交
151
                    'ctbPrefix':  'ctb',
P
plum-lihui 已提交
152 153
                    'ctbStartIdx': 0,
                    'ctbNum':     10,
P
plum-lihui 已提交
154 155 156
                    'rowsPerTbl': 10000,
                    'batchNum':   10,
                    'startTs':    1640966400000,  # 2022-01-01 00:00:00.000
P
plum-lihui 已提交
157
                    'pollDelay':  3,
P
plum-lihui 已提交
158 159 160 161
                    'showMsg':    1,
                    'showRow':    1,
                    'snapshot':   1}

P
plum-lihui 已提交
162 163 164
        paraDict['vgroups'] = self.vgroups
        paraDict['ctbNum'] = self.ctbNum
        paraDict['rowsPerTbl'] = self.rowsPerTbl
G
Ganlin Zhao 已提交
165

P
plum-lihui 已提交
166 167 168
        topicNameList = ['topic1']
        expectRowsList = []
        tmqCom.initConsumerTable()
G
Ganlin Zhao 已提交
169

P
plum-lihui 已提交
170 171 172 173 174 175
        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)
G
Ganlin Zhao 已提交
176
        tdSql.query(queryString)
P
plum-lihui 已提交
177
        expectRowsList.append(tdSql.getRows())
P
plum-lihui 已提交
178
        totalRowsInserted = expectRowsList[0]
P
plum-lihui 已提交
179 180 181

        # init consume info, and start tmq_sim, then check consume result
        tdLog.info("insert consume info to consume processor")
P
plum-lihui 已提交
182
        consumerId   = 1
P
plum-lihui 已提交
183
        expectrowcnt = math.ceil(paraDict["rowsPerTbl"] * paraDict["ctbNum"] / 3)
P
plum-lihui 已提交
184 185 186 187 188 189
        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 已提交
190
        tdLog.info("start consume processor 0")
P
plum-lihui 已提交
191
        tmqCom.startTmqSimProcess(pollDelay=paraDict['pollDelay'],dbName=paraDict["dbName"],showMsg=paraDict['showMsg'], showRow=paraDict['showRow'],snapshot=paraDict['snapshot'])
G
Ganlin Zhao 已提交
192 193
        tdLog.info("wait the consume result")

P
plum-lihui 已提交
194
        expectRows = 1
P
plum-lihui 已提交
195
        resultList = tmqCom.selectConsumeResult(expectRows)
G
Ganlin Zhao 已提交
196

P
plum-lihui 已提交
197 198
        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 已提交
199
            tdLog.exit("%d tmq consume rows error!"%consumerId)
G
Ganlin Zhao 已提交
200

P
plum-lihui 已提交
201
        firstConsumeRows = resultList[0]
P
plum-lihui 已提交
202

P
plum-lihui 已提交
203 204
        # reinit consume info, and start tmq_sim, then check consume result
        tmqCom.initConsumerTable()
P
plum-lihui 已提交
205 206
        consumerId   = 2
        expectrowcnt = math.ceil(paraDict["rowsPerTbl"] * paraDict["ctbNum"] * 2/3)
P
plum-lihui 已提交
207
        tmqCom.insertConsumerInfo(consumerId, expectrowcnt,topicList,keyList,ifcheckdata,ifManualCommit)
G
Ganlin Zhao 已提交
208

P
plum-lihui 已提交
209 210
        tdLog.info("start consume processor 1")
        tmqCom.startTmqSimProcess(pollDelay=paraDict['pollDelay'],dbName=paraDict["dbName"],showMsg=paraDict['showMsg'], showRow=paraDict['showRow'],snapshot=paraDict['snapshot'])
G
Ganlin Zhao 已提交
211 212
        tdLog.info("wait the consume result")

P
plum-lihui 已提交
213 214
        expectRows = 1
        resultList = tmqCom.selectConsumeResult(expectRows)
G
Ganlin Zhao 已提交
215

P
plum-lihui 已提交
216
        actConsumeTotalRows = firstConsumeRows + resultList[0]
G
Ganlin Zhao 已提交
217

P
plum-lihui 已提交
218
        if not (expectrowcnt >= resultList[0] and totalRowsInserted == actConsumeTotalRows):
G
Ganlin Zhao 已提交
219
            tdLog.info("act consume rows, first: %d, second: %d "%(firstConsumeRows, resultList[0]))
P
plum-lihui 已提交
220
            tdLog.info("and sum of two consume rows: %d should be equal to total inserted rows: %d"%(actConsumeTotalRows, totalRowsInserted))
P
plum-lihui 已提交
221 222
            tdLog.exit("%d tmq consume rows error!"%consumerId)

G
Ganlin Zhao 已提交
223
        time.sleep(10)
P
plum-lihui 已提交
224 225 226
        for i in range(len(topicNameList)):
            tdSql.query("drop topic %s"%topicNameList[i])

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

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

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

event = threading.Event()

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