研发基于GUI的自动化测试框架(V2.0:添加测试报告的生成—excel格式和HTML格式)

import operator,wx,csv,os,datetime,unittest
from HTMLTestRunner import HTMLTestRunner
#测试框架界面类
class UI_test_frame_v2():

    def __init__(self):
        self.app=wx.App()
        self.window=wx.Frame(None,title="测试框架",size=(400,300))
        self.panel=wx.Panel(self.window)
        #定义标签
        self.filebq=wx.StaticText(self.panel,label="配置文件")
        #定义文本框(设置只读)
        self.filetxt=wx.TextCtrl(self.panel,style=wx.TE_READONLY)
        #定义打开按钮
        self.dakai=wx.Button(self.panel,label="打开")
        #定义执行按钮
        self.zhixing=wx.Button(self.panel,label="执行")
        #定义重置按钮
        self.chongzhi=wx.Button(self.panel,label="重置")
        #定义退出按钮
        self.tuichu= wx.Button(self.panel,label="退出")
        #定义测试报告类型单选按钮
        self.biaoge=wx.RadioButton(self.panel,-1,"表格形式报告")
        self.HTML = wx.RadioButton(self.panel,-1,"HTML形式报告")
        self.config=""
    def Box(self):
        #设置一个水平的BoxSizer
        boxsizer1=wx.BoxSizer()
        boxsizer1.Add(self.filebq,proportion=2,flag=wx.ALL,border=10)
        boxsizer1.Add(self.filetxt,proportion=6,flag=wx.ALL,border=10)
        #设置第二个水平的BoxSizer
        boxsizer2= wx.BoxSizer()
        boxsizer2.Add(self.dakai,flag=wx.ALL,border=10)
        boxsizer2.Add(self.zhixing,flag=wx.ALL,border=10)
        boxsizer2.Add(self.chongzhi,flag=wx.ALL,border=10)
        boxsizer2.Add(self.tuichu,flag=wx.ALL,border=10)
        # 设置垂直的BoxSizer
        boxsizer3=wx.BoxSizer(wx.VERTICAL)
        boxsizer3.Add(self.biaoge)
        boxsizer3.Add(self.HTML)
        #设置第二个垂直的BoxSizer41
        boxsizer4=wx.BoxSizer(wx.VERTICAL)
        boxsizer4.Add(boxsizer1,flag=wx.TOP|wx.EXPAND,border=40)
        boxsizer4.Add(boxsizer3,flag=wx.ALL|wx.EXPAND,border=15)
        boxsizer4.Add(boxsizer2)
        #设置boxsizer生效
        self.panel.SetSizer(boxsizer4)

    def open_file(self,event):
        #设置打开文件对话框
        self.dlog=wx.FileDialog(self.panel,message="打开文件",wildcard="*.csv",style=wx.FD_OPEN)
        #当点击确定,把文件信息放入文本框中
        if self.dlog.ShowModal()==wx.ID_OK:
            self.filetxt.AppendText(self.dlog.GetPath())
            self.config=self.dlog.GetPath()

    def run_driver(self,event):
        #对文本框是否为空进行校验
        filetxt=self.filetxt.GetValue()
        if filetxt=="":
            dlg=wx.MessageDialog(None,"请输入文件名和路径","提示信息",wx.YES_DEFAULT|wx.ICON_QUESTION)
            if dlg.ShowModal()==wx.ID_YES:
                dlg.Destroy()
        else:
            #调用测试驱动程序
            driver_obj=driver()
            if self.biaoge.GetValue()==True:
                driver_obj.runtest(self.config)
            elif self.HTML.GetValue()==True:
                driver_obj.runtest1(self.config)
            else:
                dlg=wx.MessageDialog(None,"请选择报告类型","提示信息",wx.YES_DEFAULT|wx.ICON_QUESTION)
                if dlg.ShowModal() == wx.ID_YES:
                    dlg.Destroy()
    #重置
    def clear(self,event):
        self.filetxt.SetValue("")

    #关闭窗体
    def exit(self,event):
        self.window.Close()

    #将按钮和事件绑定
    def event_bind(self):
        self.dakai.Bind(wx.EVT_BUTTON, self.open_file)
        self.zhixing.Bind(wx.EVT_BUTTON, self.run_driver)
        self.chongzhi.Bind(wx.EVT_BUTTON,self.clear)
        self.tuichu.Bind(wx.EVT_BUTTON, self.exit)

    #显示窗体
    def run(self):
        # 激活窗体
        self.window.Show()
        # 运行APP
        self.app.MainLoop()

#测试框架驱动类
class driver():
    #测试驱动执行方法
    def runtest(self,config):
        #获取框架执行开始时间
        starttime=datetime.datetime.now()
        file=open(config,"r")
        table=csv.reader(file)
        #创建测试报告文件并写入标题
        reportobj=report()
        reportobj.create_report()
        # 跳过首行
        header=next(table)
        list=[]
        line=0
        sucnum=0
        errnum=0
        for row in table:
            line+=1
            dic={}
            dic["lujing"]=row[1]
            dic["state"]=row[2]
            dic["bianhao"]=row[0]
            dic["num"] = int(row[3])
            list.append(dic)
        list1=sorted(list,key=operator.itemgetter("num"))
        #print(list1)
        for i in range(0,line):
            n=0
            for j in list1[i].items():
                #print(j)
                n+=1
                if n==1:
                    path=j[1]
                if n==2:
                    state=j[1]
                if n==3:
                    biaohao=j[1]
                if n==4:
                    num=j[1]
                    if state=="yes":
                        strOS=("python "+path)
                        #执行文件
                        os.system(strOS)
                        reportobj.read_result()
                        reportobj.writeconent(biaohao,path,state,num,reportobj.content)
                        sucnum=sucnum+int(reportobj.sucnum)
                        errnum=errnum+int(reportobj.errnum)

        # 获取结束时间
        endtime=datetime.datetime.now()
        difftime=(endtime-starttime).microseconds
        #调用测试报告统计总数和时间
        reportobj.writetotal(sucnum,errnum,difftime)
        print("报告已生成")
    def runtest1(self,config):
        # 打开对应的配置文件,进行读取
        file=open(config,"r")
        table=csv.reader(file)
        # 跳过首行
        header=next(table)
        list=[]
        line=0
        for row in table:
            #print(row)
            line+=1
            dic={}
            dic[row[1]] = row[0]
            dic["num"] = int(row[3])
            dic["state"] = row[2]
            list.append(dic)
        list1=sorted(list, key=operator.itemgetter("num"))
        for i in range(0,line):
            n=0
            for j in list1[i].items():
                #print(j)
                n+=1
                if n==1:
                    fname = j[1]
                    route = j[0]
                if n==3:
                    state=j[1]
                    if state=="yes":
                        suite=unittest.defaultTestLoader.discover(route,pattern=fname)
                        path=(r"E:\testframe\test_report\HTML_report.html")
                        file=open(path,"ab")
                        HTMLTestRunner(stream=file,verbosity=1,title="自动化测试报告",description="chrome",tester="张三").run(suite)
                file.close()


#测试报告类
class report():
    #创建测试报告写入标题栏
    def create_report(self):
        self.path=r"E:\testframe\test_report\report.csv"
        if os.path.exists(self.path):
            os.remove(self.path)
        self.reportfile=open(self.path,"a",newline="")
        self.w=csv.writer(self.reportfile)
        file=open(r"E:\testframe\test_config\test_config.csv","r")
        table=csv.reader(file)
        title=list(table)[0]
        #print(title)
        self.w.writerow(title+["测试结论"])
        self.reportfile.close()

    #写入内容
    def writeconent(self,bianhao,jiaobenlujing,zhuangtai,xunxu,result):
        self.reportfile=open(self.path,"a",newline="")
        self.w=csv.writer(self.reportfile)
        self.w.writerow([bianhao]+[jiaobenlujing]+[zhuangtai]+[xunxu]+[result])
        self.reportfile.close()

    #统计总数和时间
    def writetotal(self,sucnum,errnum,time):
        self.reportfile=open(self.path,"a",newline="")
        self.w=csv.writer(self.reportfile)
        totalnum=sucnum+errnum
        self.w.writerow(["测试用例总数"]+[totalnum]+["条"])
        self.w.writerow(["执行成功用例数"]+[sucnum]+["条"])
        self.w.writerow(["执行失败用例数"]+[errnum]+["条"])
        self.w.writerow(["执行时间"]+[time]+["微秒"])
        self.reportfile.close()

    def add_result(self,content,sucnum,errnum):
        tmp=open(r"E:\testframe\test_report\tmp.txt","w")
        tmp.write(content+"\n")
        tmp.write(sucnum+"\n")
        tmp.write(errnum+"\n")
        tmp.close()

    def read_result(self):
        tmp=open(r"E:\testframe\test_report\tmp.txt","r")
        result=tmp.read().split("\n")
        self.content=result[0]
        self.sucnum=result[1]
        self.errnum=result[2]

if __name__ == '__main__':
    UI_test_frame_obj=UI_test_frame_v2()
    UI_test_frame_obj.Box()
    UI_test_frame_obj.event_bind()
    UI_test_frame_obj.run()

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值