自动化测试中的关键字驱动

本文介绍了使用Python实现关键字驱动的自动化测试原理,利用getattr实现反射机制,通过配置文件存储测试步骤。在pytest框架下,收集并执行测试用例,确保了测试用例的动态加载和前后关联性参数的处理。StepMethod类是关键字驱动的核心,它根据excel中的方法调用相应代码。
摘要由CSDN通过智能技术生成

关键字驱动

通过关键字做对应的动作,很早的自动化测试工具都走的这个方向,比如RobotFramework,QTP等,这里简单介绍一下关键字驱动的原理

python 实现关键字驱动

python实现关键字驱动,主要用到的是python中的反射getattr

getattr:实现反射机制

getattr可以通过字符串获取方法实例。这样,你就可以把一个类可能要调用的方法放在配置文件里,在需要的时候动态加载。

配置文件

在excel中,输入自己的测试步骤,如下
在这里插入图片描述

思路如下

在这里插入图片描述

收集测试用例

写一个方法收集测试用例概要信息,收集后格式如下

feature(当前sheet的名称),story,case_name后续添加到allure报告中去
case_loc为测试用例步骤在excel中的位置,主要用到前两个,对应的为测试用例步骤起始行,结束行
在这里插入图片描述
代码如下:OperaExcel()是自己封装的一个操作excel的类


def collect_test_cases():
    '''
    获取excel表格中所有测试用例标题及位置
    :return:  excel 表格中的测试用例列表
    '''
    excel= OperaExcel()
    sheet_names=excel.get_sheet_names()
    _list=[]
    for name in sheet_names:
        merged_cells=excel.get_merged_cells(name)
        module_locs=list(filter(lambda x:x[2]==0 ,merged_cells))
        case_locs=list(filter(lambda x:x[2]==1 ,merged_cells))
        for module_loc in module_locs:
            for case_loc in case_locs:
                if (module_loc[0] <= case_loc[0] <module_loc[1]):
                    data = {
   "feature": name}
                    data["story"]=excel.get_cell(name,module_loc[0],0)
                    data[
  • 5
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值