update_data.py 17.6 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):
24
        self.replicaVar = int(replicaVar)
J
jiacy-jcy 已提交
25
        tdLog.debug("start to execute %s" % __file__)
J
jiacy-jcy 已提交
26
        tdSql.init(conn.cursor(),logSql)
J
update  
jiacy-jcy 已提交
27
        self.setsql = TDSetSql()
J
jiacy-jcy 已提交
28 29 30
        self.dbname = 'db_test'
        self.ntbname = 'ntb'
        self.stbname = 'stb'
J
update  
jiacy-jcy 已提交
31
        self.ctbname = 'ctb'
J
jiacy-jcy 已提交
32
        self.ts = 1537146000000
J
jiacy-jcy 已提交
33
        self.str_length = 20
J
jiajingbin 已提交
34
        self.block_update_times = 10000
J
jiacy-jcy 已提交
35 36 37 38 39 40 41 42 43 44 45 46
        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 已提交
47 48
            'col12': f'binary({self.str_length})',
            'col13': f'nchar({self.str_length})',
J
jiacy-jcy 已提交
49 50
            'col_ts'  : 'timestamp'
        }
J
jiajingbin 已提交
51 52 53 54 55 56 57 58
        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 已提交
59

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

J
update  
jiacy-jcy 已提交
253 254 255 256 257 258
    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 已提交
259

J
jiajingbin 已提交
260
    def update_10000times_and_query(self):
J
jiajingbin 已提交
261 262
        new_column_dict = {"ts": "timestamp"}
        new_column_dict.update(self.column_dict)
J
jiajingbin 已提交
263 264 265
        tdSql.execute(f'drop database if exists {self.dbname}')
        tdSql.execute(f'create database {self.dbname}')
        tdSql.execute(f'use {self.dbname}')
J
jiajingbin 已提交
266
        tdSql.execute(self.setsql.set_create_stable_sql(self.stbname,new_column_dict,self.tag_dict))
J
jiajingbin 已提交
267 268 269 270 271 272 273
        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 已提交
274
    def run(self):
J
update  
jiacy-jcy 已提交
275 276
        #!bug TD-17708 and TD-17709
        # for i in range(10):
J
jiacy-jcy 已提交
277 278
            self.update_check()
            self.update_check_error()
J
jiajingbin 已提交
279
            self.update_10000times_and_query()
J
update  
jiacy-jcy 已提交
280
            # i+=1
G
Ganlin Zhao 已提交
281

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

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