1034 lines
		
	
	
		
			48 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			1034 lines
		
	
	
		
			48 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 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.error("select distinct  c1, c2 from stb1 order by ts")
 | ||
|         #tdSql.checkRows(tbnum*3+1)
 | ||
|         tdSql.error("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())
 | ||
| 
 | ||
| 
 | ||
| 
 |