percentile.py 6.3 KB
Newer Older
J
jiacy-jcy 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
###################################################################
#           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 -*-

J
jiacy-jcy 已提交
14

J
jiacy-jcy 已提交
15 16 17 18 19
from util.log import *
from util.cases import *
from util.sql import *
import numpy as np

J
jiacy-jcy 已提交
20 21
from util.sqlset import TDSetSql

J
jiacy-jcy 已提交
22 23 24 25

class TDTestCase:
    def init(self, conn, logSql):
        tdLog.debug("start to execute %s" % __file__)
26
        tdSql.init(conn.cursor(), True)
J
jiacy-jcy 已提交
27 28 29

        self.rowNum = 10
        self.ts = 1537146000000
J
jiacy-jcy 已提交
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
        self.setsql = TDSetSql()
        self.ntbname = 'ntb'
        self.stbname = 'stb'
        self.binary_length = 20 # the length of binary for column_dict
        self.nchar_length = 20  # the length of nchar for column_dict
        self.column_dict = {
            'ts'  : 'timestamp',
            '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',
            'col12': f'binary({self.binary_length})',
            'col13': f'nchar({self.nchar_length})'
        }
J
jiacy-jcy 已提交
51
        
J
jiacy-jcy 已提交
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
        self.tag_dict = {
            'ts_tag'  : 'timestamp',
            't1': 'tinyint',
            't2': 'smallint',
            't3': 'int',
            't4': 'bigint',
            't5': 'tinyint unsigned',
            't6': 'smallint unsigned',
            't7': 'int unsigned',
            't8': 'bigint unsigned',
            't9': 'float',
            't10': 'double',
            't11': 'bool',
            't12': f'binary({self.binary_length})',
            't13': f'nchar({self.nchar_length})'
        }
        self.binary_str = 'taosdata'
        self.nchar_str = '涛思数据'
        self.tbnum = 2
J
jiacy-jcy 已提交
71 72 73 74 75 76 77 78 79 80 81 82
        self.tag_ts = self.ts
        self.tag_tinyint = 1
        self.tag_smallint = 2
        self.tag_int = 3
        self.tag_bigint = 4
        self.tag_utint = 5
        self.tag_usint = 6
        self.tag_uint = 7
        self.tag_ubint = 8
        self.tag_float = 9.1
        self.tag_double = 10.1
        self.tag_bool = True
J
jiacy-jcy 已提交
83
        self.tag_values = [
J
jiacy-jcy 已提交
84 85
            f'{self.tag_ts},{self.tag_tinyint},{self.tag_smallint},{self.tag_int},{self.tag_bigint},\
            {self.tag_utint},{self.tag_usint},{self.tag_uint},{self.tag_ubint},{self.tag_float},{self.tag_double},{self.tag_bool},"{self.binary_str}","{self.nchar_str}"'
J
jiacy-jcy 已提交
86 87 88 89
            
        ]
        
        self.param = [1,50,100]
J
jiacy-jcy 已提交
90
        
J
jiacy-jcy 已提交
91
    def insert_data(self,column_dict,tbname,row_num):
J
jiacy-jcy 已提交
92 93
        intData = []        
        floatData = []
J
jiacy-jcy 已提交
94
        insert_sql = self.setsql.set_insertsql(column_dict,tbname,self.binary_str,self.nchar_str)
J
jiacy-jcy 已提交
95 96
        for i in range(row_num):
            insert_list = []
J
jiacy-jcy 已提交
97 98
            self.setsql.insert_values(column_dict,i,insert_sql,insert_list,self.ts)
            intData.append(i)            
J
jiacy-jcy 已提交
99 100
            floatData.append(i + 0.1)
        return intData,floatData
J
jiacy-jcy 已提交
101 102 103 104
    def check_tags(self,tags,param,num,value):
        tdSql.query(f'select percentile({tags}, {param}) from {self.stbname}_{num}')
        print(tdSql.queryResult)
        tdSql.checkEqual(tdSql.queryResult[0][0], value)
J
jiacy-jcy 已提交
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
    def function_check_ntb(self):
        tdSql.prepare()
        tdSql.execute(self.setsql.set_create_normaltable_sql(self.ntbname,self.column_dict))
        intData,floatData = self.insert_data(self.column_dict,self.ntbname,self.rowNum)
        for k,v in self.column_dict.items():
            for param in self.param:
                if v.lower() in ['timestamp','bool'] or 'binary' in v.lower() or 'nchar' in v.lower():
                    tdSql.error(f'select percentile({k},{param}) from {self.ntbname}')
                elif v.lower() in ['tinyint','smallint','int','bigint','tinyint unsigned','smallint unsigned','int unsigned','bigint unsigned']:
                    tdSql.query(f'select percentile({k}, {param}) from {self.ntbname}')
                    tdSql.checkData(0, 0, np.percentile(intData, param))
                else:
                    tdSql.query(f'select percentile({k}, {param}) from {self.ntbname}')
                    tdSql.checkData(0, 0, np.percentile(floatData, param))
    def function_check_ctb(self):
        tdSql.prepare()
        tdSql.execute(self.setsql.set_create_stable_sql(self.stbname,self.column_dict,self.tag_dict))
        for i in range(self.tbnum):
            tdSql.execute(f"create table {self.stbname}_{i} using {self.stbname} tags({self.tag_values[0]})")
J
jiacy-jcy 已提交
124 125 126 127 128 129 130 131 132 133 134 135
            intData,floatData = self.insert_data(self.column_dict,f'{self.stbname}_{i}',self.rowNum)
        for i in range(self.tbnum):
            for k,v in self.column_dict.items():
                for param in self.param:
                    if v.lower() in ['timestamp','bool'] or 'binary' in v.lower() or 'nchar' in v.lower():
                        tdSql.error(f'select percentile({k},{param}) from {self.stbname}_{i}')
                    elif v.lower() in ['tinyint','smallint','int','bigint','tinyint unsigned','smallint unsigned','int unsigned','bigint unsigned']:
                        tdSql.query(f'select percentile({k}, {param}) from {self.stbname}_{i}')
                        tdSql.checkData(0, 0, np.percentile(intData, param))
                    else:
                        tdSql.query(f'select percentile({k}, {param}) from {self.stbname}_{i}')
                        tdSql.checkData(0, 0, np.percentile(floatData, param))
J
commit  
jiacy-jcy 已提交
136
            
J
jiacy-jcy 已提交
137 138 139
            #!bug TD-17119
            # for k,v in self.tag_dict.items():
            #     for param in self.param:
J
jiacy-jcy 已提交
140 141
            #         tdSql.error(f'select percentile({k},{param}) from {self.stbname}_{i}')
                    
J
jiacy-jcy 已提交
142
    def run(self):
J
jiacy-jcy 已提交
143
        self.function_check_ntb()
J
jiacy-jcy 已提交
144
        self.function_check_ctb()
J
jiacy-jcy 已提交
145 146 147 148 149 150 151
        
    def stop(self):
        tdSql.close()
        tdLog.success("%s successfully executed" % __file__)

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