提交 5f5313b2 编写于 作者: B bryanchang0603

[TD-4366] modifying test case

上级 545b6002
......@@ -17,6 +17,7 @@ from util.cases import *
from util.sql import *
from util.dnodes import tdDnodes
from datetime import datetime
import subprocess
##TODO: auto test version is currently unsupported, need to come up with
# an auto test version in the future
......@@ -41,6 +42,23 @@ class TDTestCase:
break
return buildPath
def getTDenginePath(self):
selfPath = os.path.dirname(os.path.realpath(__file__))
if ("community" in selfPath):
projPath = selfPath[:selfPath.find("community")]
else:
projPath = selfPath[:selfPath.find("tests")]
print(projPath)
for root, dirs, files in os.walk(projPath):
if ("sim" in dirs):
print(root)
rootRealPath = os.path.realpath(root)
# if ("packaging" not in rootRealPath):
# buildPath = root[:len(root)-len("/build/bin")]
# break
return rootRealPath
def run(self):
tdSql.prepare()
buildPath = self.getBuildPath()
......@@ -49,6 +67,12 @@ class TDTestCase:
else:
tdLog.info("taosd found in %s" % buildPath)
binPath = buildPath+ "/build/bin/"
TDenginePath = self.getTDenginePath()
print('TD '+ TDenginePath)
if (TDenginePath == ""):
tdLog.exit("TDengine not found!")
else:
tdLog.info("TDengine found in %s" % TDenginePath)
## change system time to 2020/10/20
os.system ('timedatectl set-ntp off')
......@@ -58,7 +82,13 @@ class TDTestCase:
#11 data files should be generated
#vnode at TDinternal/community/sim/dnode1/data/vnode
os.system("%staosdemo -f tools/taosdemoAllTest/manual_change_time_1_1_A.json" % binPath)
input("please the data file. After checking, press enter")
commandArray = ['ls', '-l', f'{TDenginePath}/sim/dnode1/data/vnode/vnode2/tsdb/data']
result = subprocess.run(commandArray, stdout=subprocess.PIPE).stdout.decode('utf-8')
print(result.count('data'))
if result.count('data') != 11:
tdLog.exit('wrong number of files')
else:
tdLog.info("data file number correct")
tdSql.query('select first(ts) from stb_0') #check the last data in the database
tdSql.checkData(0,0,datetime(2020,10,11,0,0,0,0))
......@@ -73,7 +103,13 @@ class TDTestCase:
tdDnodes.start(1)
tdSql.query('select first(ts) from stb_0')
tdSql.checkData(0,0,datetime(2020,10,14,8,0,0,0)) #check the last data in the database
input("please the data file. After checking, press enter")
commandArray = ['ls', '-l', f'{TDenginePath}/sim/dnode1/data/vnode/vnode2/tsdb/data']
result = subprocess.run(commandArray, stdout=subprocess.PIPE).stdout.decode('utf-8')
print(result.count('data'))
if result.count('data') != 7:
tdLog.exit('wrong number of files')
else:
tdLog.info("data file number correct")
......
......@@ -26,6 +26,23 @@ class TDTestCase:
tdLog.debug("start to execute %s" % __file__)
tdSql.init(conn.cursor(), logSql)
def getTDenginePath(self):
selfPath = os.path.dirname(os.path.realpath(__file__))
if ("community" in selfPath):
projPath = selfPath[:selfPath.find("community")]
else:
projPath = selfPath[:selfPath.find("tests")]
print(projPath)
for root, dirs, files in os.walk(projPath):
if ("sim" in dirs):
print(root)
rootRealPath = os.path.realpath(root)
# if ("packaging" not in rootRealPath):
# buildPath = root[:len(root)-len("/build/bin")]
# break
return rootRealPath
def getBuildPath(self):
selfPath = os.path.dirname(os.path.realpath(__file__))
......@@ -43,13 +60,19 @@ class TDTestCase:
return buildPath
def run(self):
#tdSql.prepare()
tdSql.prepare()
buildPath = self.getBuildPath()
if (buildPath == ""):
tdLog.exit("taosd not found!")
else:
tdLog.info("taosd found in %s" % buildPath)
binPath = buildPath+ "/build/bin/"
TDenginePath = self.getTDenginePath()
print('TD '+ TDenginePath)
if (TDenginePath == ""):
tdLog.exit("TDengine not found!")
else:
tdLog.info("TDengine found in %s" % TDenginePath)
## change system time to 2020/10/20
os.system ('timedatectl set-ntp off')
......@@ -58,15 +81,26 @@ class TDTestCase:
#run taosdemo to insert data. one row per second from 2020/10/11 to 2020/10/20
#11 data files should be generated
#vnode at TDinternal/community/sim/dnode1/data/vnode
#os.system("%staosdemo -f tools/taosdemoAllTest/manual_change_time_1_1_A.json" % binPath)
#input("please the data file. After checking, press enter")
commandArray = ['ls', '-l', f'{binPath}sim/dnode1/data/vnode/vnode2/tsdb/data', '|grep', '\'data\'', '|wc', '-l']
os.system("%staosdemo -f tools/taosdemoAllTest/manual_change_time_1_1_A.json" % binPath)
commandArray = ['ls', '-l', f'{TDenginePath}/sim/dnode1/data/vnode/vnode2/tsdb/data']
result = subprocess.run(commandArray, stdout=subprocess.PIPE).stdout.decode('utf-8')
print(result.count('data'))
if result.count('data') != 11:
tdLog.exit('wrong number of files')
else:
tdLog.info("data file number correct")
os.system ('timedatectl set-time 2020-10-25')
os.system("%staosdemo -f tools/taosdemoAllTest/manual_change_time_1_1_B.json" % binPath)
commandArray = ['ls', '-l', f'{TDenginePath}/sim/dnode1/data/vnode/vnode2/tsdb/data']
result = subprocess.run(commandArray, stdout=subprocess.PIPE).stdout.decode('utf-8')
print(result)
# tdSql.query('select first(ts) from stb_0')
# tdSql.checkData(0,0,datetime(2020,10,11,0,0,0,0))
# tdSql.query('select last(ts) from stb_0')
# tdSql.checkData(0,0,datetime(2020,10,20,23,59,59,0))
print(result.count('data'))
if result.count('data') != 7:
tdLog.exit('wrong number of files')
else:
tdLog.info("data file number correct")
tdSql.query('select first(ts) from stb_0')
tdSql.checkData(0,0,datetime(2020,10,14,8,0,0,0))
def stop(self):
tdSql.close()
......
###################################################################
# 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 fabric import Connection
import sys
from util.log import *
from util.cases import *
from util.sql import *
from util.dnodes import tdDnodes
from datetime import datetime
import subprocess
# class VMPnode
# ##TODO: auto test version is currently unsupported, need to come up with
# # an auto test version in the future
# class TDTestCase:
# def init(self, conn, logSql):
# tdLog.debug("start to execute %s" % __file__)
# tdSql.init(conn.cursor(), logSql)
# def run(self):
# return
# def stop(self):
# tdSql.close()
# tdLog.debug("%s alter block manual check finish" % __file__)
# tdCases.addWindows(__file__, TDTestCase())
# tdCases.addLinux(__file__, TDTestCase())
conn = conn = Connection("{}@{}".format('ubuntu', "lyq-q-1"), connect_kwargs={"password": "{}".format('tbase125!')})
conn.run('sudo timedatectl set-ntp off')
conn.run('sudo timedatectl set-time 2020-10-20')
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册