zoukankan      html  css  js  c++  java
  • python 接口自动化测试(四)

    说完了SOAP协议的接口自动化

    该说下http协议的接口测试了

    HttpService.py

    import requests
    import sys
    reload(sys)
    sys.setdefaultencoding( "utf-8" )
    
    
    
    class HttpService():
        def __init__(self,host,url):
            self.host=host
            self.url=url
    
        def httpReq(self,params,method="POST"):
            requesturl=self.host+self.url
            if(method == "POST"):
                resp_data=requests.post(requesturl,params)
            else:
                resp_data=requests.get(requesturl)
            resp=resp_data.text
            return resp
    View Code

    这是http请求的实现类,运用了requests模块

    之后就是在具体的执行文件中调用上面的HttpService.py

    在RunMain.py中添加方法:

    def runHttpTest(ip,list,serviceClass):
        length=len(list)
        #实现控制台输出执行进度
        widgets = [ip+' Progress: ', Percentage(), ' ', Bar(marker=RotatingMarker('>')),
          ' ', ETA()]
        pbar = ProgressBar(widgets=widgets, maxval=length).start()
        for i in range(length):
            pbar.update(i+1)
            try:
                #实例化类的对象
                runhttptest = serviceClass(ip,str(list[i][0]))
                if(str(list[i][2]) == "GET"): #判断http请求的方法
                    test_rep=runhttptest.httpReq(None,"GET")
                    DataEngine.httpGetResultCheck(test_rep,xlw,list,i) #返回结果判断
                else:
                    dict=eval(str(list[i][2]))
                    test_rep=runhttptest.httpReq(dict)
                    DataEngine.httpResultCheck(test_rep,xlw,list,i)
    
            except Exception,e:
                print(str(list[i][1])+"	"+str(e))
                Logging.writeException(e)
        pbar.finish()
    View Code

    由于接口返回结果和SOAP接口的返回结果类型不一致,所以DataEngine.py中的结果处理方法就要做一些扩展,由于时间关系,我这边就直接另写了两个方法进行结果断言处理

    def httpResultCheck(test_rep,xlw,list,xls_row):
        global COUNT_ROWs
        result=test_rep.find(',"status":1',22)
        if(result != -1):
            xlw.write_HttpResult(COUNT_ROWs,list,xls_row,True)
            COUNT_ROWs=COUNT_ROWs+1
        else:
            Logging.writeHttpLog(str(list[xls_row][1]),str(test_rep))
            xlw.write_HttpResult(COUNT_ROWs,list,xls_row,False)
            COUNT_ROWs=COUNT_ROWs+1
    
    def httpGetResultCheck(test_rep,xlw,list,xls_row):
        global COUNT_ROWs
        test_rep=json.loads(test_rep)
        result=test_rep['status']
        if(result == 1):
            xlw.write_HttpResult(COUNT_ROWs,list,xls_row,True)
            COUNT_ROWs=COUNT_ROWs+1
        else:
            Logging.writeHttpLog(str(list[xls_row][1]),str(test_rep))
            xlw.write_HttpResult(COUNT_ROWs,list,xls_row,False)
            COUNT_ROWs=COUNT_ROWs+1
    View Code

    以上就是所有的代码添加:

    执行后结果输出见下图:

    其中执行失败的用例,会以红色醒目标识出来,并在其后输出具体的中文用例描述

    如有问题,欢迎交流

  • 相关阅读:
    【CLR in c#】事件
    IComparer 指定排序。
    【CLR in c#】属性
    C# Aspect-Oriented Programming(AOP) 利用多种模式实现动态代理
    设计模式六大原则(六): 开闭原则(Open Closed Principle)
    设计模式六大原则(五):迪米特法则(Law Of Demeter)
    设计模式六大原则(四):接口隔离原则(Interface Segregation Principle)
    设计模式六大原则(三):依赖倒置原则(Dependence Inversion Principle)
    设计模式六大原则(二):里氏替换原则(Liskov Substitution Principle)
    设计模式六大原则(一):单一职责原则(Single Responsibility Principle)
  • 原文地址:https://www.cnblogs.com/hito/p/5359759.html
Copyright © 2011-2022 走看看