使用unittest进行swagger-ui接口测试-测试用例及报告

import requests

#http://docs.python-requests.org/zh_CN/latest/user/quickstart.html

import unittest

import json

from  HTMLTestRunner import  HTMLTestRunner


classTestSwagger(unittest.TestCase):

    def  setUp(self):

        self.url1='https://petstore.swagger.io/v2/pet/988'

        self.url2='https://petstore.swagger.io/v2/pet'

#以后数据需要从外面导入,这样才灵活

        self.data2={

"id":988,

"category": {

"id":99,

"name":"cou_cou"

                  },

"name":"doggie",

"photoUrls": [

"string"

                  ],

"tags": [

                    {

"id":0,

"name":"leimeng"

                    }

                  ],

"status":"available"

                }

self.data2['tags'][0]['id']=7

print(self.data2)

    #@unittest.skip

    deftest_get_pet_2by_id(self):

        res=requests.get(url=self.url1)

        #print(res.json())

        result=res.json()

        #indent是缩进4个格式,将json转成dict时,看着就好看一些容易定位。

        print(json.dumps(res.json(),indent=4))

        #判断协议是否正确,200表示响应成功,但并不代表响应中的数据和内容也成功。只是有响应。

        #断言(预期结果,实际结果)

        self.assertEqual(200, res.status_code)

        #判断业务和数据层,其他就是用户的需求是否满足要求,验证什么根据需求验。

        self.assertEqual(988, result['id'])

        self.assertEqual('doggie', result['name'])

        self.assertEqual('leimeng', result['tags'][0]['name'])

        #验证接口层性能方面是否满足要求

        #self.assertLessEqual(1, re.elapsed.total_seconds(), '响应时间超1秒了')

        #编写的测试用例目前是有顺序的,先是协议层,再是数据层,最后是性能安全等方面


        #@unittest.skip

        deftest_post_pet_1add_store(self):

            #json参数的意思是如果不是json格式,它会帮你转成json格式, 如果响应时间超过预期值,测试用例失败

            res=requests.post(url=self.url2,json=self.data2,timeout=1)

            print(res.json())

if__name__=='__main__':

        #unittest.main()

#建立一个套件,

        suite=unittest.TestSuite()

#这是一个例子,通过makeSuite(类名)把整个类所有方法都加上

        #suite.addTest(unittest.makeSuite(TestSwagger))

        #cur_path = os.path.abspath(os.curdir)

        file_path='html_report.html'

#是对文件进行操作,打开文件,写入东西,第一参数是文件地址和文件名,第二参数是对文件什么操作

#是写w 或是r 的操作。 别名是f

        with open(file_path,'wb') as f:

#是通过类名方法名加一个或多个用例到套件中

            suite.addTest(TestSwagger('test_get_pet_2by_id'))

#使用htmltestrunner,流--将文件名,verbosity显示信息级别复杂库,原意唠叨,标题,描述

            runner=HTMLTestRunner(stream=f,verbosity=1,title='**测试报告',description='**测试用例')

#运行套件

        runner.run(suite)


你可能感兴趣的:(使用unittest进行swagger-ui接口测试-测试用例及报告)