test: add sma profermance test
This commit is contained in:
parent
2a8c90db40
commit
6aa38d1cc9
|
@ -0,0 +1,190 @@
|
||||||
|
###################################################################
|
||||||
|
# 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
|
||||||
|
|
||||||
|
from numpy.lib.function_base import insert
|
||||||
|
import taos
|
||||||
|
from util.log import *
|
||||||
|
from util.cases import *
|
||||||
|
from util.sql import *
|
||||||
|
import numpy as np
|
||||||
|
|
||||||
|
# constant define
|
||||||
|
WAITS = 5 # wait seconds
|
||||||
|
|
||||||
|
class TDTestCase:
|
||||||
|
#
|
||||||
|
# --------------- main frame -------------------
|
||||||
|
#
|
||||||
|
|
||||||
|
def caseDescription(self):
|
||||||
|
'''
|
||||||
|
limit and offset keyword function test cases;
|
||||||
|
case1: limit offset base function test
|
||||||
|
case2: offset return valid
|
||||||
|
'''
|
||||||
|
return
|
||||||
|
|
||||||
|
# init
|
||||||
|
def init(self, conn, logSql):
|
||||||
|
tdLog.debug("start to execute %s" % __file__)
|
||||||
|
tdSql.init(conn.cursor())
|
||||||
|
tdSql.prepare()
|
||||||
|
self.create_tables();
|
||||||
|
self.ts = 1500000000000
|
||||||
|
|
||||||
|
|
||||||
|
# run case
|
||||||
|
def run(self):
|
||||||
|
# insert data
|
||||||
|
self.insert_data("t1", self.ts, 1000*10000)
|
||||||
|
self.insert_data1("t4", self.ts, 1000*10000)
|
||||||
|
# test base case
|
||||||
|
# self.test_case1()
|
||||||
|
tdLog.debug(" LIMIT test_case1 ............ [OK]")
|
||||||
|
# test advance case
|
||||||
|
# self.test_case2()
|
||||||
|
tdLog.debug(" LIMIT test_case2 ............ [OK]")
|
||||||
|
|
||||||
|
|
||||||
|
# stop
|
||||||
|
def stop(self):
|
||||||
|
tdSql.close()
|
||||||
|
tdLog.success("%s successfully executed" % __file__)
|
||||||
|
|
||||||
|
#
|
||||||
|
# --------------- case -------------------
|
||||||
|
#
|
||||||
|
|
||||||
|
# create table
|
||||||
|
def create_tables(self):
|
||||||
|
# super table
|
||||||
|
tdSql.execute("create table st(ts timestamp, i1 int) tags(area int)");
|
||||||
|
# child table
|
||||||
|
tdSql.execute("create table t1 using st tags(1)");
|
||||||
|
tdSql.execute("create table t2 using st tags(2)");
|
||||||
|
tdSql.execute("create table t3 using st tags(3)");
|
||||||
|
|
||||||
|
tdSql.execute("create table st1(ts timestamp, i1 int ,i2 int) tags(area int) sma(i2) ");
|
||||||
|
tdSql.execute("create table t4 using st1 tags(1)");
|
||||||
|
|
||||||
|
return
|
||||||
|
|
||||||
|
# insert data1
|
||||||
|
def insert_data(self, tbname, ts_start, count):
|
||||||
|
pre_insert = "insert into %s values"%tbname
|
||||||
|
sql = pre_insert
|
||||||
|
tdLog.debug("doing insert table %s rows=%d ..."%(tbname, count))
|
||||||
|
for i in range(count):
|
||||||
|
sql += " (%d,%d)"%(ts_start + i*1000, i )
|
||||||
|
if i >0 and i%30000 == 0:
|
||||||
|
tdSql.execute(sql)
|
||||||
|
sql = pre_insert
|
||||||
|
# end sql
|
||||||
|
if sql != pre_insert:
|
||||||
|
tdSql.execute(sql)
|
||||||
|
|
||||||
|
tdLog.debug("INSERT TABLE DATA ............ [OK]")
|
||||||
|
return
|
||||||
|
|
||||||
|
def insert_data1(self, tbname, ts_start, count):
|
||||||
|
pre_insert = "insert into %s values"%tbname
|
||||||
|
sql = pre_insert
|
||||||
|
tdLog.debug("doing insert table %s rows=%d ..."%(tbname, count))
|
||||||
|
for i in range(count):
|
||||||
|
sql += " (%d,%d,%d)"%(ts_start + i*1000, i , i+1)
|
||||||
|
if i >0 and i%30000 == 0:
|
||||||
|
tdSql.execute(sql)
|
||||||
|
sql = pre_insert
|
||||||
|
# end sql
|
||||||
|
if sql != pre_insert:
|
||||||
|
tdSql.execute(sql)
|
||||||
|
|
||||||
|
tdLog.debug("INSERT TABLE DATA ............ [OK]")
|
||||||
|
return
|
||||||
|
|
||||||
|
# test case1 base
|
||||||
|
# def test_case1(self):
|
||||||
|
# #
|
||||||
|
# # limit base function
|
||||||
|
# #
|
||||||
|
# # base no where
|
||||||
|
# sql = "select * from t1 limit 10"
|
||||||
|
# tdSql.waitedQuery(sql, 10, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 0)
|
||||||
|
# tdSql.checkData(9, 1, 9)
|
||||||
|
|
||||||
|
# # have where
|
||||||
|
# sql = "select * from t1 where ts>='2017-07-14 10:40:01' and ts<'2017-07-14 10:40:06' limit 10"
|
||||||
|
# tdSql.waitedQuery(sql, 5, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 1)
|
||||||
|
# tdSql.checkData(4, 1, 5)
|
||||||
|
|
||||||
|
# #
|
||||||
|
# # offset base function
|
||||||
|
# #
|
||||||
|
# # no where
|
||||||
|
# sql = "select * from t1 limit 10 offset 5"
|
||||||
|
# tdSql.waitedQuery(sql, 10, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 5)
|
||||||
|
# tdSql.checkData(9, 1, 14)
|
||||||
|
|
||||||
|
# # have where only ts
|
||||||
|
# sql = "select * from t1 where ts>='2017-07-14 10:40:10' and ts<'2017-07-14 10:40:20' limit 10 offset 5"
|
||||||
|
# tdSql.waitedQuery(sql, 5, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 15)
|
||||||
|
# tdSql.checkData(4, 1, 19)
|
||||||
|
|
||||||
|
# # have where with other column condition
|
||||||
|
# sql = "select * from t1 where i1>=1 and i1<11 limit 10 offset 5"
|
||||||
|
# tdSql.waitedQuery(sql, 5, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 6)
|
||||||
|
# tdSql.checkData(4, 1, 10)
|
||||||
|
|
||||||
|
# # have where with ts and other column condition
|
||||||
|
# sql = "select * from t1 where ts>='2017-07-14 10:40:10' and ts<'2017-07-14 10:40:50' and i1>=20 and i1<=25 limit 10 offset 5"
|
||||||
|
# tdSql.waitedQuery(sql, 1, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 25)
|
||||||
|
|
||||||
|
# return
|
||||||
|
|
||||||
|
# # test advance
|
||||||
|
# def test_case2(self):
|
||||||
|
# #
|
||||||
|
# # OFFSET merge file data with memory data
|
||||||
|
# #
|
||||||
|
|
||||||
|
# # offset
|
||||||
|
# sql = "select * from t1 limit 10 offset 72000"
|
||||||
|
# tdSql.waitedQuery(sql, 10, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 72000)
|
||||||
|
|
||||||
|
# # each insert one row into NO.0 NO.2 NO.7 blocks
|
||||||
|
# sql = "insert into t1 values (%d, 0) (%d, 2) (%d, 7)"%(self.ts+1, self.ts + 2*3300*1000+1, self.ts + 7*3300*1000+1)
|
||||||
|
# tdSql.execute(sql)
|
||||||
|
# # query result
|
||||||
|
# sql = "select * from t1 limit 10 offset 72000"
|
||||||
|
# tdSql.waitedQuery(sql, 10, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 72000 - 3)
|
||||||
|
|
||||||
|
# # have where
|
||||||
|
# sql = "select * from t1 where ts>='2017-07-14 10:40:10' and ts<'2017-07-22 18:40:10' limit 10 offset 72000"
|
||||||
|
# tdSql.waitedQuery(sql, 10, WAITS)
|
||||||
|
# tdSql.checkData(0, 1, 72000 - 3 + 10 + 1)
|
||||||
|
|
||||||
|
#
|
||||||
|
# add case with filename
|
||||||
|
#
|
||||||
|
tdCases.addWindows(__file__, TDTestCase())
|
||||||
|
tdCases.addLinux(__file__, TDTestCase())
|
Loading…
Reference in New Issue