组织架构:

  包括配置文件,反射、文件路径、Excel操作、测试报告生成

case.config

[MODE]
file_name=case_data.xlsx
mode={"register":'all',"login":'all',"recharge":'all'}

tools文件夹里的东西

do_config.py
 # -*- conding:utr-8 -*-
#@Time :2018/11/17 11:21
#@Author:GYP测试
#@File :do_config.py import configparser
class ReadConfig:
def read_config(self,file_name,section,option):
cf=configparser.ConfigParser()
cf.read(file_name,encoding='utf-8')
return cf.get(section,option)
if __name__ == '__main__':
res=ReadConfig().read_config('case.config','MODE','file_name')
print(res)
do_excel.py
 # -*- conding:utr-8 -*-
#@Time :2018/11/17 14:05
#@Author:GYP测试
#@File :do_excel.py
from openpyxl import load_workbook
from tools.do_config import ReadConfig
from tools.project_path import * class Do_Excle:
def __init__(self):
self.file_name = test_data_path
self.sheet_names = eval(ReadConfig().read_config(case_config_path, 'MODE', 'mode'))
def get_header(self):
wb = load_workbook(self.file_name)
for sheet_name in self.sheet_names:
sheet=wb[sheet_name]
header=[]
for i in range(1,sheet.max_column+1):
header.append(sheet.cell(1,i).value)
return header
def Read_Excle(self):
wb = load_workbook(self.file_name)
test_data = []
for sheet_name in self.sheet_names:
sheet = wb[sheet_name]
header = self.get_header()
if self.sheet_names[sheet_name]=='all':
for i in range(2,sheet.max_row+1):
sub_data={}
for j in range(1,sheet.max_column+1):
sub_data[header[j-1]]=sheet.cell(i,j).value
test_data.append(sub_data)
else:
for case_id in self.sheet_names[sheet_name]:
sub_data={}
for j in range(1,sheet.max_column+1):
sub_data[header[j-1]]=sheet.cell(case_id+1,j).value
test_data.append(sub_data)
return test_data
@staticmethod
def write_excel(fiel_name,sheet_name,i,ActaulResult):
wb=load_workbook(fiel_name)
sheet=wb[sheet_name]
sheet.cell(i,8).value=ActaulResult
wb.save(fiel_name)
if __name__ == '__main__':
res=Do_Excle().Read_Excle()
print(res)
print(len(res))

get_data.py

# -*- conding:utf-8 -*-
#@Time :2018/11/19 11:37
#@Author:GYP测试
#@File :get_data.py class Get_Data: cookie=None
http_requests.py
 # -*- conding:utr-8 -*-
#@Time :2018/11/16 21:50
#@Author:GYP测试
#@File :http_requests.py import requests
class Http_Request:
def request(self,method,url,data,cookie=None):
try:
if method == 'post':
res=requests.post(url,data,cookies=cookie)
else:
res=requests.get(url,data,cookies=cookie)
except Exception as e:
print("非法请求,请检查{0}".format(e))
raise e
return res
http_test.py
 # -*- conding:utr-8 -*-
#@Time :2018/11/18 15:00
#@Author:GYP测试
#@File :http_test.py import unittest #单元测试框架 from tools.do_excel import Do_Excle #数据读写
from tools.project_path import * #文件路径
from ddt import ddt,data #数据处理框架
from tools.get_data import Get_Data #反射
from tools.http_requests import Http_Request test_data=Do_Excle().Read_Excle() #读取数据
@ddt
class TestHttp(unittest.TestCase):
@data(*test_data)
def test_api(self,item):
res=Http_Request().request(item['method'],item['url'],eval(item['data']),getattr(Get_Data,'cookie'))
if res.cookies: #利用反射获取cookie的值
setattr(Get_Data,'cookie',res.cookies)
try:
self.assertEqual(str(item['ExpectedResult']),res.json()['code'])
ActaulResult='Pass'
except AssertionError as e:
print('执行用例失败,请检查%s' %e)
ActaulResult = 'Faile'
print("获取到的结果是:{0}".format(res.json()))
finally:
# print(item['case_id'])
Do_Excle.write_excel(test_data_path,item['module'],item['case_id']+1,ActaulResult)
project_path.py
# -*- conding:utr-8 -*-
#@Time :2018/11/17 13:46
#@Author:GYP测试
#@File :project_path.py import os
from tools.do_config import ReadConfig # class Get_Path:
# def get_path(self):
path=os.path.split(os.path.split(os.path.realpath(__file__))[0])[0] case_config_path=os.path.join(path,'conf','case.config') data_file_name=ReadConfig().read_config(case_config_path,'MODE','file_name')
test_data_path=os.path.join(path,'test_data',data_file_name)
html_repot_path=os.path.join(path,'test_result','html_report','test_api.html')
print(case_config_path)
print(html_repot_path)
run.py
 # -*- conding:utr-8 -*-
#@Time :2018/11/16 21:36
#@Author:GYP测试
#@File :run.py import unittest
import HTMLTestRunner
from tools.project_path import * from tools.http_test import TestHttp
suite=unittest.TestSuite() loader=unittest.TestLoader() suite.addTest(loader.loadTestsFromTestCase(TestHttp)) with open(html_repot_path,'wb') as file:
runner=HTMLTestRunner.HTMLTestRunner(
stream=file,
title='这个是接口自动化的测试报告',
description='我来测试哦!',
tester='GYP')
runner.run(suite)
 
 

python接口自动化1的更多相关文章

  1. Python接口自动化——soap协议传参的类型是ns0类型的要创建工厂方法纪要

    1:在Python接口自动化中,对于soap协议的xml的请求我们可以使用Suds Client来实现,其soap协议传参的类型基本上是有2种: 第一种是传参,不需要再创建啥, 第二种就是ns0类型的 ...

  2. python接口自动化(十)--post请求四种传送正文方式(详解)

    简介 post请求我在python接口自动化(八)--发送post请求的接口(详解)已经讲过一部分了,主要是发送一些较长的数据,还有就是数据比较安全等.我们要知道post请求四种传送正文方式首先需要先 ...

  3. python接口自动化-Cookie_绕过验证码登录

    前言 有些登录的接口会有验证码,例如:短信验证码,图形验证码等,这种登录的验证码参数可以从后台获取(或者最直接的可查数据库) 获取不到也没关系,可以通过添加Cookie的方式绕过验证码 前面在“pyt ...

  4. python接口自动化28-requests-html爬虫框架

    前言 requests库的好,只有用过的人才知道,最近这个库的作者又出了一个好用的爬虫框架requests-html.之前解析html页面用过了lxml和bs4, requests-html集成了一些 ...

  5. python接口自动化-参数化

    原文地址https://www.cnblogs.com/yoyoketang/p/6891710.html python接口自动化 -参数关联(一)https://www.cnblogs.com/11 ...

  6. python接口自动化 -参数关联(一)

    原文地址https://www.cnblogs.com/yoyoketang/p/6886610.html 原文地址https://www.cnblogs.com/yoyoketang/ 原文地址ht ...

  7. python接口自动化20-requests获取响应时间(elapsed)与超时(timeout)

    前言 requests发请求时,接口的响应时间,也是我们需要关注的一个点,如果响应时间太长,也是不合理的. 如果服务端没及时响应,也不能一直等着,可以设置一个timeout超时的时间 关于reques ...

  8. python接口自动化24-有token的接口项目使用unittest框架设计

    获取token 在做接口自动化的时候,经常会遇到多个用例需要用同一个参数token,并且这些测试用例跨.py脚本了. 一般token只需要获取一次就行了,然后其它使用unittest框架的测试用例全部 ...

  9. python接口自动化6-重定向(Location)

    前言 某屌丝男A鼓起勇气向女神B打电话表白,女神B是个心机婊觉得屌丝男A是好人,不想直接拒绝于是设置呼叫转移给闺蜜C了,最终屌丝男A和女神闺蜜C表白成功了,这种场景其实就是重定向了. 一.重定向 1. ...

  10. python接口自动化5-Json数据处理

    前言 有些post的请求参数是json格式的,这个前面第二篇post请求里面提到过,需要导入json模块处理. 一般常见的接口返回数据也是json格式的,我们在做判断时候,往往只需要提取其中几个关键的 ...

随机推荐

  1. Laravel底层实现原理系列

    Laravel 从学徒到工匠精校版 地址:https://laravelacademy.org/laravel-from-appreciate-to-artisan

  2. 【转】BTree,B-Tree,B+Tree,B*Tree

    B树: 即二叉搜索树: 1.所有非叶子结点至多拥有两个儿子(Left和Right): 2.所有结点存储一个关键字: 3.非叶子结点的左指针指向小于其关键字的子树,右指针指向大于其关键字的子树: 如: ...

  3. 一、docker的原理

    一.docker解决什么问题: 高效的利用资源 应用之间相互隔离 应用之间不能发生资源抢占,每个应用只能使用事先注册申请的资源. 环境封装,利于迁移 二.docker的原理: 1.Namespaces ...

  4. java实现八大排序算法

    Arrays.sort() 采用了2种排序算法 -- 基本类型数据使用快速排序法,对象数组使用归并排序. java的Collections.sort算法调用的是归并排序,它是稳定排序 方法一:直接插入 ...

  5. 使用原生 python 造轮子搭建博客

    这篇用来 记录一个 从零开始的 博客搭建,希望坚持下去,因为python 开发效率令人发指,所以会原生从零写 ORM ,Web 框架 前提是打好 异步 io 的基础, 使用异步,有一点要谨记,一旦开始 ...

  6. SQL 耗时优化

    Ø  简介 在平常的开发中,我们经常会编写各种各样的 SQL 语句,比如:SQL 查询.存储过程.或者视图查询等.当我们编写的 SQL 语句比较复杂,或者表的数据量比较大,导致查询超时!这时,就要去分 ...

  7. Exp5 MSF基础应用 20164314

    一.实践内容 本实践目标是掌握metasploit的基本应用方式,重点常用的三种攻击方式的思路.具体需要完成: 1.一个主动攻击实践,如ms08_067; (成功) 2.一个针对浏览器的攻击,如ms1 ...

  8. CPU或以太网模块重启DHCP请求

    最近,带了一个实习生,一天: 他:师傅,PLC如何首次分配IP地址啊? 我:不是教过你了吗? 他:我怎么用BOOTP软件,半天没有反应啊? 我:..... 原来,他做实验的CPU已经被分配IP地址了, ...

  9. asp.net webapi 获取报文体的问题

    用这种方法: var data=await Request.Content.ReadAsStringAsync(); 一般都无法获取到内容.原因是内部的流对象已经到了最后面.要获取到里面的需要把流的位 ...

  10. axios formData提交数据 && axios设置charset无效???

    但是这样会出现一个问题,什么问题呢? 我设置了请求头编码utf-8,但是没生效 content-type里面没有出现utf-8???????查了很多资料,说这是axios固有的bug,我....... ...