265 lines
18 KiB
Python
265 lines
18 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 -*-
|
|
|
|
from util.log import *
|
|
from util.cases import *
|
|
from util.sql import *
|
|
|
|
class TDTestCase:
|
|
def init(self, conn, logSql):
|
|
tdLog.debug("start to execute %s" % __file__)
|
|
tdSql.init(conn.cursor())
|
|
self.ts = 1537146000000
|
|
self.param_list = ['LT','lt','Lt','lT','GT','gt','Gt','gT','LE','le','Le','lE','GE','ge','Ge','gE','NE','ne','Ne','nE','EQ','eq','Eq','eQ']
|
|
self.row_num = 10
|
|
def run(self):
|
|
tdSql.prepare()
|
|
# timestamp = 1ms , time_unit = 1s
|
|
tdSql.execute('''create table test(ts timestamp, col1 tinyint, col2 smallint, col3 int, col4 bigint, col5 float, col6 double,
|
|
col7 bool, col8 binary(20), col9 nchar(20), col11 tinyint unsigned, col12 smallint unsigned, col13 int unsigned, col14 bigint unsigned)''')
|
|
for i in range(self.row_num):
|
|
tdSql.execute("insert into test values(%d, %d, %d, %d, %d, %f, %f, %d, 'taosdata%d', '涛思数据%d', %d, %d, %d, %d)"
|
|
% (self.ts + i, i + 1, i + 1, i + 1, i + 1, i + 0.1, i + 0.1, i % 2, i + 1, i + 1, i + 1, i + 1, i + 1, i + 1))
|
|
integer_list = [1,2,3,4,11,12,13,14]
|
|
float_list = [5,6]
|
|
|
|
for i in integer_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5) from test")
|
|
tdSql.checkRows(10)
|
|
if j in ['LT' ,'lt','Lt','lT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (0,), (0,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GT','gt', 'Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (0,), (0,), (0,), (0,)])
|
|
elif j in ['LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (0,), (0,), (0,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in [ 'GE','ge','Ge','gE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (0,), (0,), (0,), (0,), (0,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (0,), (0,), (0,), (-1,), (0,), (0,), (0,), (0,), (0,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
for i in float_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5) from test")
|
|
tdSql.checkRows(10)
|
|
if j in ['LT','lt','Lt','lT','LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (0,), (0,), (0,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GE','ge','Ge','gE','GT','gt','Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (0,), (0,), (0,), (0,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (0,), (0,), (0,), (0,), (0,), (0,), (0,), (0,), (0,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
|
|
error_column_list = ['ts','col7','col8','col9','a',1]
|
|
for i in error_column_list:
|
|
for j in self.param_list:
|
|
tdSql.error(f"select stateduration({i},{j},5) from test")
|
|
|
|
error_param_list = ['a',1]
|
|
for i in error_param_list:
|
|
tdSql.error(f"select stateduration(col1,{i},5) from test")
|
|
|
|
# timestamp = 1s, time_unit =1s
|
|
tdSql.execute('''create table test1(ts timestamp, col1 tinyint, col2 smallint, col3 int, col4 bigint, col5 float, col6 double,
|
|
col7 bool, col8 binary(20), col9 nchar(20), col11 tinyint unsigned, col12 smallint unsigned, col13 int unsigned, col14 bigint unsigned)''')
|
|
for i in range(self.row_num):
|
|
tdSql.execute("insert into test1 values(%d, %d, %d, %d, %d, %f, %f, %d, 'taosdata%d', '涛思数据%d', %d, %d, %d, %d)"
|
|
% (self.ts + i*1000, i + 1, i + 1, i + 1, i + 1, i + 0.1, i + 0.1, i % 2, i + 1, i + 1, i + 1, i + 1, i + 1, i + 1))
|
|
|
|
for i in integer_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5) from test1")
|
|
tdSql.checkRows(10)
|
|
# print(tdSql.queryResult)
|
|
if j in ['LT' ,'lt','Lt','lT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GT','gt', 'Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in [ 'GE','ge','Ge','gE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,), (5,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
for i in float_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5) from test1")
|
|
tdSql.checkRows(10)
|
|
print(tdSql.queryResult)
|
|
if j in ['LT','lt','Lt','lT','LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GE','ge','Ge','gE','GT','gt','Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (5,), (6,), (7,), (8,), (9,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
|
|
|
|
# timestamp = 1m, time_unit =1m
|
|
tdSql.execute('''create table test2(ts timestamp, col1 tinyint, col2 smallint, col3 int, col4 bigint, col5 float, col6 double,
|
|
col7 bool, col8 binary(20), col9 nchar(20), col11 tinyint unsigned, col12 smallint unsigned, col13 int unsigned, col14 bigint unsigned)''')
|
|
for i in range(self.row_num):
|
|
tdSql.execute("insert into test2 values(%d, %d, %d, %d, %d, %f, %f, %d, 'taosdata%d', '涛思数据%d', %d, %d, %d, %d)"
|
|
% (self.ts + i*1000*60, i + 1, i + 1, i + 1, i + 1, i + 0.1, i + 0.1, i % 2, i + 1, i + 1, i + 1, i + 1, i + 1, i + 1))
|
|
|
|
for i in integer_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5,1m) from test2")
|
|
tdSql.checkRows(10)
|
|
# print(tdSql.queryResult)
|
|
if j in ['LT' ,'lt','Lt','lT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GT','gt', 'Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in [ 'GE','ge','Ge','gE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,), (5,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
for i in float_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5,1m) from test2")
|
|
tdSql.checkRows(10)
|
|
print(tdSql.queryResult)
|
|
if j in ['LT','lt','Lt','lT','LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GE','ge','Ge','gE','GT','gt','Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (5,), (6,), (7,), (8,), (9,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
|
|
# timestamp = 1h, time_unit =1h
|
|
tdSql.execute('''create table test3(ts timestamp, col1 tinyint, col2 smallint, col3 int, col4 bigint, col5 float, col6 double,
|
|
col7 bool, col8 binary(20), col9 nchar(20), col11 tinyint unsigned, col12 smallint unsigned, col13 int unsigned, col14 bigint unsigned)''')
|
|
for i in range(self.row_num):
|
|
tdSql.execute("insert into test3 values(%d, %d, %d, %d, %d, %f, %f, %d, 'taosdata%d', '涛思数据%d', %d, %d, %d, %d)"
|
|
% (self.ts + i*1000*60*60, i + 1, i + 1, i + 1, i + 1, i + 0.1, i + 0.1, i % 2, i + 1, i + 1, i + 1, i + 1, i + 1, i + 1))
|
|
|
|
for i in integer_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5,1h) from test3")
|
|
tdSql.checkRows(10)
|
|
# print(tdSql.queryResult)
|
|
if j in ['LT' ,'lt','Lt','lT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GT','gt', 'Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in [ 'GE','ge','Ge','gE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,), (5,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
for i in float_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5,1h) from test3")
|
|
tdSql.checkRows(10)
|
|
print(tdSql.queryResult)
|
|
if j in ['LT','lt','Lt','lT','LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GE','ge','Ge','gE','GT','gt','Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (5,), (6,), (7,), (8,), (9,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
|
|
# timestamp = 1h,time_unit =1m
|
|
for i in integer_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5,1m) from test3")
|
|
tdSql.checkRows(10)
|
|
# print(tdSql.queryResult)
|
|
if j in ['LT' ,'lt','Lt','lT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (60,), (120,), (180,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GT','gt', 'Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (60,), (120,), (180,), (240,)])
|
|
elif j in ['LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (60,), (120,), (180,), (240,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in [ 'GE','ge','Ge','gE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (60,), (120,), (180,), (240,), (300,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (60,), (120,), (180,), (-1,), (0,), (60,), (120,), (180,), (240,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
for i in float_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5,1m) from test3")
|
|
tdSql.checkRows(10)
|
|
print(tdSql.queryResult)
|
|
if j in ['LT','lt','Lt','lT','LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (60,), (120,), (180,), (240,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GE','ge','Ge','gE','GT','gt','Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (60,), (120,), (180,), (240,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (60,), (120,), (180,), (240,), (300,), (360,), (420,), (480,), (540,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
|
|
# for stb
|
|
tdSql.execute('''create table stb(ts timestamp, col1 tinyint, col2 smallint, col3 int, col4 bigint, col5 float, col6 double,
|
|
col7 bool, col8 binary(20), col9 nchar(20), col11 tinyint unsigned, col12 smallint unsigned, col13 int unsigned, col14 bigint unsigned) tags(t0 int)''')
|
|
tdSql.execute('create table stb_1 using stb tags(1)')
|
|
for i in range(self.row_num):
|
|
tdSql.execute("insert into stb_1 values(%d, %d, %d, %d, %d, %f, %f, %d, 'taosdata%d', '涛思数据%d', %d, %d, %d, %d)"
|
|
% (self.ts + i*1000*60*60, i + 1, i + 1, i + 1, i + 1, i + 0.1, i + 0.1, i % 2, i + 1, i + 1, i + 1, i + 1, i + 1, i + 1))
|
|
|
|
for i in integer_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5,1h) from stb")
|
|
tdSql.checkRows(10)
|
|
# print(tdSql.queryResult)
|
|
if j in ['LT' ,'lt','Lt','lT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GT','gt', 'Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in [ 'GE','ge','Ge','gE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,), (5,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (0,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
for i in float_list:
|
|
for j in self.param_list:
|
|
tdSql.query(f"select stateduration(col{i},'{j}',5,1h) from stb")
|
|
tdSql.checkRows(10)
|
|
print(tdSql.queryResult)
|
|
if j in ['LT','lt','Lt','lT','LE','le','Le','lE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
elif j in ['GE','ge','Ge','gE','GT','gt','Gt','gT']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (0,), (1,), (2,), (3,), (4,)])
|
|
elif j in ['NE','ne','Ne','nE']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(0,), (1,), (2,), (3,), (4,), (5,), (6,), (7,), (8,), (9,)])
|
|
elif j in ['EQ','eq','Eq','eQ']:
|
|
tdSql.checkEqual(tdSql.queryResult,[(-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,), (-1,)])
|
|
|
|
def stop(self):
|
|
tdSql.close()
|
|
tdLog.success("%s successfully executed" % __file__)
|
|
|
|
tdCases.addWindows(__file__, TDTestCase())
|
|
tdCases.addLinux(__file__, TDTestCase()) |