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)
网友评论