cleardata模块主要是用于在每次测试之前清除历史执行痕迹,主要代码如下:

from Util.ParseExcel import *
from ProVar.ProjConfigVar import *
from Util.Log import * def clear():
"""清除测试集,测试用例,断言表的上次执行数据"""
info("开始清除最后执行历史————————————————————————")
excel = Excel(ExceldirPath)
excel.set_sheet_by_index(1)
info("开始清除测试集%s" % excel.ws.title)
# 记录已经清除过的sheet
cleared = []
for row_a in excel.get_rows_values()[1:]:
# 清除测试集里面的执行历史
excel.set_sheet_by_index(1)
try:
# 清除执行结果
excel.write_cell_value(int(row_a[0])+1,Test_Suit_execute_result_col_no+1,"")
# 清除执行时间
excel.write_cell_value(int(row_a[0]) + 1, Test_Suit_execute_time_col_no + 1, "")
# 如果有测试集sheet,清除测试集对应的sheet
if not excel.set_sheet_by_name(row_a[Test_Suit_test_step_sheet_name_col_no]) or row_a[Test_Suit_test_step_sheet_name_col_no] in cleared :
continue
# 清除测试用例数据
cleared.append(excel.get_current_sheet_names())
info("开始清除测试用例%s" % excel.ws.title)
for row_b in excel.get_rows_values()[1:]:
# 清除执行返回结果数据
excel.write_cell_value(int(row_b[0]) + 1, Test_Case_executeResult_col_no + 1, "")
# 清除返回结果内容
excel.write_cell_value(int(row_b[0]) + 1, Test_Case_result_content_col_no + 1, "")
# 清除断结果数据
excel.write_cell_value(int(row_b[0]) + 1,Test_Case_assert_result_col_no+1,"")
# 清除提取的变量
excel.write_cell_value(int(row_b[0]) + 1, Test_Case_var_result_col_no + 1, "")
# 清除异常数据
excel.write_cell_value(int(row_b[0]) + 1, Test_Case_exception_col_no + 1, "")
# 清除执行时间
excel.write_cell_value(int(row_b[0]) + 1, Test_Case_execute_time_col_no + 1, "")
# 如果是以断言表格的形式断言结果,清除断言表格的执行结果数据
if not row_b[Test_Case_assert_content_col_no] or not excel.set_sheet_by_name(row_b[Test_Case_assert_content_col_no]) or row_b[Test_Case_assert_content_col_no] in cleared :
continue
cleared.append(excel.get_current_sheet_names())
# 清除断言数据
info("开始清除断言表%s" % excel.ws.title)
for row_c in excel.get_rows_values()[1:]:
# 清除断言结果
excel.write_cell_value(int(row_c[0]) + 1,Assert_result_col_no + 1,"")
# 清除执行时间
excel.write_cell_value(int(row_c[0]) + 1, Assert_time_col_no + 1, "")
except:
continue if __name__ == '__main__':
clear()

共计清除3个模块的数据,分别是测试集,测试用例,断言表3个模块进行清除

20191011-构建我们公司自己的自动化接口测试框架-Util的ClearData模块的更多相关文章

  1. 20191011-构建我们公司自己的自动化接口测试框架-Util的AssertResult模块

    AssertResult主要就是进行结果断言的了,因为断言结果分2种情况,一种是断言词,一种是断言sheet,如果涉及断言sheet,则需要操作excel到对应的断言表断言所有的字段并且书写断言结果主 ...

  2. 20191011-构建我们公司自己的自动化接口测试框架-Util的TestDataHandler模块

    TestDataHandler模块主要是做测试数据的处理,包括转换数据格式和变量参数处理转换数据格式函数: data是数据,data以$()的方式识别变量,如果请求的数据有变量,则将变量用global ...

  3. 20191011-构建我们公司自己的自动化接口测试框架-Util的getTestSuite模块

    getTestSuite主要是用于在testData里面获取测试集以及对应的测试数据,包括2个主要的方法,一个是获取测试集,一个是获取测试集里面要执行的测试用例 获取测试集方法: from Util. ...

  4. 20191011-构建我们公司自己的自动化接口测试框架-Util的htmlreport模块

    生成htmlreport的模块是我在网上随意找的一个版本,主要生成的report包括接口名称,接口url,请求数据,响应数据,断言词,断言结果等 具体的htmlreport代码如下: # -*- en ...

  5. 20191011-构建我们公司自己的自动化接口测试框架-Util的读取excel常用方法模块

    包括获取excel的sheet名字,设定excel的sheet,读excel,写excel等常规操作. from openpyxl import Workbook from openpyxl impo ...

  6. 20191011-构建我们公司自己的自动化接口测试框架-Action的request方法封装

    Action模块 封装接口request方法,根据传入的参数调用不同的请求方法,因为项目特色,我们公司的接口都是get和post方法,所以仅仅封装了get和post方法: import request ...

  7. 20191011-构建我们公司自己的自动化接口测试框架-testrun最重要的模块

    testrun模块呢就是最终自动化测试入口,调用前面封装的各个模块主要流程是: 1. 获取测试集种待执行的测试用例 2. 处理测试用例获取的数据,包括转换数据格式,处理数据的中的关联等 3. 处理完数 ...

  8. 20191011-构建我们公司自己的自动化接口测试框架-ProVar模块

    ProVar模块主要定义测试数据所在目录,以及定义变量和测试数据excel里面的column对应这样后续在进行excel操作的时候直接使用变量即可进行操作,后期excel的column有增删的时候,修 ...

  9. 20191011-构建我们公司自己的自动化接口测试框架-Config配置

    Config模块主要是为了存放的一些其他配置等的一个目录,当前目录存放日志配置文件 ################################################ [loggers] ...

随机推荐

  1. css3 perspective与translateZ变换

    css3中的坐标系,rotateX就是绕着x轴旋转,rotateY就是绕着Y轴旋转,rotateZ就是绕着z轴旋转(也就是xy平面的旋转). perspective属性用来设置视点,在css3的模型中 ...

  2. 2019-06-03 校内python模拟题解(所有非原题)

    一起来女装吧 本题改编自USACO(USA Computing Olympiad) 1.1节的第一题 (感谢lsy同学对本题题面的贡献) 直接计算就好了 chr:将ASCII码转成字符 ord:字符对 ...

  3. 在取变量名的时候,千万不要用new

    这样子是会报错的

  4. Alpha项目冲刺! Day4-产出

    各个成员今日完成的任务 林恩:任务分工,博客撰写,了解安卓环境搭建 杨长元:安卓本地数据库基本建立 李震:学习 胡彤:完善服务端 寇永明:学习 王浩:学习 李杰:学习 各个成员遇到的问题 林恩:为自己 ...

  5. Qt之模型/视图(实时更新数据)

    上两节简单介绍了Qt中对于模型/视图的编程,大部分助手里说的很清楚了,现在就开始实战部分吧! 在实际应用中,视图展示的数据往往并非一成不变的,那么如何实时更新成了一个很重要的问题!功能:(1)添加委托 ...

  6. oracle主键修改级联外键

    举例:修改te_rygj_menu这张表的主键menu_id时,te_rygj_usermenu中的menu_id也跟着修改.利用触发器trigger实现: create or replace tri ...

  7. cv相关博客文章

    收藏些图像处理,机器学习,深度学习方面比较不错的文章,时常学习,复习和膜拜吧... 图像方面(传统CV): 1. SIFT特征 https://www.cnblogs.com/wangguchangq ...

  8. trylock方法

    synchronized 是不占用到手不罢休的,会一直试图占用下去. 与 synchronized 的钻牛角尖不一样,Lock接口还提供了一个trylock方法.trylock会在指定时间范围内试图占 ...

  9. 123457123456#0#-----com.threeapp.HeiXIanBuNengPeng01----黑线不能碰

    -com.threeapp.HeiXIanBuNengPeng01----黑线不能碰

  10. iOS-OC的MRC和ARC内存管理机制

    1. Objective-c语言中的MRC(MannulReference Counting) 在MRC的内存管理模式下,对变量的管理相关的方法有:retain,release和autorelease ...