update_data.py 17.5 KB
Newer Older
J
jiacy-jcy 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
###################################################################
#           Copyright (c) 2016 by TAOS Technologies, Inc.
#                     All rights reserved.
#
#  This file is proprietary and confidential to TAOS Technologies.
#  No part of this file may be reproduced, stored, transmitted,
#  disclosed or used in any form or by any means other than as
#  expressly provided by the written permission from Jianhui Tao
#
###################################################################

# -*- coding: utf-8 -*-

import random
J
jiacy-jcy 已提交
15
from datetime import datetime
J
jiacy-jcy 已提交
16 17 18 19 20
from util import constant
from util.log import *
from util.cases import *
from util.sql import *
from util.common import *
J
update  
jiacy-jcy 已提交
21
from util.sqlset import TDSetSql
J
jiacy-jcy 已提交
22
class TDTestCase:
23
    def init(self, conn, logSql, replicaVar=1):
J
jiacy-jcy 已提交
24
        tdLog.debug("start to execute %s" % __file__)
J
jiacy-jcy 已提交
25
        tdSql.init(conn.cursor(),logSql)
J
update  
jiacy-jcy 已提交
26
        self.setsql = TDSetSql()
J
jiacy-jcy 已提交
27 28 29
        self.dbname = 'db_test'
        self.ntbname = 'ntb'
        self.stbname = 'stb'
J
update  
jiacy-jcy 已提交
30
        self.ctbname = 'ctb'
J
jiacy-jcy 已提交
31
        self.ts = 1537146000000
J
jiacy-jcy 已提交
32
        self.str_length = 20
J
jiajingbin 已提交
33
        self.block_update_times = 10000
J
jiacy-jcy 已提交
34 35 36 37 38 39 40 41 42 43 44 45
        self.column_dict = {
            'col1': 'tinyint',
            'col2': 'smallint',
            'col3': 'int',
            'col4': 'bigint',
            'col5': 'tinyint unsigned',
            'col6': 'smallint unsigned',
            'col7': 'int unsigned',
            'col8': 'bigint unsigned',
            'col9': 'float',
            'col10': 'double',
            'col11': 'bool',
J
jiacy-jcy 已提交
46 47
            'col12': f'binary({self.str_length})',
            'col13': f'nchar({self.str_length})',
J
jiacy-jcy 已提交
48 49
            'col_ts'  : 'timestamp'
        }
J
jiajingbin 已提交
50 51 52 53 54 55 56 57
        self.tag_dict = {
            't0':'int'
        }
        # The number of tag_values should be same as tbnum
        self.tag_values = [
            f'10',
            f'100'
        ]
G
Ganlin Zhao 已提交
58

J
update  
jiacy-jcy 已提交
59
    def data_check(self,tbname,col_name,col_type,value):
J
jiacy-jcy 已提交
60 61 62 63 64 65
        tdSql.query(f'select {col_name} from {tbname}')
        if col_type.lower() == 'float' or col_type.lower() == 'double':
            if abs(tdSql.queryResult[0][0] - value) / value <= 0.0001:
                tdSql.checkEqual(tdSql.queryResult[0][0],tdSql.queryResult[0][0])
            else:
                tdLog.exit(f'{col_name} data check failure')
J
update  
jiacy-jcy 已提交
66
        elif col_type.lower() == 'timestamp':
J
jiacy-jcy 已提交
67
            tdSql.checkEqual(str(tdSql.queryResult[0][0]),str(datetime.fromtimestamp(value/1000).strftime("%Y-%m-%d %H:%M:%S.%f")))
J
jiacy-jcy 已提交
68 69
        else:
            tdSql.checkEqual(tdSql.queryResult[0][0],value)
J
update  
jiacy-jcy 已提交
70 71 72 73 74 75 76
    def update_and_check_data(self,tbname,col_name,col_type,value,dbname):
        if 'binary' in col_type.lower() or 'nchar' in col_type.lower():
            tdSql.execute(f'insert into {tbname} values({self.ts},"{value}")')
        else:
            tdSql.execute(f'insert into {tbname} values({self.ts},{value})')
        self.data_check(tbname,col_name,col_type,value)
        tdSql.execute(f'flush database {dbname}')
J
update  
jiacy-jcy 已提交
77
        tdSql.execute('reset query cache')
J
update  
jiacy-jcy 已提交
78
        self.data_check(tbname,col_name,col_type,value)
J
update  
jiacy-jcy 已提交
79 80
        for func in ['first','last']:
            tdSql.execute(f'select {func}({col_name}) from {tbname}')
J
update  
jiacy-jcy 已提交
81 82 83 84 85 86 87 88
    def error_check(self,tbname,column_dict,tb_type=None,stbname=None):
        str_length = self.str_length+1
        for col_name,col_type in column_dict.items():
            if tb_type == 'ntb':
                tdSql.execute(f'create table {tbname} (ts timestamp,{col_name} {col_type})')
            elif tb_type == 'ctb':
                tdSql.execute(f'create table {stbname} (ts timestamp,{col_name} {col_type}) tags(t0 int)')
                tdSql.execute(f'create table {tbname} using {stbname} tags(1)')
J
jiacy-jcy 已提交
89
            tdSql.execute(f'insert into {tbname} values({self.ts},null)')
J
update  
jiacy-jcy 已提交
90 91 92
            if col_type.lower() == 'double':
                for error_value in [tdCom.getLongName(self.str_length),True,False,1.1*constant.DOUBLE_MIN,1.1*constant.DOUBLE_MAX]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
93 94
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
95 96 97
            elif col_type.lower() == 'float':
                for error_value in [tdCom.getLongName(self.str_length),True,False,1.1*constant.FLOAT_MIN,1.1*constant.FLOAT_MAX]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
98 99
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
100 101 102
            elif 'binary' in col_type.lower() or 'nchar' in col_type.lower():
                for error_value in [tdCom.getLongName(str_length)]:
                    tdSql.error(f'insert into {tbname} values({self.ts},"{error_value}")')
J
jiacy-jcy 已提交
103 104
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
105 106 107
            elif col_type.lower() == 'bool':
                for error_value in [tdCom.getLongName(self.str_length)]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
108 109
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
110 111 112
            elif col_type.lower() == 'tinyint':
                for error_value in [constant.TINYINT_MIN-1,constant.TINYINT_MAX+1,random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX),tdCom.getLongName(self.str_length),True,False]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
113 114
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
115 116 117
            elif col_type.lower() == 'smallint':
                for error_value in [constant.SMALLINT_MIN-1,constant.SMALLINT_MAX+1,random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX),tdCom.getLongName(self.str_length),True,False]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
118 119
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
120 121 122
            elif col_type.lower() == 'int':
                for error_value in [constant.INT_MIN-1,constant.INT_MAX+1,random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX),tdCom.getLongName(self.str_length),True,False]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
123 124
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
125 126 127
            elif col_type.lower() == 'bigint':
                for error_value in [constant.BIGINT_MIN-1,constant.BIGINT_MAX+1,random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX),tdCom.getLongName(self.str_length),True,False]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
128 129
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
130 131
            elif col_type.lower() == 'tinyint unsigned':
                for error_value in [constant.TINYINT_UN_MIN-1,constant.TINYINT_UN_MAX+1,random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX),tdCom.getLongName(self.str_length),True,False]:
G
Ganlin Zhao 已提交
132
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
133
                    if tb_type == 'ctb':
G
Ganlin Zhao 已提交
134
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
135 136 137
            elif col_type.lower() == 'smallint unsigned':
                for error_value in [constant.SMALLINT_UN_MIN-1,constant.SMALLINT_UN_MAX+1,random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX),tdCom.getLongName(self.str_length),True,False]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
138 139
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
140 141 142
            elif col_type.lower() == 'int unsigned':
                for error_value in [constant.INT_UN_MIN-1,constant.INT_UN_MAX+1,random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX),tdCom.getLongName(self.str_length),True,False]:
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
143 144
                    if tb_type == 'ctb':
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
145 146
            elif col_type.lower() == 'bigint unsigned':
                for error_value in [constant.BIGINT_UN_MIN-1,constant.BIGINT_UN_MAX+1,random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX),tdCom.getLongName(self.str_length),True,False]:
G
Ganlin Zhao 已提交
147
                    tdSql.error(f'insert into {tbname} values({self.ts},{error_value})')
J
jiacy-jcy 已提交
148
                    if tb_type == 'ctb':
G
Ganlin Zhao 已提交
149
                        tdSql.error(f'insert into {stbname} values({self.ts},{error_value})')
J
update  
jiacy-jcy 已提交
150 151 152 153
            tdSql.execute(f'drop table {tbname}')
            if tb_type == 'ctb':
                tdSql.execute(f'drop table {stbname}')
    def update_data_check(self,tbname,column_dict,dbname,tb_type=None,stbname=None):
J
jiacy-jcy 已提交
154 155 156 157 158 159 160 161 162 163 164
        up_tinyint = random.randint(constant.TINYINT_MIN,constant.TINYINT_MAX)
        up_smallint = random.randint(constant.SMALLINT_MIN,constant.SMALLINT_MAX)
        up_int = random.randint(constant.INT_MIN,constant.INT_MAX)
        up_bigint = random.randint(constant.BIGINT_MIN,constant.BIGINT_MAX)
        up_untinyint = random.randint(constant.TINYINT_UN_MIN,constant.TINYINT_UN_MAX)
        up_unsmallint = random.randint(constant.SMALLINT_UN_MIN,constant.SMALLINT_UN_MAX)
        up_unint = random.randint(constant.INT_UN_MIN,constant.INT_MAX)
        up_unbigint = random.randint(constant.BIGINT_UN_MIN,constant.BIGINT_UN_MAX)
        up_bool = random.randint(0,100)%2
        up_float = random.uniform(constant.FLOAT_MIN,constant.FLOAT_MAX)
        up_double = random.uniform(constant.DOUBLE_MIN*(1E-300),constant.DOUBLE_MAX*(1E-300))
J
jiacy-jcy 已提交
165 166 167 168 169 170
        binary_length = []
        for i in range(self.str_length+1):
            binary_length.append(i)
        nchar_length = []
        for i in range(self.str_length+1):
            nchar_length.append(i)
J
update  
jiacy-jcy 已提交
171 172 173 174 175 176
        for col_name,col_type in column_dict.items():
            if tb_type == 'ntb':
                tdSql.execute(f'create table {tbname} (ts timestamp,{col_name} {col_type})')
            elif tb_type == 'ctb':
                tdSql.execute(f'create table {stbname} (ts timestamp,{col_name} {col_type}) tags(t0 int)')
                tdSql.execute(f'create table {tbname} using {stbname} tags(1)')
J
jiacy-jcy 已提交
177
            tdSql.execute(f'insert into {tbname} values({self.ts},null)')
J
jiacy-jcy 已提交
178
            if col_type.lower() == 'tinyint':
J
update  
jiacy-jcy 已提交
179
                self.update_and_check_data(tbname,col_name,col_type,up_tinyint,dbname)
J
jiacy-jcy 已提交
180
            elif col_type.lower() == 'smallint':
J
update  
jiacy-jcy 已提交
181
                self.update_and_check_data(tbname,col_name,col_type,up_smallint,dbname)
J
jiacy-jcy 已提交
182
            elif col_type.lower() == 'int':
J
update  
jiacy-jcy 已提交
183
                self.update_and_check_data(tbname,col_name,col_type,up_int,dbname)
J
jiacy-jcy 已提交
184
            elif col_type.lower() == 'bigint':
J
update  
jiacy-jcy 已提交
185
                self.update_and_check_data(tbname,col_name,col_type,up_bigint,dbname)
J
jiacy-jcy 已提交
186
            elif col_type.lower() == 'tinyint unsigned':
J
update  
jiacy-jcy 已提交
187
                self.update_and_check_data(tbname,col_name,col_type,up_untinyint,dbname)
J
jiacy-jcy 已提交
188
            elif col_type.lower() == 'smallint unsigned':
J
update  
jiacy-jcy 已提交
189
                self.update_and_check_data(tbname,col_name,col_type,up_unsmallint,dbname)
J
jiacy-jcy 已提交
190
            elif col_type.lower() == 'int unsigned':
J
update  
jiacy-jcy 已提交
191
                self.update_and_check_data(tbname,col_name,col_type,up_unint,dbname)
J
jiacy-jcy 已提交
192
            elif col_type.lower() == 'bigint unsigned':
J
update  
jiacy-jcy 已提交
193
                self.update_and_check_data(tbname,col_name,col_type,up_unbigint,dbname)
J
jiacy-jcy 已提交
194
            elif col_type.lower() == 'bool':
G
Ganlin Zhao 已提交
195
                self.update_and_check_data(tbname,col_name,col_type,up_bool,dbname)
J
jiacy-jcy 已提交
196
            elif col_type.lower() == 'float':
G
Ganlin Zhao 已提交
197
                self.update_and_check_data(tbname,col_name,col_type,up_float,dbname)
J
jiacy-jcy 已提交
198
            elif col_type.lower() == 'double':
J
update  
jiacy-jcy 已提交
199
                self.update_and_check_data(tbname,col_name,col_type,up_double,dbname)
J
jiacy-jcy 已提交
200
            elif 'binary' in col_type.lower():
J
jiacy-jcy 已提交
201 202 203
                for i in binary_length:
                    up_binary = tdCom.getLongName(i)
                    self.update_and_check_data(tbname,col_name,col_type,up_binary,dbname)
J
jiacy-jcy 已提交
204
            elif 'nchar' in col_type.lower():
J
jiacy-jcy 已提交
205 206 207
                for i in nchar_length:
                    up_nchar = tdCom.getLongName(i)
                    self.update_and_check_data(tbname,col_name,col_type,up_nchar,dbname)
J
update  
jiacy-jcy 已提交
208 209
            elif col_type.lower() == 'timestamp':
                self.update_and_check_data(tbname,col_name,col_type,self.ts+1,dbname)
J
update  
jiacy-jcy 已提交
210 211
            tdSql.execute(f'insert into {tbname} values({self.ts},null)')
            tdSql.query(f'select {col_name} from {tbname}')
J
jiacy-jcy 已提交
212
            tdSql.checkEqual(tdSql.queryResult[0][0],None)
J
update  
jiacy-jcy 已提交
213
            tdSql.execute(f'flush database {self.dbname}')
J
update  
jiacy-jcy 已提交
214 215
            tdSql.execute('reset query cache')
            tdSql.query(f'select {col_name} from {tbname}')
J
update  
jiacy-jcy 已提交
216
            tdSql.checkEqual(tdSql.queryResult[0][0],None)
J
update  
jiacy-jcy 已提交
217 218 219 220
            tdSql.execute(f'drop table {tbname}')
            if tb_type == 'ctb':
                tdSql.execute(f'drop table {stbname}')
    def update_check(self):
J
jiacy-jcy 已提交
221 222 223
        tdSql.execute(f'drop database if exists {self.dbname}')
        tdSql.execute(f'create database {self.dbname}')
        tdSql.execute(f'use {self.dbname}')
J
update  
jiacy-jcy 已提交
224
        self.update_data_check(self.ntbname,self.column_dict,self.dbname,'ntb')
J
jiacy-jcy 已提交
225 226
        for col_name,col_type in self.column_dict.items():
            tdSql.execute(f'create table {self.ntbname} (ts timestamp,{col_name} {col_type})')
J
jiacy-jcy 已提交
227
            tdSql.execute(f'insert into {self.ntbname} values({self.ts},null)')
J
update  
jiacy-jcy 已提交
228 229 230 231 232 233 234 235
            if 'binary' in col_type.lower():
                up_binary = tdCom.getLongName(self.str_length+1)
                tdSql.execute(f'alter table {self.ntbname} modify column {col_name} binary({self.str_length+1})')
                self.update_and_check_data(self.ntbname,col_name,col_type,up_binary,self.dbname)
            elif 'nchar' in col_type.lower():
                up_nchar = tdCom.getLongName(self.str_length+1)
                tdSql.execute(f'alter table {self.ntbname} modify column {col_name} nchar({self.str_length+1})')
                self.update_and_check_data(self.ntbname,col_name,col_type,up_nchar,self.dbname)
J
jiacy-jcy 已提交
236
            tdSql.execute(f'drop table {self.ntbname}')
J
update  
jiacy-jcy 已提交
237 238 239 240
        self.update_data_check(self.ctbname,self.column_dict,self.dbname,'ctb',self.stbname)
        for col_name,col_type in self.column_dict.items():
            tdSql.execute(f'create table {self.stbname} (ts timestamp,{col_name} {col_type}) tags(t0 int)')
            tdSql.execute(f'create table {self.ctbname} using {self.stbname} tags(1)')
J
jiacy-jcy 已提交
241
            tdSql.execute(f'insert into {self.ctbname} values({self.ts},null)')
J
update  
jiacy-jcy 已提交
242 243 244 245 246 247 248 249 250
            if 'binary' in col_type.lower():
                up_binary = tdCom.getLongName(self.str_length+1)
                tdSql.execute(f'alter table {self.stbname} modify column {col_name} binary({self.str_length+1})')
                self.update_and_check_data(self.ctbname,col_name,col_type,up_binary,self.dbname)
            elif 'nchar' in col_type.lower():
                up_nchar = tdCom.getLongName(self.str_length+1)
                tdSql.execute(f'alter table {self.stbname} modify column {col_name} nchar({self.str_length+1})')
                self.update_and_check_data(self.ctbname,col_name,col_type,up_nchar,self.dbname)
            tdSql.execute(f'drop table {self.stbname}')
J
jiacy-jcy 已提交
251

J
update  
jiacy-jcy 已提交
252 253 254 255 256 257
    def update_check_error(self):
        tdSql.execute(f'drop database if exists {self.dbname}')
        tdSql.execute(f'create database {self.dbname}')
        tdSql.execute(f'use {self.dbname}')
        self.error_check(self.ntbname,self.column_dict,'ntb')
        self.error_check(self.ctbname,self.column_dict,'ctb',self.stbname)
J
jiacy-jcy 已提交
258

J
jiajingbin 已提交
259
    def update_10000times_and_query(self):
J
jiajingbin 已提交
260 261
        new_column_dict = {"ts": "timestamp"}
        new_column_dict.update(self.column_dict)
J
jiajingbin 已提交
262 263 264
        tdSql.execute(f'drop database if exists {self.dbname}')
        tdSql.execute(f'create database {self.dbname}')
        tdSql.execute(f'use {self.dbname}')
J
jiajingbin 已提交
265
        tdSql.execute(self.setsql.set_create_stable_sql(self.stbname,new_column_dict,self.tag_dict))
J
jiajingbin 已提交
266 267 268 269 270 271 272
        tdSql.execute(f'create table {self.stbname}_1 using {self.stbname} tags({self.tag_values[0]})')
        tdSql.execute(f'insert into {self.stbname}_1 values ({self.ts}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.choice(["True", "FALSE"])}, {random.randint(1, 127)}, {random.randint(1, 127)}, now)')
        for i in range(self.block_update_times):
            tdSql.execute(f'insert into {self.stbname}_1 values ({self.ts}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.randint(1, 127)}, {random.choice(["True", "FALSE"])}, {random.randint(1, 127)}, {random.randint(1, 127)}, now)')
        tdSql.query(f'select count(*) from {self.stbname}')
        tdSql.query(f'select * from {self.stbname}')

J
update  
jiacy-jcy 已提交
273
    def run(self):
J
update  
jiacy-jcy 已提交
274 275
        #!bug TD-17708 and TD-17709
        # for i in range(10):
J
jiacy-jcy 已提交
276 277
            self.update_check()
            self.update_check_error()
J
jiajingbin 已提交
278
            self.update_10000times_and_query()
J
update  
jiacy-jcy 已提交
279
            # i+=1
G
Ganlin Zhao 已提交
280

J
jiacy-jcy 已提交
281 282 283 284 285
    def stop(self):
        tdSql.close()
        tdLog.success("%s successfully executed" % __file__)

tdCases.addWindows(__file__, TDTestCase())
G
Ganlin Zhao 已提交
286
tdCases.addLinux(__file__, TDTestCase())