提交 d8440475 编写于 作者: C cpwu

fix case

上级 ee821197
...@@ -27,6 +27,8 @@ TAOS_BIN_TYPE = [ ...@@ -27,6 +27,8 @@ TAOS_BIN_TYPE = [
TAOS_TIME_INIT = ["b", "u", "a", "s", "m", "h", "d", "w", "n", "y"] TAOS_TIME_INIT = ["b", "u", "a", "s", "m", "h", "d", "w", "n", "y"]
TAOS_PRECISION = ["ms", "us", "ns"] TAOS_PRECISION = ["ms", "us", "ns"]
PRECISION_DEFAULT = "ms"
PRECISION = PRECISION_DEFAULT
# basic data type boundary # basic data type boundary
TINYINT_MAX = 127 TINYINT_MAX = 127
...@@ -110,6 +112,8 @@ TIME_N = 30 * TIME_D ...@@ -110,6 +112,8 @@ TIME_N = 30 * TIME_D
TIME_Y = 365 * TIME_D TIME_Y = 365 * TIME_D
# session parameters
INTERVAL_MIN = 1 * TIME_MS if PRECISION == PRECISION_DEFAULT else 1 * TIME_US
# streams and related agg-function # streams and related agg-function
......
...@@ -142,8 +142,8 @@ class SMAschema: ...@@ -142,8 +142,8 @@ class SMAschema:
del self.other[k] del self.other[k]
from ...pytest.util.sql import * # from ...pytest.util.sql import *
from ...pytest.util.constant import * # from ...pytest.util.constant import *
class TDTestCase: class TDTestCase:
updatecfgDict = {"querySmaOptimize": 1} updatecfgDict = {"querySmaOptimize": 1}
...@@ -170,7 +170,11 @@ class TDTestCase: ...@@ -170,7 +170,11 @@ class TDTestCase:
if sma.func: if sma.func:
sql += f" function({', '.join(sma.func)})" sql += f" function({', '.join(sma.func)})"
if sma.interval: if sma.interval:
sql += f" interval({', '.join(sma.interval)})" interval, offset = self.__get_interval_offset(sma.interval)
if offset:
sql += f" interval({interval}, {offset})"
else:
sql += f" interval({interval})"
if sma.sliding: if sma.sliding:
sql += f" sliding({sma.sliding})" sql += f" sliding({sma.sliding})"
if sma.watermark: if sma.watermark:
...@@ -213,6 +217,8 @@ class TDTestCase: ...@@ -213,6 +217,8 @@ class TDTestCase:
return True return True
def __check_sma_watermark(self, arg): def __check_sma_watermark(self, arg):
if not arg:
return False
if not isinstance(arg, str): if not isinstance(arg, str):
return False return False
if arg[-1] not in SMA_WATMARK_MAXDELAY_INIT: if arg[-1] not in SMA_WATMARK_MAXDELAY_INIT:
...@@ -229,13 +235,14 @@ class TDTestCase: ...@@ -229,13 +235,14 @@ class TDTestCase:
return True return True
def __check_sma_max_delay(self, arg): def __check_sma_max_delay(self, arg):
self.__check_sma_watermark(arg) if not self.__check_sma_watermark(arg):
return False
if tdSql.get_times(arg) < MAX_DELAY_MIN: if tdSql.get_times(arg) < MAX_DELAY_MIN:
return False return False
return True return True
def __check_sliding(self, arg): def __check_sma_sliding(self, arg):
if not isinstance(arg, str): if not isinstance(arg, str):
return False return False
if arg[-1] not in TAOS_TIME_INIT: if arg[-1] not in TAOS_TIME_INIT:
...@@ -245,10 +252,40 @@ class TDTestCase: ...@@ -245,10 +252,40 @@ class TDTestCase:
if not arg[:-1].isdecimal(): if not arg[:-1].isdecimal():
return False return False
return True
def __get_interval_offset(self, args):
if isinstance(args, str):
interval, offset = args, None
elif isinstance(args,tuple) or isinstance(args, list):
if len(args) == 1:
interval, offset = args[0], None
elif len(args) == 2:
interval, offset = args
else:
interval, offset = False, False
else:
interval, offset = False, False
return interval, offset
def __check_interval(self, arg): def __check_sma_interval(self, args):
if not isinstance(arg, tuple): if not isinstance(args, tuple) and not isinstance(args,str):
return False return False
interval, offset = self.__get_interval_offset(args)
if not interval:
return False
if not self.__check_sma_sliding(interval):
return False
if tdSql.get_times(interval) < INTERVAL_MIN:
return False
if offset:
if not self.__check_sma_sliding(offset):
return False
if tdSql.get_times(interval) <= tdSql.get_times(offset) :
return False
return True
def __sma_create_check(self, sma:SMAschema): def __sma_create_check(self, sma:SMAschema):
if self.updatecfgDict["querySmaOptimize"] == 0: if self.updatecfgDict["querySmaOptimize"] == 0:
...@@ -272,9 +309,10 @@ class TDTestCase: ...@@ -272,9 +309,10 @@ class TDTestCase:
return False return False
if not sma.func or not self.__check_sma_func(sma.func): if not sma.func or not self.__check_sma_func(sma.func):
return False return False
if not sma.interval: if not sma.sliding or not self.__check_sma_sliding(sma.sliding):
return False return False
if not sma.sliding : interval, _ = self.__get_interval_offset(sma.interval)
if not sma.interval or not self.__check_sma_interval(sma.interval) or tdSql.get_times(interval) < tdSql.get_times(sma.sliding):
return False return False
if not sma.watermark or not self.__check_sma_watermark(sma.watermark): if not sma.watermark or not self.__check_sma_watermark(sma.watermark):
return False return False
...@@ -300,10 +338,10 @@ class TDTestCase: ...@@ -300,10 +338,10 @@ class TDTestCase:
# err_sqls.append( SMAschema(operator="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) ) # err_sqls.append( SMAschema(operator="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) )
# err_sqls.append( SMAschema(tbname="", func=(f"min({INT_COL})",f"max({INT_COL})") ) ) # err_sqls.append( SMAschema(tbname="", func=(f"min({INT_COL})",f"max({INT_COL})") ) )
# err_sqls.append( SMAschema(func="",tbname=STBNAME ) ) # err_sqls.append( SMAschema(func="",tbname=STBNAME ) )
# err_sqls.append( SMAschema(interval="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) ) err_sqls.append( SMAschema(interval=("6m"),tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) )
# err_sqls.append( SMAschema(sliding="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) ) # err_sqls.append( SMAschema(sliding="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) )
# err_sqls.append( SMAschema(max_delay="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) ) # err_sqls.append( SMAschema(max_delay="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) )
err_sqls.append( SMAschema(watermark="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) ) # err_sqls.append( SMAschema(watermark="",tbname=STBNAME, func=(f"min({INT_COL})",f"max({INT_COL})") ) )
return err_sqls, cur_sqls return err_sqls, cur_sqls
...@@ -311,7 +349,6 @@ class TDTestCase: ...@@ -311,7 +349,6 @@ class TDTestCase:
def test_create_sma(self): def test_create_sma(self):
err_sqls , cur_sqls = self.__create_sma_sql err_sqls , cur_sqls = self.__create_sma_sql
for err_sql in err_sqls: for err_sql in err_sqls:
print(type(err_sql.watermark))
self.sma_create_check(err_sql) self.sma_create_check(err_sql)
def all_test(self): def all_test(self):
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册