################################################################### # 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 sys import subprocess import random import math from util.log import * from util.cases import * from util.sql import * from util.dnodes import * class TDTestCase: def init(self, conn, logSql): tdLog.debug(f"start to execute {__file__}") tdSql.init(conn.cursor(), logSql) def getBuildPath(self) -> str: selfPath = os.path.dirname(os.path.realpath(__file__)) if ("community" in selfPath): projPath = selfPath[:selfPath.find("community")] else: projPath = selfPath[:selfPath.find("tests")] for root, dirs, files in os.walk(projPath): if ("taosd" in files): rootRealPath = os.path.dirname(os.path.realpath(root)) if ("packaging" not in rootRealPath): buildPath = root[:len(root) - len("/debug/build/bin")] break return buildPath def getCfgDir(self) -> str: selfPath = os.path.dirname(os.path.realpath(__file__)) if ("community" in selfPath): cfgDir = self.getBuildPath() + "/community/sim/dnode1/cfg" else: cfgDir = self.getBuildPath() + "/sim/dnode1/cfg" return cfgDir def getCfgFile(self) -> str: return self.getCfgDir()+"/taos.cfg" def td3690(self): tdLog.printNoPrefix("==========TD-3690==========") tdSql.query("show variables") tdSql.checkData(53, 1, 864000) def td4082(self): tdLog.printNoPrefix("==========TD-4082==========") cfgfile = self.getCfgFile() max_compressMsgSize = 100000000 tdSql.query("show variables") tdSql.checkData(26, 1, -1) tdSql.query("show dnodes") index = tdSql.getData(0, 0) tdDnodes.stop(index) cmd = f"sed -i '$a compressMSgSize {max_compressMsgSize}' {cfgfile} " try: _ = subprocess.check_output(cmd, shell=True).decode("utf-8") except Exception as e: raise e tdDnodes.start(index) tdSql.query("show variables") tdSql.checkData(26, 1, 100000000) tdDnodes.stop(index) cmd = f"sed -i '$s/{max_compressMsgSize}/{max_compressMsgSize+10}/g' {cfgfile} " try: _ = subprocess.check_output(cmd, shell=True).decode("utf-8") except Exception as e: raise e tdDnodes.start(index) tdSql.query("show variables") tdSql.checkData(26, 1, -1) tdDnodes.stop(index) cmd = f"sed -i '$d' {cfgfile}" try: _ = subprocess.check_output(cmd, shell=True).decode("utf-8") except Exception as e: raise e tdDnodes.start(index) def td4097(self): tdLog.printNoPrefix("==========TD-4097==========") tdSql.execute("drop database if exists db") tdSql.execute("drop database if exists db1") tdSql.execute("create database if not exists db keep 3650") tdSql.execute("create database if not exists db1 keep 3650") tdSql.execute("create database if not exists new keep 3650") tdSql.execute("create database if not exists private keep 3650") tdSql.execute("create database if not exists db2 keep 3650") tdSql.execute("create stable db.stb1 (ts timestamp, c1 int) tags(t1 int)") tdSql.execute("create stable db.stb2 (ts timestamp, c1 int) tags(t1 int)") tdSql.execute("create stable db1.stb3 (ts timestamp, c1 int) tags(t1 int)") tdSql.execute("create table db.t10 using db.stb1 tags(1)") tdSql.execute("create table db.t11 using db.stb1 tags(2)") tdSql.execute("create table db.t20 using db.stb2 tags(3)") tdSql.execute("create table db1.t30 using db1.stb3 tags(4)") tdLog.printNoPrefix("==========TD-4097==========") # 插入数据,然后进行show create 操作 # p1 不进入指定数据库 tdSql.query("show create database db") tdSql.checkRows(1) tdSql.query("show create database db1") tdSql.checkRows(1) tdSql.query("show create database db2") tdSql.checkRows(1) tdSql.query("show create database new") tdSql.checkRows(1) tdSql.query("show create database private") tdSql.checkRows(1) tdSql.error("show create database ") tdSql.error("show create databases db ") tdSql.error("show create database db.stb1") tdSql.error("show create database db0") tdSql.error("show create database db db1") tdSql.error("show create database db, db1") tdSql.error("show create database stb1") tdSql.error("show create database * ") tdSql.query("show create stable db.stb1") tdSql.checkRows(1) tdSql.error("show create stable db.t10") tdSql.error("show create stable db.stb0") tdSql.error("show create stable stb1") tdSql.error("show create stable ") tdSql.error("show create stable *") tdSql.error("show create stable db.stb1 db.stb2") tdSql.error("show create stable db.stb1, db.stb2") tdSql.query("show create table db.stb1") tdSql.checkRows(1) tdSql.query("show create table db.t10") tdSql.checkRows(1) tdSql.error("show create table db.stb0") tdSql.error("show create table stb1") tdSql.error("show create table ") tdSql.error("show create table *") tdSql.error("show create table db.stb1 db.stb2") tdSql.error("show create table db.stb1, db.stb2") # p2 进入指定数据库 tdSql.execute("use db") tdSql.query("show create database db") tdSql.checkRows(1) tdSql.query("show create database db1") tdSql.checkRows(1) tdSql.error("show create database ") tdSql.error("show create databases db ") tdSql.error("show create database db.stb1") tdSql.error("show create database db0") tdSql.error("show create database db db1") tdSql.error("show create database db, db1") tdSql.error("show create database stb1") tdSql.error("show create database * ") tdSql.query("show create stable db.stb1") tdSql.checkRows(1) tdSql.query("show create stable stb1") tdSql.checkRows(1) tdSql.query("show create stable db1.stb3") tdSql.checkRows(1) tdSql.error("show create stable db.t10") tdSql.error("show create stable db") tdSql.error("show create stable t10") tdSql.error("show create stable db.stb0") tdSql.error("show create stables stb1") tdSql.error("show create stable ") tdSql.error("show create stable *") tdSql.error("show create stable db.stb1 db.stb2") tdSql.error("show create stable stb1 stb2") tdSql.error("show create stable db.stb1, db.stb2") tdSql.error("show create stable stb1, stb2") tdSql.query("show create table db.stb1") tdSql.checkRows(1) tdSql.query("show create table stb1") tdSql.checkRows(1) tdSql.query("show create table db.t10") tdSql.checkRows(1) tdSql.query("show create table t10") tdSql.checkRows(1) tdSql.query("show create table db1.t30") tdSql.checkRows(1) tdSql.error("show create table t30") tdSql.error("show create table db.stb0") tdSql.error("show create table db.t0") tdSql.error("show create table db") tdSql.error("show create tables stb1") tdSql.error("show create tables t10") tdSql.error("show create table ") tdSql.error("show create table *") tdSql.error("show create table db.stb1 db.stb2") tdSql.error("show create table db.t11 db.t10") tdSql.error("show create table db.stb1, db.stb2") tdSql.error("show create table db.t11, db.t10") tdSql.error("show create table stb1 stb2") tdSql.error("show create table t11 t10") tdSql.error("show create table stb1, stb2") tdSql.error("show create table t11, t10") # p3 删库删表后进行查询 tdSql.execute("drop table if exists t11") tdSql.error("show create table t11") tdSql.error("show create table db.t11") tdSql.query("show create stable stb1") tdSql.checkRows(1) tdSql.query("show create table t10") tdSql.checkRows(1) tdSql.execute("drop stable if exists stb2") tdSql.error("show create table stb2") tdSql.error("show create table db.stb2") tdSql.error("show create stable stb2") tdSql.error("show create stable db.stb2") tdSql.error("show create stable db.t20") tdSql.query("show create database db") tdSql.checkRows(1) tdSql.query("show create stable db.stb1") tdSql.checkRows(1) tdSql.execute("drop database if exists db1") tdSql.error("show create database db1") tdSql.error("show create stable db1.t31") tdSql.error("show create stable db1.stb3") tdSql.query("show create database db") tdSql.checkRows(1) tdSql.query("show create stable db.stb1") tdSql.checkRows(1) def td4153(self): tdLog.printNoPrefix("==========TD-4153==========") pass def td4288(self): tdLog.printNoPrefix("==========TD-4288==========") # keep ~ [days,365000] tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db") tdSql.query("show variables") tdSql.checkData(38, 1, 3650) tdSql.query("show databases") tdSql.checkData(0,7,"3650,3650,3650") days = tdSql.getData(0, 6) tdSql.error("alter database db keep 3650001") tdSql.error("alter database db keep 9") tdSql.error("alter database db keep 0b") tdSql.error("alter database db keep 3650,9,36500") tdSql.error("alter database db keep 3650,3650,365001") tdSql.error("alter database db keep 36500,a,36500") tdSql.error("alter database db keep (36500,3650,3650)") tdSql.error("alter database db keep [36500,3650,36500]") tdSql.error("alter database db keep 36500,0xff,3650") tdSql.error("alter database db keep 36500,0o365,3650") tdSql.error("alter database db keep 36500,0A3Ch,3650") tdSql.error("alter database db keep") tdSql.error("alter database db keep0 36500") tdSql.execute("alter database db keep 36500") tdSql.query("show databases") tdSql.checkData(0, 7, "3650,3650,36500") tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db1") tdSql.query("show databases") tdSql.checkData(0, 7, "3650,3650,3650") tdSql.query("show variables") tdSql.checkData(38, 1, 3650) tdSql.execute("alter database db1 keep 365") tdSql.execute("drop database if exists db1") pass def td4724(self): tdLog.printNoPrefix("==========TD-4724==========") cfgfile = self.getCfgFile() minTablesPerVnode = 5 maxTablesPerVnode = 10 maxVgroupsPerDb = 100 tdSql.query("show dnodes") index = tdSql.getData(0, 0) tdDnodes.stop(index) vnode_cmd = f"sed -i '$a maxVgroupsPerDb {maxVgroupsPerDb}' {cfgfile} " min_cmd = f"sed -i '$a minTablesPerVnode {minTablesPerVnode}' {cfgfile} " max_cmd = f"sed -i '$a maxTablesPerVnode {maxTablesPerVnode}' {cfgfile} " try: _ = subprocess.check_output(vnode_cmd, shell=True).decode("utf-8") _ = subprocess.check_output(min_cmd, shell=True).decode("utf-8") _ = subprocess.check_output(max_cmd, shell=True).decode("utf-8") except Exception as e: raise e tdDnodes.start(index) tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db keep 3650") tdSql.execute("use db") tdSql.execute("create stable db.stb1 (ts timestamp, c1 int) tags(t1 int)") insert_sql = "insert into " for i in range(100): tdSql.execute(f"create table db.t1{i} using db.stb1 tags({i})") insert_sql += f" t1{i} values({1604298064000 + i*1000}, {i})" tdSql.query("show dnodes") vnode_count = tdSql.getData(0, 2) if vnode_count <= 1: tdLog.exit("vnode is less than 2") tdSql.execute(insert_sql) tdDnodes.stop(index) cmd = f"sed -i '$d' {cfgfile}" try: _ = subprocess.check_output(cmd, shell=True).decode("utf-8") _ = subprocess.check_output(cmd, shell=True).decode("utf-8") _ = subprocess.check_output(cmd, shell=True).decode("utf-8") except Exception as e: raise e tdDnodes.start(index) pass def td4889(self): tdLog.printNoPrefix("==========TD-4889==========") tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db keep 3650") tdSql.execute("use db") tdSql.execute("create stable db.stb1 (ts timestamp, c1 int) tags(t1 int)") for i in range(1000): tdSql.execute(f"create table db.t1{i} using db.stb1 tags({i})") for j in range(100): tdSql.execute(f"insert into db.t1{i} values (now-100d, {i+j})") tdSql.query("show vgroups") index = tdSql.getData(0,0) tdSql.checkData(0, 6, 0) tdSql.execute(f"compact vnodes in({index})") for i in range(3): tdSql.query("show vgroups") if tdSql.getData(0, 6) == 1: tdLog.printNoPrefix("show vgroups row:0 col:6 data:1 == expect:1") break if i == 3: tdLog.exit("compacting not occured") time.sleep(0.5) pass def td5168insert(self): tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db keep 3650") tdSql.execute("use db") tdSql.execute("create stable db.stb1 (ts timestamp, c1 float, c2 float, c3 double, c4 double) tags(t1 int)") tdSql.execute("create table db.t1 using db.stb1 tags(1)") for i in range(5): c1 = 1001.11 + i*0.1 c2 = 1001.11 + i*0.1 + 1*0.01 c3 = 1001.11 + i*0.1 + 2*0.01 c4 = 1001.11 + i*0.1 + 3*0.01 tdSql.execute(f"insert into db.t1 values ('2021-07-01 08:00:0{i}.000', {c1}, {c2}, {c3}, {c4})") # tdSql.execute("insert into db.t1 values ('2021-07-01 08:00:00.000', 1001.11, 1001.12, 1001.13, 1001.14)") # tdSql.execute("insert into db.t1 values ('2021-07-01 08:00:01.000', 1001.21, 1001.22, 1001.23, 1001.24)") # tdSql.execute("insert into db.t1 values ('2021-07-01 08:00:02.000', 1001.31, 1001.32, 1001.33, 1001.34)") # tdSql.execute("insert into db.t1 values ('2021-07-01 08:00:03.000', 1001.41, 1001.42, 1001.43, 1001.44)") # tdSql.execute("insert into db.t1 values ('2021-07-01 08:00:04.000', 1001.51, 1001.52, 1001.53, 1001.54)") # for i in range(1000000): for i in range(1000000): random1 = random.uniform(1000,1001) random2 = random.uniform(1000,1001) random3 = random.uniform(1000,1001) random4 = random.uniform(1000,1001) tdSql.execute(f"insert into db.t1 values (now+{i}a, {random1}, {random2},{random3}, {random4})") pass def td5168(self): tdLog.printNoPrefix("==========TD-5168==========") # 插入小范围内的随机数 tdLog.printNoPrefix("=====step0: 默认情况下插入数据========") self.td5168insert() # 获取五个时间点的数据作为基准数值,未压缩情况下精准匹配 for i in range(5): tdSql.query(f"select * from db.t1 where ts='2021-07-01 08:00:0{i}.000' ") # c1, c2, c3, c4 = tdSql.getData(0, 1), tdSql.getData(0, 2), tdSql.getData(0, 3), tdSql.getData(0, 4) for j in range(4): locals()["f" + str(j) + str(i)] = tdSql.getData(0, j+1) print(f"f{j}{i}:", locals()["f" + str(j) + str(i)]) tdSql.checkData(0, j+1, locals()["f" + str(j) + str(i)]) # tdSql.query("select * from db.t1 limit 100,1") # f10, f11, f12, f13 = tdSql.getData(0,1), tdSql.getData(0,2), tdSql.getData(0,3), tdSql.getData(0,4) # # tdSql.query("select * from db.t1 limit 1000,1") # f20, f21, f22, f23 = tdSql.getData(0,1), tdSql.getData(0,2), tdSql.getData(0,3), tdSql.getData(0,4) # # tdSql.query("select * from db.t1 limit 10000,1") # f30, f31, f32, f33 = tdSql.getData(0,1), tdSql.getData(0,2), tdSql.getData(0,3), tdSql.getData(0,4) # # tdSql.query("select * from db.t1 limit 100000,1") # f40, f41, f42, f43 = tdSql.getData(0,1), tdSql.getData(0,2), tdSql.getData(0,3), tdSql.getData(0,4) # # tdSql.query("select * from db.t1 limit 1000000,1") # f50, f51, f52, f53 = tdSql.getData(0,1), tdSql.getData(0,2), tdSql.getData(0,3), tdSql.getData(0,4) # 关闭服务并获取未开启压缩情况下的数据容量 tdSql.query("show dnodes") index = tdSql.getData(0, 0) tdDnodes.stop(index) cfgdir = self.getCfgDir() cfgfile = self.getCfgFile() lossy_cfg_cmd=f"grep lossyColumns {cfgfile}|awk '{{print $2}}'" data_size_cmd = f"du -s {cfgdir}/../data/vnode/ | awk '{{print $1}}'" dsize_init = int(subprocess.check_output(data_size_cmd,shell=True).decode("utf-8")) lossy_args = subprocess.check_output(lossy_cfg_cmd, shell=True).decode("utf-8") tdLog.printNoPrefix(f"close the lossyColumns,data size is: {dsize_init};the lossyColumns line is: {lossy_args}") ################################################### float_lossy = "float" double_lossy = "double" float_double_lossy = "float|double" no_loosy = "" double_precision_cmd = f"sed -i '$a dPrecision 0.000001' {cfgfile}" _ = subprocess.check_output(double_precision_cmd, shell=True).decode("utf-8") lossy_float_cmd = f"sed -i '$a lossyColumns {float_lossy}' {cfgfile} " lossy_double_cmd = f"sed -i '$d' {cfgfile} && sed -i '$a lossyColumns {double_lossy}' {cfgfile} " lossy_float_double_cmd = f"sed -i '$d' {cfgfile} && sed -i '$a lossyColumns {float_double_lossy}' {cfgfile} " lossy_no_cmd = f"sed -i '$a lossyColumns {no_loosy}' {cfgfile} " ################################################### # 开启有损压缩,参数float,并启动服务插入数据 tdLog.printNoPrefix("=====step1: lossyColumns设置为float========") lossy_float = subprocess.check_output(lossy_float_cmd, shell=True).decode("utf-8") tdDnodes.start(index) self.td5168insert() # 查询前面所述5个时间数据并与基准数值进行比较 for i in range(5): tdSql.query(f"select * from db.t1 where ts='2021-07-01 08:00:0{i}.000' ") # c1, c2, c3, c4 = tdSql.getData(0, 1), tdSql.getData(0, 2), tdSql.getData(0, 3), tdSql.getData(0, 4) for j in range(4): # locals()["f" + str(j) + str(i)] = tdSql.getData(0, j+1) # print(f"f{j}{i}:", locals()["f" + str(j) + str(i)]) tdSql.checkData(0, j+1, locals()["f" + str(j) + str(i)]) # 关闭服务并获取压缩参数为float情况下的数据容量 tdDnodes.stop(index) dsize_float = int(subprocess.check_output(data_size_cmd,shell=True).decode("utf-8")) lossy_args = subprocess.check_output(lossy_cfg_cmd, shell=True).decode("utf-8") tdLog.printNoPrefix(f"open the lossyColumns, data size is:{dsize_float};the lossyColumns line is: {lossy_args}") # 修改有损压缩,参数double,并启动服务 tdLog.printNoPrefix("=====step2: lossyColumns设置为double========") lossy_double = subprocess.check_output(lossy_double_cmd, shell=True).decode("utf-8") tdDnodes.start(index) self.td5168insert() # 查询前面所述5个时间数据并与基准数值进行比较 for i in range(5): tdSql.query(f"select * from db.t1 where ts='2021-07-01 08:00:0{i}.000' ") for j in range(4): tdSql.checkData(0, j+1, locals()["f" + str(j) + str(i)]) # 关闭服务并获取压缩参数为double情况下的数据容量 tdDnodes.stop(index) dsize_double = int(subprocess.check_output(data_size_cmd, shell=True).decode("utf-8")) lossy_args = subprocess.check_output(lossy_cfg_cmd, shell=True).decode("utf-8") tdLog.printNoPrefix(f"open the lossyColumns, data size is:{dsize_double};the lossyColumns line is: {lossy_args}") # 修改有损压缩,参数 float&&double ,并启动服务 tdLog.printNoPrefix("=====step3: lossyColumns设置为 float&&double ========") lossy_float_double = subprocess.check_output(lossy_float_double_cmd, shell=True).decode("utf-8") tdDnodes.start(index) self.td5168insert() # 查询前面所述5个时间数据并与基准数值进行比较 for i in range(5): tdSql.query(f"select * from db.t1 where ts='2021-07-01 08:00:0{i}.000' ") for j in range(4): tdSql.checkData(0, j+1, locals()["f" + str(j) + str(i)]) # 关闭服务并获取压缩参数为 float&&double 情况下的数据容量 tdDnodes.stop(index) dsize_float_double = int(subprocess.check_output(data_size_cmd, shell=True).decode("utf-8")) lossy_args = subprocess.check_output(lossy_cfg_cmd, shell=True).decode("utf-8") tdLog.printNoPrefix(f"open the lossyColumns, data size is:{dsize_float_double};the lossyColumns line is: {lossy_args}") if not ((dsize_float_double < dsize_init) and (dsize_double < dsize_init) and (dsize_float < dsize_init)) : tdLog.printNoPrefix(f"When lossyColumns value is float, data size is: {dsize_float}") tdLog.printNoPrefix(f"When lossyColumns value is double, data size is: {dsize_double}") tdLog.printNoPrefix(f"When lossyColumns value is float and double, data size is: {dsize_float_double}") tdLog.printNoPrefix(f"When lossyColumns is closed, data size is: {dsize_init}") tdLog.exit("压缩未生效") else: tdLog.printNoPrefix(f"When lossyColumns value is float, data size is: {dsize_float}") tdLog.printNoPrefix(f"When lossyColumns value is double, data size is: {dsize_double}") tdLog.printNoPrefix(f"When lossyColumns value is float and double, data size is: {dsize_float_double}") tdLog.printNoPrefix(f"When lossyColumns is closed, data size is: {dsize_init}") tdLog.printNoPrefix("压缩生效") pass def td5433(self): tdLog.printNoPrefix("==========TD-5433==========") tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db keep 3650") tdSql.execute("use db") tdSql.execute("create stable db.stb1 (ts timestamp, c1 int) tags(t0 tinyint, t1 int)") tdSql.execute("create stable db.stb2 (ts timestamp, c1 int) tags(t0 binary(16), t1 binary(16))") numtab=2000000 for i in range(numtab): sql = f"create table db.t{i} using db.stb1 tags({i%128}, {100+i})" tdSql.execute(sql) tdSql.execute(f"insert into db.t{i} values (now-10d, {i})") tdSql.execute(f"insert into db.t{i} values (now-9d, {i*2})") tdSql.execute(f"insert into db.t{i} values (now-8d, {i*3})") tdSql.execute("create table db.t01 using db.stb2 tags('1', '100')") tdSql.execute("create table db.t02 using db.stb2 tags('2', '200')") tdSql.execute("create table db.t03 using db.stb2 tags('3', '300')") tdSql.execute("create table db.t04 using db.stb2 tags('4', '400')") tdSql.execute("create table db.t05 using db.stb2 tags('5', '500')") tdSql.query("select distinct t1 from stb1 where t1 != '150'") tdSql.checkRows(numtab-1) tdSql.query("select distinct t1 from stb1 where t1 != 150") tdSql.checkRows(numtab-1) tdSql.query("select distinct t1 from stb1 where t1 = 150") tdSql.checkRows(1) tdSql.query("select distinct t1 from stb1 where t1 = '150'") tdSql.checkRows(1) tdSql.query("select distinct t1 from stb1") tdSql.checkRows(numtab) tdSql.query("select distinct t0 from stb1 where t0 != '2'") tdSql.checkRows(127) tdSql.query("select distinct t0 from stb1 where t0 != 2") tdSql.checkRows(127) tdSql.query("select distinct t0 from stb1 where t0 = 2") tdSql.checkRows(1) tdSql.query("select distinct t0 from stb1 where t0 = '2'") tdSql.checkRows(1) tdSql.query("select distinct t0 from stb1") tdSql.checkRows(128) tdSql.query("select distinct t1 from stb2 where t1 != '200'") tdSql.checkRows(4) tdSql.query("select distinct t1 from stb2 where t1 != 200") tdSql.checkRows(4) tdSql.query("select distinct t1 from stb2 where t1 = 200") tdSql.checkRows(1) tdSql.query("select distinct t1 from stb2 where t1 = '200'") tdSql.checkRows(1) tdSql.query("select distinct t1 from stb2") tdSql.checkRows(5) tdSql.query("select distinct t0 from stb2 where t0 != '2'") tdSql.checkRows(4) tdSql.query("select distinct t0 from stb2 where t0 != 2") tdSql.checkRows(4) tdSql.query("select distinct t0 from stb2 where t0 = 2") tdSql.checkRows(1) tdSql.query("select distinct t0 from stb2 where t0 = '2'") tdSql.checkRows(1) tdSql.query("select distinct t0 from stb2") tdSql.checkRows(5) pass def td5798(self): tdLog.printNoPrefix("==========TD-5798 + TD-5810==========") tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db keep 3650") tdSql.execute("use db") tdSql.execute("create stable db.stb1 (ts timestamp, c1 int, c2 int) tags(t0 tinyint, t1 int, t2 int)") tdSql.execute("create stable db.stb2 (ts timestamp, c2 int, c3 binary(16)) tags(t2 binary(16), t3 binary(16), t4 int)") maxRemainderNum=7 tbnum=101 for i in range(tbnum-1): sql = f"create table db.t{i} using db.stb1 tags({i%maxRemainderNum}, {(i-1)%maxRemainderNum}, {i%2})" tdSql.execute(sql) tdSql.execute(f"insert into db.t{i} values (now-10d, {i}, {i%3})") tdSql.execute(f"insert into db.t{i} values (now-9d, {i}, {(i-1)%3})") tdSql.execute(f"insert into db.t{i} values (now-8d, {i}, {(i-2)%3})") tdSql.execute(f"insert into db.t{i} (ts )values (now-7d)") tdSql.execute(f"create table db.t0{i} using db.stb2 tags('{i%maxRemainderNum}', '{(i-1)%maxRemainderNum}', {i%3})") tdSql.execute(f"insert into db.t0{i} values (now-10d, {i}, '{(i+1)%3}')") tdSql.execute(f"insert into db.t0{i} values (now-9d, {i}, '{(i+2)%3}')") tdSql.execute(f"insert into db.t0{i} values (now-8d, {i}, '{(i)%3}')") tdSql.execute(f"insert into db.t0{i} (ts )values (now-7d)") tdSql.execute("create table db.t100num using db.stb1 tags(null, null, null)") tdSql.execute("create table db.t0100num using db.stb2 tags(null, null, null)") tdSql.execute(f"insert into db.t100num values (now-10d, {tbnum-1}, 1)") tdSql.execute(f"insert into db.t100num values (now-9d, {tbnum-1}, 0)") tdSql.execute(f"insert into db.t100num values (now-8d, {tbnum-1}, 2)") tdSql.execute(f"insert into db.t100num (ts )values (now-7d)") tdSql.execute(f"insert into db.t0100num values (now-10d, {tbnum-1}, 1)") tdSql.execute(f"insert into db.t0100num values (now-9d, {tbnum-1}, 0)") tdSql.execute(f"insert into db.t0100num values (now-8d, {tbnum-1}, 2)") tdSql.execute(f"insert into db.t0100num (ts )values (now-7d)") #========== TD-5810 suport distinct multi-data-coloumn ========== tdSql.query(f"select distinct c1 from stb1 where c1 <{tbnum}") tdSql.checkRows(tbnum) tdSql.query(f"select distinct c2 from stb1") tdSql.checkRows(4) tdSql.query(f"select distinct c1,c2 from stb1 where c1 <{tbnum}") tdSql.checkRows(tbnum*3) tdSql.query(f"select distinct c1,c1 from stb1 where c1 <{tbnum}") tdSql.checkRows(tbnum) tdSql.query(f"select distinct c1,c2 from stb1 where c1 <{tbnum} limit 3") tdSql.checkRows(3) tdSql.query(f"select distinct c1,c2 from stb1 where c1 <{tbnum} limit 3 offset {tbnum*3-2}") tdSql.checkRows(2) tdSql.query(f"select distinct c1 from t1 where c1 <{tbnum}") tdSql.checkRows(1) tdSql.query(f"select distinct c2 from t1") tdSql.checkRows(4) tdSql.query(f"select distinct c1,c2 from t1 where c1 <{tbnum}") tdSql.checkRows(3) tdSql.query(f"select distinct c1,c1 from t1 ") tdSql.checkRows(2) tdSql.query(f"select distinct c1,c1 from t1 where c1 <{tbnum}") tdSql.checkRows(1) tdSql.query(f"select distinct c1,c2 from t1 where c1 <{tbnum} limit 3") tdSql.checkRows(3) tdSql.query(f"select distinct c1,c2 from t1 where c1 <{tbnum} limit 3 offset 2") tdSql.checkRows(1) tdSql.query(f"select distinct c3 from stb2 where c2 <{tbnum} ") tdSql.checkRows(3) tdSql.query(f"select distinct c3, c2 from stb2 where c2 <{tbnum} limit 2") tdSql.checkRows(2) tdSql.error("select distinct c5 from stb1") tdSql.error("select distinct c5 from t1") tdSql.error("select distinct c1 from db.*") tdSql.error("select c2, distinct c1 from stb1") tdSql.error("select c2, distinct c1 from t1") tdSql.error("select distinct c2 from ") tdSql.error("distinct c2 from stb1") tdSql.error("distinct c2 from t1") tdSql.error("select distinct c1, c2, c3 from stb1") tdSql.error("select distinct c1, c2, c3 from t1") tdSql.error("select distinct stb1.c1, stb1.c2, stb2.c2, stb2.c3 from stb1") tdSql.error("select distinct stb1.c1, stb1.c2, stb2.c2, stb2.c3 from t1") tdSql.error("select distinct t1.c1, t1.c2, t2.c1, t2.c2 from t1") tdSql.query(f"select distinct c1 c2, c2 c3 from stb1 where c1 <{tbnum}") tdSql.checkRows(tbnum*3) tdSql.query(f"select distinct c1 c2, c2 c3 from t1 where c1 <{tbnum}") tdSql.checkRows(3) tdSql.query("select distinct c1, c2 from stb1 order by ts") tdSql.checkRows(tbnum*3+1) tdSql.query("select distinct c1, c2 from t1 order by ts") tdSql.checkRows(4) tdSql.error("select distinct c1, ts from stb1 group by c2") tdSql.error("select distinct c1, ts from t1 group by c2") tdSql.error("select distinct c1, max(c2) from stb1 ") tdSql.error("select distinct c1, max(c2) from t1 ") tdSql.error("select max(c2), distinct c1 from stb1 ") tdSql.error("select max(c2), distinct c1 from t1 ") tdSql.error("select distinct c1, c2 from stb1 where c1 > 3 group by t0") tdSql.error("select distinct c1, c2 from t1 where c1 > 3 group by t0") tdSql.error("select distinct c1, c2 from stb1 where c1 > 3 interval(1d) ") tdSql.error("select distinct c1, c2 from t1 where c1 > 3 interval(1d) ") tdSql.error("select distinct c1, c2 from stb1 where c1 > 3 interval(1d) fill(next)") tdSql.error("select distinct c1, c2 from t1 where c1 > 3 interval(1d) fill(next)") tdSql.error("select distinct c1, c2 from stb1 where ts > now-10d and ts < now interval(1d) fill(next)") tdSql.error("select distinct c1, c2 from t1 where ts > now-10d and ts < now interval(1d) fill(next)") tdSql.error("select distinct c1, c2 from stb1 where c1 > 3 slimit 1") tdSql.error("select distinct c1, c2 from t1 where c1 > 3 slimit 1") tdSql.query(f"select distinct c1, c2 from stb1 where c1 between {tbnum-2} and {tbnum} ") tdSql.checkRows(6) tdSql.query("select distinct c1, c2 from stb1 where c1 in (1,2,3,4,5)") tdSql.checkRows(15) tdSql.query("select distinct c1, c2 from stb1 where c1 in (100,1000,10000)") tdSql.checkRows(3) tdSql.query(f"select distinct c1,c2 from (select * from stb1 where c1 > {tbnum-2}) ") tdSql.checkRows(3) tdSql.query(f"select distinct c1,c2 from (select * from t1 where c1 < {tbnum}) ") tdSql.checkRows(3) tdSql.query(f"select distinct c1,c2 from (select * from stb1 where t2 !=0 and t2 != 1) ") tdSql.checkRows(4) tdSql.error("select distinct c1, c2 from (select distinct c1, c2 from stb1 where t0 > 2 and t1 < 3) ") tdSql.error("select c1, c2 from (select distinct c1, c2 from stb1 where t0 > 2 and t1 < 3) ") tdSql.query("select distinct c1, c2 from (select c2, c1 from stb1 where c1 > 2 ) where c1 < 4") tdSql.checkRows(3) tdSql.error("select distinct c1, c2 from (select c1 from stb1 where t0 > 2 ) where t1 < 3") tdSql.error("select distinct c1, c2 from (select c2, c1 from stb1 where c1 > 2 order by ts)") # tdSql.error("select distinct c1, c2 from (select c2, c1 from t1 where c1 > 2 order by ts)") tdSql.error("select distinct c1, c2 from (select c2, c1 from stb1 where c1 > 2 group by c1)") # tdSql.error("select distinct c1, c2 from (select max(c1) c1, max(c2) c2 from stb1 group by c1)") # tdSql.error("select distinct c1, c2 from (select max(c1) c1, max(c2) c2 from t1 group by c1)") tdSql.query("select distinct c1, c2 from (select max(c1) c1, max(c2) c2 from stb1 )") tdSql.checkRows(1) tdSql.query("select distinct c1, c2 from (select max(c1) c1, max(c2) c2 from t1 )") tdSql.checkRows(1) tdSql.error("select distinct stb1.c1, stb1.c2 from stb1 , stb2 where stb1.ts=stb2.ts and stb1.t2=stb2.t4") tdSql.error("select distinct t1.c1, t1.c2 from t1 , t2 where t1.ts=t2.ts ") # tdSql.error("select distinct c1, c2 from (select count(c1) c1, count(c2) c2 from stb1 group by ts)") # tdSql.error("select distinct c1, c2 from (select count(c1) c1, count(c2) c2 from t1 group by ts)") #========== TD-5798 suport distinct multi-tags-coloumn ========== tdSql.query("select distinct t1 from stb1") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t0, t1 from stb1") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t1, t0 from stb1") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t1, t2 from stb1") tdSql.checkRows(maxRemainderNum*2+1) tdSql.query("select distinct t0, t1, t2 from stb1") tdSql.checkRows(maxRemainderNum*2+1) tdSql.query("select distinct t0 t1, t1 t2 from stb1") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t0, t0, t0 from stb1") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t0, t1 from t1") tdSql.checkRows(1) tdSql.query("select distinct t0, t1 from t100num") tdSql.checkRows(1) tdSql.query("select distinct t3 from stb2") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t2, t3 from stb2") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t3, t2 from stb2") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t4, t2 from stb2") tdSql.checkRows(maxRemainderNum*3+1) tdSql.query("select distinct t2, t3, t4 from stb2") tdSql.checkRows(maxRemainderNum*3+1) tdSql.query("select distinct t2 t1, t3 t2 from stb2") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t3, t3, t3 from stb2") tdSql.checkRows(maxRemainderNum+1) tdSql.query("select distinct t2, t3 from t01") tdSql.checkRows(1) tdSql.query("select distinct t3, t4 from t0100num") tdSql.checkRows(1) ########## should be error ######### tdSql.error("select distinct from stb1") tdSql.error("select distinct t3 from stb1") tdSql.error("select distinct t1 from db.*") tdSql.error("select distinct t2 from ") tdSql.error("distinct t2 from stb1") tdSql.error("select distinct stb1") tdSql.error("select distinct t0, t1, t2, t3 from stb1") tdSql.error("select distinct stb1.t0, stb1.t1, stb2.t2, stb2.t3 from stb1") tdSql.error("select dist t0 from stb1") tdSql.error("select distinct stb2.t2, stb2.t3 from stb1") tdSql.error("select distinct stb2.t2 t1, stb2.t3 t2 from stb1") tdSql.error("select distinct t0, t1 from t1 where t0 < 7") ########## add where condition ########## tdSql.query("select distinct t0, t1 from stb1 where t1 > 3") tdSql.checkRows(3) tdSql.query("select distinct t0, t1 from stb1 where t1 > 3 limit 2") tdSql.checkRows(2) tdSql.query("select distinct t0, t1 from stb1 where t1 > 3 limit 2 offset 2") tdSql.checkRows(1) tdSql.query("select distinct t0, t1 from stb1 where t1 > 3 slimit 2") tdSql.checkRows(3) tdSql.error("select distinct t0, t1 from stb1 where c1 > 2") tdSql.query("select distinct t0, t1 from stb1 where t1 > 3 and t1 < 5") tdSql.checkRows(1) tdSql.error("select distinct stb1.t0, stb1.t1 from stb1, stb2 where stb1.t2=stb2.t4") tdSql.error("select distinct t0, t1 from stb1 where stb2.t4 > 2") tdSql.error("select distinct t0, t1 from stb1 where t1 > 3 group by t0") tdSql.error("select distinct t0, t1 from stb1 where t1 > 3 interval(1d) ") tdSql.error("select distinct t0, t1 from stb1 where t1 > 3 interval(1d) fill(next)") tdSql.error("select distinct t0, t1 from stb1 where ts > now-10d and ts < now interval(1d) fill(next)") tdSql.error("select max(c1), distinct t0 from stb1 where t0 > 2") tdSql.error("select distinct t0, max(c1) from stb1 where t0 > 2") tdSql.error("select distinct t0 from stb1 where t0 in (select t0 from stb1 where t0 > 2)") tdSql.query("select distinct t0, t1 from stb1 where t0 in (1,2,3,4,5)") tdSql.checkRows(5) tdSql.query("select distinct t1 from (select t0, t1 from stb1 where t0 > 2) ") tdSql.checkRows(4) tdSql.error("select distinct t1 from (select distinct t0, t1 from stb1 where t0 > 2 and t1 < 3) ") tdSql.error("select distinct t1 from (select distinct t0, t1 from stb1 where t0 > 2 ) where t1 < 3") tdSql.query("select distinct t1 from (select t0, t1 from stb1 where t0 > 2 ) where t1 < 3") tdSql.checkRows(1) tdSql.error("select distinct t1, t0 from (select t1 from stb1 where t0 > 2 ) where t1 < 3") tdSql.error("select distinct t1, t0 from (select max(t1) t1, max(t0) t0 from stb1 group by t1)") tdSql.error("select distinct t1, t0 from (select max(t1) t1, max(t0) t0 from stb1)") tdSql.query("select distinct t1, t0 from (select t1,t0 from stb1 where t0 > 2 ) where t1 < 3") tdSql.checkRows(1) tdSql.error(" select distinct t1, t0 from (select t1,t0 from stb1 where t0 > 2 order by ts) where t1 < 3") tdSql.error("select t1, t0 from (select distinct t1,t0 from stb1 where t0 > 2 ) where t1 < 3") tdSql.error(" select distinct t1, t0 from (select t1,t0 from stb1 where t0 > 2 group by ts) where t1 < 3") tdSql.error("select distinct stb1.t1, stb1.t2 from stb1 , stb2 where stb1.ts=stb2.ts and stb1.t2=stb2.t4") tdSql.error("select distinct t1.t1, t1.t2 from t1 , t2 where t1.ts=t2.ts ") pass def td5935(self): tdLog.printNoPrefix("==========TD-5935==========") tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db keep 3650") tdSql.execute("use db") tdSql.execute("create stable db.stb1 (ts timestamp, c1 int, c2 float) tags(t1 int, t2 int)") nowtime=int(round((time.time()*1000))) for i in range(100): sql = f"create table db.t{i} using db.stb1 tags({i % 7}, {i % 2})" tdSql.execute(sql) for j in range(1000): tdSql.execute(f"insert into db.t{i} values ({nowtime-j*10}, {1000-j}, {round(random.random()*j,3)})") tdSql.execute(f"insert into db.t{i} (ts) values ({nowtime-10000}) ") ########### TD-5933 verify the bug of "function stddev with interval return 0 rows" is fixed ########## stddevAndIntervalSql=f"select last(*) from t0 where ts>={nowtime-10000} interval(10a) limit 10" tdSql.query(stddevAndIntervalSql) tdSql.checkRows(10) ########## TD-5978 verify the bug of "when start row is null, result by fill(next) is 0 " is fixed ########## fillsql=f"select last(*) from t0 where ts>={nowtime-10000} and ts<{nowtime} interval(10a) fill(next) limit 10" tdSql.query(fillsql) fillResult=False if (tdSql.getData(0,2) != 0) and (tdSql.getData(0, 2) is not None): fillResult=True if fillResult: tdLog.success(f"sql is :{fillsql}, fill(next) is correct") else: tdLog.exit("fill(next) is wrong") pass def td6068(self): tdLog.printNoPrefix("==========TD-6068==========") tdSql.execute("drop database if exists db") tdSql.execute("create database if not exists db keep 3650") tdSql.execute("use db") tdSql.execute("create stable db.stb1 (ts timestamp, c1 int, c2 float, c3 timestamp, c4 binary(16), c5 double, c6 bool) tags(t1 int)") for i in range(100): sql = f"create table db.t{i} using db.stb1 tags({i})" tdSql.execute(sql) tdSql.execute(f"insert into db.t{i} values (now-10h, {i}, {i+random.random()}, now-10h, 'a_{i}', '{i-random.random()}', True)") tdSql.execute(f"insert into db.t{i} values (now-9h, {i+random.randint(1,10)}, {i+random.random()}, now-9h, 'a_{i}', '{i-random.random()}', FALSE )") tdSql.execute(f"insert into db.t{i} values (now-8h, {i+random.randint(1,10)}, {i+random.random()}, now-8h, 'b_{i}', '{i-random.random()}', True)") tdSql.execute(f"insert into db.t{i} values (now-7h, {i+random.randint(1,10)}, {i+random.random()}, now-7h, 'b_{i}', '{i-random.random()}', FALSE )") tdSql.execute(f"insert into db.t{i} values (now-6h, {i+random.randint(1,10)}, {i+random.random()}, now-6h, 'c_{i}', '{i-random.random()}', True)") tdSql.execute(f"insert into db.t{i} values (now-5h, {i+random.randint(1,10)}, {i+random.random()}, now-5h, 'c_{i}', '{i-random.random()}', FALSE )") tdSql.execute(f"insert into db.t{i} (ts)values (now-4h)") tdSql.execute(f"insert into db.t{i} (ts)values (now-11h)") tdSql.execute(f"insert into db.t{i} (ts)values (now-450m)") tdSql.query("select ts as t,derivative(c1, 10m, 0) from t1") tdSql.checkRows(5) tdSql.checkCols(3) for i in range(5): data=tdSql.getData(i, 0) tdSql.checkData(i, 1, data) tdSql.query("select ts as t, derivative(c1, 1h, 0) from stb1 group by tbname") tdSql.checkRows(500) tdSql.checkCols(4) tdSql.query("select ts as t, derivative(c1, 1s, 0) from t1") tdSql.query("select ts as t, derivative(c1, 1d, 0) from t1") tdSql.error("select ts as t, derivative(c1, 1h, 0) from stb1") tdSql.query("select ts as t, derivative(c2, 1h, 0) from t1") tdSql.checkRows(5) tdSql.error("select ts as t, derivative(c3, 1h, 0) from t1") tdSql.error("select ts as t, derivative(c4, 1h, 0) from t1") tdSql.query("select ts as t, derivative(c5, 1h, 0) from t1") tdSql.checkRows(5) tdSql.error("select ts as t, derivative(c6, 1h, 0) from t1") tdSql.error("select ts as t, derivative(t1, 1h, 0) from t1") tdSql.query("select ts as t, diff(c1) from t1") tdSql.checkRows(5) tdSql.checkCols(3) for i in range(5): data=tdSql.getData(i, 0) tdSql.checkData(i, 1, data) tdSql.query("select ts as t, diff(c1) from stb1 group by tbname") tdSql.checkRows(500) tdSql.checkCols(4) tdSql.query("select ts as t, diff(c1) from t1") tdSql.query("select ts as t, diff(c1) from t1") tdSql.error("select ts as t, diff(c1) from stb1") tdSql.query("select ts as t, diff(c2) from t1") tdSql.checkRows(5) tdSql.error("select ts as t, diff(c3) from t1") tdSql.error("select ts as t, diff(c4) from t1") tdSql.query("select ts as t, diff(c5) from t1") tdSql.checkRows(5) tdSql.error("select ts as t, diff(c6) from t1") tdSql.error("select ts as t, diff(t1) from t1") tdSql.error("select ts as t, diff(c1, c2) from t1") tdSql.error("select ts as t, bottom(c1, 0) from t1") tdSql.query("select ts as t, bottom(c1, 5) from t1") tdSql.checkRows(5) tdSql.checkCols(3) for i in range(5): data=tdSql.getData(i, 0) tdSql.checkData(i, 1, data) tdSql.query("select ts as t, bottom(c1, 5) from stb1") tdSql.checkRows(5) tdSql.query("select ts as t, bottom(c1, 5) from stb1 group by tbname") tdSql.checkRows(500) tdSql.query("select ts as t, bottom(c1, 8) from t1") tdSql.checkRows(6) tdSql.query("select ts as t, bottom(c2, 8) from t1") tdSql.checkRows(6) tdSql.error("select ts as t, bottom(c3, 5) from t1") tdSql.error("select ts as t, bottom(c4, 5) from t1") tdSql.query("select ts as t, bottom(c5, 8) from t1") tdSql.checkRows(6) tdSql.error("select ts as t, bottom(c6, 5) from t1") tdSql.error("select ts as t, bottom(c5, 8) as b from t1 order by b") tdSql.error("select ts as t, bottom(t1, 1) from t1") tdSql.error("select ts as t, bottom(t1, 1) from stb1") tdSql.error("select ts as t, bottom(t1, 3) from stb1 order by c3") tdSql.error("select ts as t, bottom(t1, 3) from t1 order by c3") tdSql.error("select ts as t, top(c1, 0) from t1") tdSql.query("select ts as t, top(c1, 5) from t1") tdSql.checkRows(5) tdSql.checkCols(3) for i in range(5): data=tdSql.getData(i, 0) tdSql.checkData(i, 1, data) tdSql.query("select ts as t, top(c1, 5) from stb1") tdSql.checkRows(5) tdSql.query("select ts as t, top(c1, 5) from stb1 group by tbname") tdSql.checkRows(500) tdSql.query("select ts as t, top(c1, 8) from t1") tdSql.checkRows(6) tdSql.query("select ts as t, top(c2, 8) from t1") tdSql.checkRows(6) tdSql.error("select ts as t, top(c3, 5) from t1") tdSql.error("select ts as t, top(c4, 5) from t1") tdSql.query("select ts as t, top(c5, 8) from t1") tdSql.checkRows(6) tdSql.error("select ts as t, top(c6, 5) from t1") tdSql.error("select ts as t, top(c5, 8) as b from t1 order by b") tdSql.error("select ts as t, top(t1, 1) from t1") tdSql.error("select ts as t, top(t1, 1) from stb1") tdSql.error("select ts as t, top(t1, 3) from stb1 order by c3") tdSql.error("select ts as t, top(t1, 3) from t1 order by c3") pass def run(self): # master branch # self.td3690() # self.td4082() # self.td4288() # self.td4724() # self.td5798() # self.td5935() self.td6068() # develop branch # self.td4097() # self.td4889() # self.td5168() # self.td5433() def stop(self): tdSql.close() tdLog.success(f"{__file__} successfully executed") tdCases.addWindows(__file__, TDTestCase()) tdCases.addLinux(__file__, TDTestCase())