function_arithmetic.py 3.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
###################################################################
#           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 taos
from util.log import *
from util.cases import *
from util.sql import *
import numpy as np


class TDTestCase:
    def init(self, conn, logSql):
        tdLog.debug("start to execute %s" % __file__)
        tdSql.init(conn.cursor())

        self.rowNum = 10
        self.ts = 1537146000000
        
    def run(self):
        tdSql.prepare()

        tdSql.execute('''create table test(ts timestamp, col1 int, col2 int) tags(loc nchar(20))''')
        tdSql.execute("create table test1 using test tags('beijing')")
        tdSql.execute("create table test2 using test tags('shanghai')")
        for i in range(self.rowNum):
            tdSql.execute("insert into test1 values(%d, %d, %d)" % (self.ts + i, i + 1, i + 1))
            tdSql.execute("insert into test2 values(%d, %d, %d)" % (self.ts + i, i + 1, i + 1))

        # arithmetic verifacation
        tdSql.query("select 0.1 + 0.1 from test")
        tdSql.checkRows(self.rowNum * 2)
        for i in range(self.rowNum * 2):
            tdSql.checkData(0, 0, 0.20000000)
        
        tdSql.query("select 4 * avg(col1) from test")
        tdSql.checkRows(1)        
        tdSql.checkData(0, 0, 22)

        tdSql.query("select 4 * sum(col1) from test")
        tdSql.checkRows(1)        
        tdSql.checkData(0, 0, 440)

        tdSql.query("select 4 * avg(col1) * sum(col2) from test")
        tdSql.checkRows(1)        
        tdSql.checkData(0, 0, 2420)

        tdSql.query("select 4 * avg(col1) * sum(col2) from test group by loc")
        tdSql.checkRows(2)
        tdSql.checkData(0, 0, 1210)
        tdSql.checkData(1, 0, 1210)

        tdSql.error("select avg(col1 * 2)from test group by loc")
        
        # add testcases for TD-10515---> test arithmetic function with blank table 
        tdSql.execute("create table test3 using test tags('heilongjiang')")
        sql_list = [
            "select 0.1 + 0.1 from test3",
            "select 0.1 - 0.1 from test3",
            "select 0.1 * 0.1 from test3",
            "select 0.1 / 0.1 from test3",
            "select 4 * avg(col1) from test3",
            "select 4 * sum(col1) from test3",
            "select 4 * avg(col1) * sum(col2) from test3",
            "select max(col1) / 4 from test3",
            "select min(col1) - 4 from test3",
            "select min(col1) + max(col1) * avg(col1) / sum(col1) + 4 from test3"
        ]
        for sql in sql_list:
            tdSql.query(sql)
            tdSql.checkRows(0)

    def stop(self):
        tdSql.close()
        tdLog.success("%s successfully executed" % __file__)

tdCases.addWindows(__file__, TDTestCase())
tdCases.addLinux(__file__, TDTestCase())