用例读入数据库:

#! /usr/bin/python
# coding:utf-8
import sys,os
from Engine import DataEngine reload(sys)
sys.setdefaultencoding( "utf-8")
from Engine.XlsEngine import XlsEngine_rd
from Engine.SqlEngine import MSSQL
dir=os.getcwd() #文件的绝对路径
#用例文件,casedir=[[xls文件名列表],[xls文件路径列表]]
casedir = DataEngine.getDateCase('.\DataSrc') class ReadCase:
def __init__(self,file):
self.file=file def readCase(self):
data = XlsEngine_rd(self.file)
data.xlrd_open()
sheets=data.xlrd_object.sheets()
result_list=[]
for index in range(len(sheets)):#遍历excel文件的sheets
sheet = data.xlrd_object.sheet_by_index(index)
rows = sheet.nrows
sheet_list=[]
for i in range(rows):
sheet_list.append(sheet.row_values(i))
result_list.append(sheet_list) #单个sheet中的内容列表并入到结果列表中
return result_list class caseToDb():
def __init__(self,host,user,psw,dbname):
self.host=host
self.user=user
self.psw=psw
self.dbname=dbname
self.con = MSSQL(self.host,self.user,self.psw,self.dbname) def InsertInterDefineSql(self,url,Descn,method,FlatType,ResultType):
sql="INSERT INTO[dbo].[InterDefine]([Url],[Descn],[Method],[FlatType],[CreatDate],[EditDate],[VerSion],[IsRun],[ResultType])\
VALUES('%s','%s','%s',%d,GETDATE(),GETDATE(),1,'Y','%s')"%(url,Descn,method,FlatType,ResultType)
self.con.ExecNonQuery(sql) def InsertDataCaseSql(self,InterfaceId,CaseId,AC,Data,IsRun,Expect):
sql="INSERT INTO [dbo].[DataCase]([InterfaceId],[CaseId],[AC],[DataStr],[IsRun],[Expect],[CreatDate],[EditDate])\
VALUES(%d,%d,'%s','%s','%s','%s',GETDATE(),GETDATE())"%(InterfaceId,CaseId,AC,Data,IsRun,Expect)
self.con.ExecNonQuery(sql) def methodId(self,method):
sql="SELECT Id FROM dbo.InterDefine WHERE Method = '%s'"%method
Id=self.con.ExecQuery(sql)
return Id
def dataCaseId(self,caseId,interfaceid):
sql="SELECT Id FROM dbo.Datacase WHERE caseId = %d and interfaceid = %d"%(caseId,interfaceid)
Id=self.con.ExecQuery(sql)
return Id def run():
a=caseToDb('192.168.1.2','release','release','tester')
try:
for xlsindex in range(0,len(casedir[1])):
result_list = ReadCase(casedir[1][xlsindex]).readCase() #依次获取用例文件地址
for i in range(len(result_list)):#len(result_list)为文件中的sheet数量
Descn = result_list[i][0][0]#获取单个sheet中的接口描述
URL = result_list[i][2][0] #获取单个sheet中的接口地址
METHOD = result_list[i][2][1]#获取单个sheet中的接口方法
ArgAccount = int(result_list[i][2][2])#获取接口的参数个数
ResultType = result_list[i][2][3]#获取接口的返回结果格式类型
FlatType = result_list[i][2][4]#获取接口所属端
if len(a.methodId(METHOD)) == 0:#如果接口定义表中无此方法,则插入接口定义参数
a.InsertInterDefineSql(URL,Descn,METHOD,FlatType,ResultType)
for j in range(5,len(result_list[i])):
Data={}
CaseId=int(result_list[i][j][0])#获取用例的id
Run=str(result_list[i][j][1])
Expect=str(result_list[i][j][2+ArgAccount])#获取预期结果
InterfaceId = int(a.methodId(METHOD)[0][0])#查询用例对应的接口在接口定义表中的ID
AC = result_list[i][j][3+ArgAccount]#单条接口用例的检查点描述
if ArgAccount != 0:
for value_index in range(2,2+ArgAccount):
value = result_list[i][j][value_index]
if isinstance(value,(float,int)):
Data[result_list[i][4][value_index]]=int(value)#组成请求参数字典
else:
Data[result_list[i][4][value_index]]=str(value)#组成请求参数字典
else:
Data={}
Data=str(Data).replace("'",'"')
if len(a.dataCaseId(CaseId,InterfaceId)) == 0:#若用例表中无此用例ID和接口id,则插入
a.InsertDataCaseSql(InterfaceId,CaseId,AC,Data,Run,Expect)
except Exception,e:
print(e) # if __name__ == '__main__':
# run()

python 接口自动化测试--代码实现(八)的更多相关文章

  1. python 接口自动化测试--代码实现(七)

    数据库还原脚本: #! /usr/bin/python # coding:utf-8 import time from Engine.SqlEngine import MSSQL COUNT=1 de ...

  2. python接口自动化测试二十八:连接SQL sever操作

    1.中文乱码问题: (1).文件头加上# -*- coding:utf-8 -*- 或者 #coding=utf8 (2).pymssql.connect连接串中charset是要跟你数据库的编码一样 ...

  3. 基于Python接口自动化测试框架+数据与代码分离(进阶篇)附源码

    引言 在上一篇<基于Python接口自动化测试框架(初级篇)附源码>讲过了接口自动化测试框架的搭建,最核心的模块功能就是测试数据库初始化,再来看看之前的框架结构: 可以看出testcase ...

  4. python接口自动化测试二十七:密码MD5加密 ''' MD5加密 ''' # 由于MD5模块在python3中被移除 # 在python3中使用hashlib模块进行md5操作 import hashlib # 待加密信息 str = 'asdas89799,.//plrmf' # 创建md5对象 hl = hashlib.md5() # Tips # 此处必须声明encode # 若写法为

    python接口自动化测试二十七:密码MD5加密   ''' MD5加密 '''# 由于MD5模块在python3中被移除# 在python3中使用hashlib模块进行md5操作import has ...

  5. python接口自动化测试七:获取登录的Cookies

    python接口自动化测试七:获取登录的Cookies,并关联到下一个请求   获取登录的cookies:loginCookies = r.cookies 把获取到的cookies传入请求:cooki ...

  6. Python接口自动化测试框架实战 从设计到开发

    第1章 课程介绍(不要错过)本章主要讲解课程的详细安排.课程学习要求.课程面向用户等,让大家很直观的对课程有整体认知! 第2章 接口测试工具Fiddler的运用本章重点讲解如何抓app\web的htt ...

  7. python 接口自动化测试(三)

    1.WriteIni.py import ConfigParser cf = ConfigParser.ConfigParser() cf.add_section("PC_WSDL" ...

  8. 记录python接口自动化测试--简单总结一下学习过程(第十目)

    至此,从excel文件中循环读取接口到把测试结果写进excel,一个简易的接口自动化测试框架就完成了.大概花了1周的时间,利用下班和周末的时间来理顺思路.编写调试代码,当然现在也还有很多不足,例如没有 ...

  9. python - 接口自动化测试实战 - case1 - 再次优化版

    本次优化: 1.  各级分Package 2.  封装[ReadExcel]类 3.  封装[ReadConfig]类 4.  封装[GetLog]类 5.  引入ddt数据驱动测试,优化测试用例代码 ...

随机推荐

  1. Bootstrap入门(九)组件3:按钮组

    Bootstrap入门(九)组件3:按钮组   先引入本地的CSS文件和JS文件(注:1.bootstrap是需要jQuery支持的.2.需要在<body>当中添加) <link h ...

  2. loadrunner controller:集合点策略

    集合点只有在多用户并发运行的时候才能体现它的作用. Scenario ---> Rendezvous 打开集合点设置界面,如下图所示: 我们可以看到Vusers 列表框里有两个用户,这与我们设置 ...

  3. windows环境下使用git客户端、github和tortoisegit管理项目代码

    一.为什么 为什么不用svn? svn是一个优秀的代码和版本管理工具,使用svn只需要搭建好svn中央仓库,配置本地svn客户端即可,自从google code关闭服务之后,互联网上已经没有非常好的公 ...

  4. C# 结构体 枚举类型

    注意:枚举类型和结构体都属于值类型. 结构体:就是一个自定义的集合,里面可以放各种类型的元素,用法大体跟集合一样. 一.定义的方法: struct student { public int nianl ...

  5. Quartz_理解2

    一.核心概念   Quartz的原理不是很复杂,只要搞明白几个概念,然后知道如何去启动和关闭一个调度程序即可.   1.Job 表示一个工作,要执行的具体内容.此接口中只有一个方法 void exec ...

  6. OSS.Common扩展.Net Standard支持实例分享

    上篇(.Net基础体系和跨框架开发普及)介绍了.Net当前生态下的大概情况,也分享了简单实现的过程,这篇文章就是讲解我的OSS.Common项目扩展.Net Standard 支持的过程,主要集中在: ...

  7. sonarqube+Scanner代码质量管理工具

    本文相关描述基于sonarqube 6.2版本. 下载地址: sonarqube下载网址:https://www.sonarqube.org/downloads/ Scanner下载网址(用于扫描项目 ...

  8. 百度富文本编辑器ueditor在jsp中的使用(ssm框架中的应用)

    折腾了一下午终于把百度富文本编辑器ueditor搞定了!   项目地址:https://github.com/724888/lightnote_new     首先我参考了一个ueditor的demo ...

  9. mybatis入门-第一个程序

    今天,我们就一起来完成mybatis的第一个小demo,使用mybatis对我们的数据库进行一个小小的操作. 需求 根据用户id查询用户的信息. 环境搭建 java环境:jdk1.7版本 开发工具:e ...

  10. UIApplication 和 Appdelegate-----iOS

    正文 一 UIApplication 1.一个UIApplication代表是一个应用程序,而且是单例的.一个程序也只能有一个UIApplication对象 2.获取UIApplication对象: ...