组织架构:
包括配置文件,反射、文件路径、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的更多相关文章
-
Python接口自动化——soap协议传参的类型是ns0类型的要创建工厂方法纪要
1:在Python接口自动化中,对于soap协议的xml的请求我们可以使用Suds Client来实现,其soap协议传参的类型基本上是有2种: 第一种是传参,不需要再创建啥, 第二种就是ns0类型的 ...
-
python接口自动化(十)--post请求四种传送正文方式(详解)
简介 post请求我在python接口自动化(八)--发送post请求的接口(详解)已经讲过一部分了,主要是发送一些较长的数据,还有就是数据比较安全等.我们要知道post请求四种传送正文方式首先需要先 ...
-
python接口自动化-Cookie_绕过验证码登录
前言 有些登录的接口会有验证码,例如:短信验证码,图形验证码等,这种登录的验证码参数可以从后台获取(或者最直接的可查数据库) 获取不到也没关系,可以通过添加Cookie的方式绕过验证码 前面在“pyt ...
-
python接口自动化28-requests-html爬虫框架
前言 requests库的好,只有用过的人才知道,最近这个库的作者又出了一个好用的爬虫框架requests-html.之前解析html页面用过了lxml和bs4, requests-html集成了一些 ...
-
python接口自动化-参数化
原文地址https://www.cnblogs.com/yoyoketang/p/6891710.html python接口自动化 -参数关联(一)https://www.cnblogs.com/11 ...
-
python接口自动化 -参数关联(一)
原文地址https://www.cnblogs.com/yoyoketang/p/6886610.html 原文地址https://www.cnblogs.com/yoyoketang/ 原文地址ht ...
-
python接口自动化20-requests获取响应时间(elapsed)与超时(timeout)
前言 requests发请求时,接口的响应时间,也是我们需要关注的一个点,如果响应时间太长,也是不合理的. 如果服务端没及时响应,也不能一直等着,可以设置一个timeout超时的时间 关于reques ...
-
python接口自动化24-有token的接口项目使用unittest框架设计
获取token 在做接口自动化的时候,经常会遇到多个用例需要用同一个参数token,并且这些测试用例跨.py脚本了. 一般token只需要获取一次就行了,然后其它使用unittest框架的测试用例全部 ...
-
python接口自动化6-重定向(Location)
前言 某屌丝男A鼓起勇气向女神B打电话表白,女神B是个心机婊觉得屌丝男A是好人,不想直接拒绝于是设置呼叫转移给闺蜜C了,最终屌丝男A和女神闺蜜C表白成功了,这种场景其实就是重定向了. 一.重定向 1. ...
-
python接口自动化5-Json数据处理
前言 有些post的请求参数是json格式的,这个前面第二篇post请求里面提到过,需要导入json模块处理. 一般常见的接口返回数据也是json格式的,我们在做判断时候,往往只需要提取其中几个关键的 ...
随机推荐
-
简单Java算法程序实现!斐波那契数列函数~
java编程基础--斐波那契数列 问题描述:一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 思路:可能出现的情况:(1) n=1 ,一种方法 ;(2)n=2 ...
-
c#:如何处理对对象进行深度拷贝
/// <summary> /// 对对象进行深度拷贝 /// </summary> /// <param name="obj"></pa ...
-
CF Soldier and Cards (模拟)
Soldier and Cards time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...
-
TODOList项目
[ 爱上Swift]十二期:TODOList项目 好久没有写Swift甚是想念,Swift,Xcode都比较稳定了写个程序熟悉一下,当然时间原因都是小Demo,废话不多说先上图. 下面是跑起来之后 ...
-
批量找注入 python3+sqlmap结合
注入一直都是用sqlmap 导致本来就不怎么精通的手工注入现在就忘的一干二净 想实战练习 却一时又找不到有注入的网站 于是便有了这篇文章 想找个批量获取域名链接的工具 但都是只是获取域名而 ...
-
[原创] debian 9.3 搭建Jira+Confluence+Bitbucket项目管理工具(三) -- 安装confluence 6.6.1
[原创] debian 9.3 搭建Jira+Confluence+Bitbucket项目管理工具(三) -- 安装confluence 6.6.1 有了安装Jira的经验, 这次再安装conflue ...
-
Less常用知识点
上篇文章介绍了如何安装Less,我们将所有东西都写在.less里面,最后通过命令将.less转换成.css文件,就可以放入到项目里用了.今天了解一些less常用知识点. 1.变量:声明两个变量,一个是 ...
-
周强201771010141《面向对象程序设计Java》第八周学习总结
一.理论知识学习部分 Java为了克服单继承的缺点,Java使用了接口,一个类可以实现一个或多个接口. 接口体中包含常量定义和方法定义,接口中只进行方法的声明,不提供方法的实现. 类似建立类的继承关系 ...
-
Eclipse------使用Debug As时报错java.lang.IllegalStateException: Failed to read Class-Path attribute from manifest of jar file:/XXX
报错信息: java.lang.IllegalStateException: Failed to read Class-Path attribute from manifest of jar file ...
-
【CF757G】Can Bash Save the Day? 可持久化点分树
[CF757G]Can Bash Save the Day? 题意:给你一棵n个点的树和一个排列${p_i}$,边有边权.有q个操作: 1 l r x:询问$\sum\limits_{i=l}^r d ...