2023Python自动化测试5种模型(建议收藏)

2023-11-03 10:52

本文主要是介绍2023Python自动化测试5种模型(建议收藏),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、前言

在自动化测试中,我们往往将自动化脚本都归纳属于哪种框架模型,比如关键字驱动模型等。

本篇将列举实际自动化测试中,Python 自动化测试的五种模型:线性模型、模块化驱动模型、数据驱动模型、关键字驱动模型、行为驱动模型。

2、线性模型

通过录制或编写脚本,一个脚本完成一个场景(一组完整功能操作),通过对脚本的回放进行自动化测试。

脚本代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-import time
from selenium import webdriverdriver = webdriver.Chrome()
driver.maximize_window()
driver.implicitly_wait(30)driver.get('https://www.baidu.com/')
time.sleep(1)
driver.find_element_by_id('kw').send_keys('自动化测试')
time.sleep(1)
driver.find_element_by_id('su').click()
time.sleep(1)
driver.quit()

3、模块化驱动模型

将脚本中重复可复用的部分拿出来写成一个公共的模块,需要的时候就调用它,这样可以大幅提高测试人员编写脚本的效率。

框架目录:

1、config 存放配置文件。

例如 base_data.json 文件,存放测试地址。

{"url": "https://www.baidu.com/"
}

2、data 存放测试数据。

3、drivers 存放浏览器驱动文件。

4、report 存放执行完成后的测试报告。

5、test 存放测试用例。

(1)case 测试用例步骤。

例如 testSearch.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-import time
import os
import unittest
from selenium import webdriver
from AutomatedTestModel.ModularDriverModel.utils.ReadConfig import ReadConfig
from AutomatedTestModel.ModularDriverModel.test.pages.searchPage import SearchPageclass TestSearch(unittest.TestCase):def setUp(self):self.driver = webdriver.Chrome()self.driver.maximize_window()self.driver.implicitly_wait(30)def tearDown(self):self.driver.quit()def get_url(self):current_path = os.path.abspath((os.path.dirname(__file__)))data = ReadConfig().read_json(current_path + "/../../config/base_data.json")return data['url']def test_search(self):url = self.get_url()self.driver.get(url)time.sleep(1)search = SearchPage(self.driver)search.search('自动化测试')if __name__ == '__main__':unittest.main()

(2)common 存放公共的方法等。

(3)pages 存放页面元素与页面操作。

例如 searchPage.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-import timeclass SearchPage:def __init__(self, driver):self.driver = driverdef search_element(self):self.kw = self.driver.find_element_by_id('kw')self.su = self.driver.find_element_by_id('su')def search(self, data):self.search_element()self.kw.send_keys(data)time.sleep(1)self.su.click()

(4)runner 存放运行脚本。

例如 main.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-import os
import time
import unittest
from AutomatedTestModel.ModularDriverModel.utils.HwTestReport import HTMLTestReportclass Main:def get_all_case(self):current_path = os.path.abspath(os.path.dirname(__file__))case_path = current_path + '/../case/'discover = unittest.defaultTestLoader.discover(case_path, pattern="test*.py")print(discover)return discoverdef set_report(self, all_case, report_path=None):if report_path is None:current_path = os.path.abspath(os.path.dirname(__file__))report_path = current_path + '/../../report/'else:report_path = report_path# 获取当前时间now = time.strftime('%Y{y}%m{m}%d{d}%H{h}%M{M}%S{s}').format(y="年", m="月", d="日", h="时", M="分", s="秒")# 标题title = u"搜索测试"# 设置报告存放路径和命名report_abspath = os.path.join(report_path, title + now + ".html")# 测试报告写入with open(report_abspath, 'wb') as report:runner = HTMLTestReport(stream=report,verbosity=2,images=True,title=title,tester='Meng')runner.run(all_case)def run_case(self, report_path=None):all_case = self.get_all_case()self.set_report(all_case, report_path)if __name__ == '__main__':Main().run_case()

6、utils 存放公共方法。

例如导出报告样式、读取配置文件等。

7、run.py 运行脚本。

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# 软件测试from AutomatedTestModel.ModularDriverModel.test.runner.main import Mainif __name__ == '__main__':Main().run_case()

运行后的测试报告。

4、数据驱动模型

该模型会根据数据的变化而引起测试结果的改变,这显然是一个非常高级的概念和想法。简单地说,该模型是一种数据的参数化呈现,即通过输入不同的参数来驱动程序执行,输出不同的测试结果。

框架目录:

1、case 存放测试用例步骤。

2、common 存放公共的方法等。

如读取 Excel 方法、生成报告等样式。

3、data 存放测试数据与预期结果。

4、report 存放执行完成后的测试报告。

打开报告效果。

5、RunMain.py 运行脚本。

#!/usr/bin/env python
# -*- coding: utf-8 -*-import os, time, unittest
from AutomatedTestModel.DataDrivenModeling.common.HwTestReport import HTMLTestReportclass RunMain:def get_all_case(self):case_path = os.getcwd()discover = unittest.defaultTestLoader.discover(case_path,pattern="Test*.py")print(discover)return discoverdef set_report(self, all_case, report_path=None):if report_path is None:current_path = os.path.abspath(os.path.dirname(__file__))report_path = current_path + '/report/'else:report_path = report_path# 获取当前时间now = time.strftime('%Y{y}%m{m}%d{d}%H{h}%M{M}%S{s}').format(y="年", m="月", d="日", h="时", M="分", s="秒")# 标题title = u"搜索测试"# 设置报告存放路径和命名report_abspath = os.path.join(report_path, title + now + ".html")# 测试报告写入with open(report_abspath, 'wb') as report:runner = HTMLTestReport(stream=report,verbosity=2,images=True,title=title,tester='Meng')runner.run(all_case)def run_case(self, report_path=None):all_case = self.get_all_case()self.set_report(all_case, report_path)if __name__ == "__main__":RunMain().run_case()

5、关键字驱动模型

这是一种通过关键字的改变而引起测试结果改变的功能自动化测试模型。QTP(UFT)、Robot Framework 等都是以关键字驱动为主的自动化测试工具,这类工具典型的特征就是具备一套易用的可视化界面,测试人员需要做的就是将测试脚本按照“填表格”的方式填入,并考虑三个问题就可以了:我要做什么?对谁做?怎么做?

框架目录:

1、action 主要存放动作事件、元素操作。

(1)Action.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-from AutomatedTestModel.KeywordDrivenModel.common.ExcelUtil import ExcelUtil
from AutomatedTestModel.KeywordDrivenModel.action.ElementOperation import ElementOperationclass Action:def __init__(self):self.element = ElementOperation()def set_value(self, element, action, parameter=None):if element == "browser":return self.element.browser_operate(action, parameter)elif element == "time":return self.element.time_operate(action, parameter)elif element is None or element == "":returnelse: # 如果不是其他的关键字,则默认为定位的元素return self.element.element_operate(element, action, parameter)def case_operate(self, excel, sheet):all_case = ExcelUtil(excel_path=excel, sheet_name=sheet).get_case()for case in all_case:self.set_value(case[0], case[1], case[2])if __name__ == '__main__':excel = '../case/casedata.xlsx'Action().case_operate(excel=excel, sheet='搜索')

(2)ElementOperation.py

2、case 存放测试用例步骤。

3、common 存放公共的方法等。

如读取 Excel 方法等。

4、RunMain.py 运行脚本。

#!/usr/bin/env python
# -*- coding: utf-8 -*-from AutomatedTestModel.KeywordDrivenModel.action.Action import Actionif __name__ == '__main__':excel = 'case/casedata.xlsx'a = Action().case_operate(excel=excel, sheet='搜索')

6、行为驱动模型

行为驱动开发(Behave Driven Development,简称BDD),即从用户的需求出发强调系统行为。通过将BDD借鉴到自动化测试中,便产生了行为驱动测试模型,这种模型通过使用自然描述语言确定自动化测试脚本,其优点是可使用自然语言编写测试用例。

框架目录:

1、features 存放用例。

(1)steps 存放步骤

#!/usr/bin/env python
# -*- coding: utf-8 -*-import time
from behave import *@When('打开访问的网页 "{url}"')
def step_open(context, url):context.driver.get(url)time.sleep(5)@Then('进入百度网站成功')
def step_assert_open(context):title = context.driver.titleassert title == "百度一下,你就知道"@When('输入 "{searchdata}"')
def step_search(context, searchdata):searchdata_element = context.driver.find_element_by_id('kw')searchdata_element.send_keys(searchdata)time.sleep(1)submit_btn = context.driver.find_element_by_id('su')submit_btn.click()@Then('获取标题')
def step_assert_search(context):success_message = context.driver.titleassert success_message == "自动化测试_百度搜索"

(2)environment.py 存放变量

(3)search.feature 存放行为

2、report、result 存放报告

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

这篇关于2023Python自动化测试5种模型(建议收藏)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/337684

相关文章

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

Python自动化批量重命名与整理文件系统

《Python自动化批量重命名与整理文件系统》这篇文章主要为大家详细介绍了如何使用Python实现一个强大的文件批量重命名与整理工具,帮助开发者自动化这一繁琐过程,有需要的小伙伴可以了解下... 目录简介环境准备项目功能概述代码详细解析1. 导入必要的库2. 配置参数设置3. 创建日志系统4. 安全文件名处

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Redis 配置文件使用建议redis.conf 从入门到实战

《Redis配置文件使用建议redis.conf从入门到实战》Redis配置方式包括配置文件、命令行参数、运行时CONFIG命令,支持动态修改参数及持久化,常用项涉及端口、绑定、内存策略等,版本8... 目录一、Redis.conf 是什么?二、命令行方式传参(适用于测试)三、运行时动态修改配置(不重启服务

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可