183 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			183 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			Python
		
	
	
	
| ###################################################################
 | |
| #           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 math
 | |
| from random import randint
 | |
| from util.log import *
 | |
| from util.cases import *
 | |
| from util.sql import *
 | |
| from util.common import *
 | |
| from util.sqlset import *
 | |
| from util.boundary import *
 | |
| 
 | |
| class TDTestCase:
 | |
|     def init(self, conn, logSql, replicaVar=1):
 | |
|         self.replicaVar = int(replicaVar)
 | |
|         tdLog.debug("start to execute %s" % __file__)
 | |
|         tdSql.init(conn.cursor())
 | |
|         self.boundary = DataBoundary()
 | |
|         self.dbname_length_boundary = self.boundary.DBNAME_MAX_LENGTH
 | |
|         self.tbname_length_boundary = self.boundary.TBNAME_MAX_LENGTH
 | |
|         self.stbname_length_boundary = self.boundary.STBNAME_MAX_LENGTH
 | |
|         self.colname_length_boundary = self.boundary.COL_KEY_MAX_LENGTH
 | |
|         self.tagname_length_boundary = self.boundary.TAG_KEY_MAX_LENGTH
 | |
|         self.username_length_boundary = 23
 | |
|         self.password_length_boundary = 128
 | |
|     def dbname_length_check(self):
 | |
|         dbname_length = randint(1,self.dbname_length_boundary-1)
 | |
|         for dbname in [tdCom.get_long_name(self.dbname_length_boundary),tdCom.get_long_name(dbname_length)]:
 | |
|             tdSql.execute(f'create database if not exists {dbname}')
 | |
|             tdSql.query(f'select name from information_schema.ins_databases where name = "{dbname}"')
 | |
|             tdSql.checkEqual(tdSql.queryResult[0][0],dbname)
 | |
|             tdSql.execute(f'drop database if exists {dbname}')
 | |
|         dbname = tdCom.get_long_name(self.dbname_length_boundary+1)
 | |
|         tdSql.error(f'create database if not exists {dbname}')
 | |
|         if "Invalid identifier name" in tdSql.error_info:
 | |
|             tdLog.info("error info is true!")
 | |
|         else:
 | |
|             tdLog.exit("error info is not true")
 | |
| 
 | |
|     def tbname_length_check(self):
 | |
|         tdSql.prepare()
 | |
|         tdSql.execute('use db')
 | |
|         tbname_length = randint(1,self.tbname_length_boundary-1)
 | |
|         tdSql.execute(f'create table stb (ts timestamp,c0 int) tags(t0 int)')
 | |
|         for tbname in [tdCom.get_long_name(self.tbname_length_boundary),tdCom.get_long_name(tbname_length)]:
 | |
|             tdSql.execute(f'create table {tbname} using stb tags(1)')
 | |
|             tdSql.query(f'select table_name from information_schema.ins_tables where table_name = "{tbname}"')
 | |
|             tdSql.checkEqual(tdSql.queryResult[0][0],tbname)
 | |
|             tdSql.execute(f'drop table {tbname}')
 | |
|         tbname = tdCom.get_long_name(self.tbname_length_boundary+1)
 | |
|         tdSql.error(f'create table {tbname} using stb tags(1)')
 | |
|         if "Invalid identifier name" in tdSql.error_info:
 | |
|             tdLog.info("error info is true!")
 | |
|         else:
 | |
|             tdLog.exit("error info is not true")
 | |
|         stbname_length = randint(1,self.stbname_length_boundary-1)
 | |
|         for stbname in [tdCom.get_long_name(self.stbname_length_boundary),tdCom.get_long_name(stbname_length)]:
 | |
|             tdSql.execute(f'create table {stbname} (ts timestamp,c0 int) tags(t0 int)')
 | |
|             tdSql.query(f'select stable_name from information_schema.ins_stables where stable_name = "{stbname}"')
 | |
|             tdSql.checkEqual(tdSql.queryResult[0][0],stbname)
 | |
|             tdSql.execute(f'drop table {stbname}')
 | |
|         stbname = tdCom.get_long_name(self.stbname_length_boundary+1)
 | |
|         tdSql.error(f'create table {stbname} (ts timestamp,c0 int) tags(t0 int)')
 | |
|         print(tdSql.error_info)
 | |
|         if "Invalid identifier name" in tdSql.error_info:
 | |
|             tdLog.info("error info is true!")
 | |
|         else:
 | |
|             tdLog.exit("error info is not true")
 | |
|         tdSql.execute('drop database db')
 | |
| 
 | |
|     def colname_length_check(self):
 | |
|         tdSql.prepare()
 | |
|         tdSql.execute('use db')
 | |
|         column_name_length = randint(1,self.colname_length_boundary-1)
 | |
|         for colname in [tdCom.get_long_name(column_name_length),tdCom.get_long_name(self.colname_length_boundary)]:
 | |
|             stbname = tdCom.get_long_name(3)
 | |
|             ntbname = tdCom.get_long_name(4)
 | |
|             tdSql.execute(f'create table {stbname} (ts timestamp,{colname} int) tags(t0 int)')
 | |
|             tdSql.query(f'describe {stbname}')
 | |
|             tdSql.checkEqual(tdSql.queryResult[1][0],colname)
 | |
|             tdSql.execute(f'create table {ntbname} (ts timestamp,{colname} int)')
 | |
|             tdSql.query(f'describe {ntbname}')
 | |
|             tdSql.checkEqual(tdSql.queryResult[1][0],colname)
 | |
|         colname = tdCom.get_long_name(self.colname_length_boundary+1)
 | |
|         tdSql.error(f'create table stb (ts timestamp,{colname} int) tags(t0 int)')
 | |
|         if "Invalid identifier name" in tdSql.error_info:
 | |
|             tdLog.info("error info is true!")
 | |
|         else:
 | |
|             tdLog.exit("error info is not true")
 | |
|         tdSql.execute('drop database db')
 | |
| 
 | |
|     def tagname_length_check(self):
 | |
|         tdSql.prepare()
 | |
|         tdSql.execute('use db')
 | |
|         tag_name_length = randint(1,self.tagname_length_boundary-1)
 | |
|         for tagname in (tdCom.get_long_name(tag_name_length),tdCom.get_long_name(self.tagname_length_boundary)):
 | |
|             stbname = tdCom.get_long_name(3)
 | |
|             tdSql.execute(f'create table {stbname} (ts timestamp,c0 int) tags({tagname} int)')
 | |
|             tdSql.query(f'describe {stbname}')
 | |
|             tdSql.checkEqual(tdSql.queryResult[-1][0],tagname)
 | |
|         tagname = tdCom.get_long_name(self.tagname_length_boundary+1)
 | |
|         tdSql.error(f'create table {stbname} (ts timestamp,c0 int) tags({tagname} int)')
 | |
|         if "Invalid identifier name" in tdSql.error_info:
 | |
|             tdLog.info("error info is true!")
 | |
|         else:
 | |
|             tdLog.exit("error info is not true")
 | |
|         tdSql.execute('drop database db')
 | |
| 
 | |
|     def username_length_check(self):
 | |
|         username_length = randint(1,self.username_length_boundary-1)
 | |
|         for username in [tdCom.get_long_name(username_length),tdCom.get_long_name(self.username_length_boundary)]:
 | |
|             tdSql.execute(f'create user {username} pass "123"')
 | |
|             tdSql.query('show users')
 | |
|             for user in tdSql.queryResult:
 | |
|                 if user[0].lower() != 'root':
 | |
|                     tdSql.checkEqual(user[0],username)
 | |
|             tdSql.execute(f'drop user {username}')
 | |
|         username = tdCom.get_long_name(self.username_length_boundary+1)
 | |
|         tdSql.error(f'create user {username} pass "123"')
 | |
|         if "Name or password too long" in tdSql.error_info:
 | |
|             tdLog.info("error info is true!")
 | |
|         else:
 | |
|             tdLog.exit("error info is not true")
 | |
|     
 | |
|     def password_length_check(self):
 | |
|         password_length = randint(1,self.password_length_boundary-1)
 | |
|         for password in [tdCom.get_long_name(password_length),tdCom.get_long_name(self.password_length_boundary)]:
 | |
|             username = tdCom.get_long_name(3)
 | |
|             tdSql.execute(f'create user {username} pass "{password}"')
 | |
|         password = tdCom.get_long_name(self.password_length_boundary+1)
 | |
|         tdSql.error(f'create user {username} pass "{password}"')
 | |
|         if "Name or password too long" in tdSql.error_info:
 | |
|             tdLog.info("error info is true!")
 | |
|         else:
 | |
|             tdLog.exit("error info is not true")
 | |
|     def sql_length_check(self):
 | |
|         insert_rows = 1021
 | |
|         tdSql.prepare()
 | |
|         tdSql.execute('use db')
 | |
|         tdSql.execute('create table ntb (ts timestamp,c0 binary(1013))')
 | |
|         values_sql = ''
 | |
|         value = tdCom.get_long_name(1013)
 | |
|         for num in range(insert_rows):
 | |
|             values_sql += f' (now+{num}s,"{value}")'
 | |
|         value = tdCom.get_long_name(65)
 | |
|         values_sql += f"(now-1s,'{value}')"
 | |
|         tdSql.execute(f'insert into ntb values{values_sql}')
 | |
|         tdSql.query('select * from ntb')
 | |
|         tdSql.checkRows(insert_rows+1)
 | |
|         tdSql.execute('create table ntb1 (ts timestamp,c0 binary(1013))')
 | |
|         tdSql.error(f'insert into ntb1 values{values_sql};')
 | |
|         print(tdSql.error_info)
 | |
|         if "SQL statement too long" in tdSql.error_info:
 | |
|             tdLog.info("error info is true!")
 | |
|         else:
 | |
|             tdLog.exit("error info is not true")
 | |
|         tdSql.execute('drop database db')
 | |
|     def run(self):
 | |
|         self.dbname_length_check()
 | |
|         self.tbname_length_check()
 | |
|         self.colname_length_check()
 | |
|         self.tagname_length_check()
 | |
|         self.username_length_check()
 | |
|         self.password_length_check()
 | |
|         self.sql_length_check()
 | |
| 
 | |
|     def stop(self):
 | |
|         tdSql.close()
 | |
|         tdLog.success("%s successfully executed" % __file__)
 | |
| 
 | |
| tdCases.addWindows(__file__, TDTestCase())
 | |
| tdCases.addLinux(__file__, TDTestCase()) |