Pytest框架Fixture+Parametrize参数化应用篇

2023-10-23 16:59

本文主要是介绍Pytest框架Fixture+Parametrize参数化应用篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面三节概要的讲述了Pytest框架Fixture应用以及Parametrize参数化应用,今天也拿实例列举进行将2个方法综合使用

Python自动化测试 | Pytest之参数化

Pytest | 参数化处理三种类型 [ 列表、元组、字典]

Python自动化测试 | Pytest之fixture

就拿小编实际项目中的管理台登录界面测试作为案例,代码浅而易学,前半部分是Fixture,后半部分是Parametrize

# coding=utf-8
# authou:shichaoimport pytest
from selenium import webdriver
import os, time
# 以上为模块调用# 定义个入参的元组列表
test_user = [(2019060601, 123456), (2019060602, 234567), (2019060603, 345678)]
driver = webdriver.Chrome()
# 定义一个全局驱动@pytest.fixture(scope='module', autouse=True) #使用fix方法,类型为模块,默认自动执行
def test_pro_ulr():driver.maximize_window() #最大化浏览器url = 'https://xfdj.pagoda.com.cn' driver.get(url) # 访问管理台time.sleep(3) #显示等待3s# 用yield关键字呼唤teardown操作,关闭浏览器yieldtime.sleep(5)driver.quit()@pytest.mark.parametrize('user, passwd', test_user) #使用par 参数取名为user、passwd ;入参为上面定义的元组
def test_login_01(test_pro_ulr, user, passwd):time.sleep(1)driver.find_element_by_xpath('//*[@id="app"]/div/div[2]/div[2]/div/div[1]/div').click()time.sleep(1)driver.find_element_by_name('username').send_keys(user)time.sleep(1) #入参:用户名driver.find_element_by_name('password').send_keys(passwd)time.sleep(1) # 入参:密码driver.find_element_by_xpath('//*[@id="app"]/div/div[2]/div[2]/div/form/div[3]/input').click()time.sleep(1) # 点击登录text = driver.find_element_by_xpath('//*[@id="app"]/div/div[2]/div[2]/div/form/div[3]/input').textassert ('登录', text)  # 输入错误的账号密码,断言是否还在登录页面if __name__ == '__main__':pytest.mark('-s', 'test_param04.py')

看看执行代码后的效果,会依次将 test_user  三组测试用例带入登录页面执selenium执行driver模拟不同的登录用户名/密码进行多次登录,执行完毕

test_user = [(2019060601, 123456),(2019060604, 234567),(2019060603, 345678)
]

以上几个实例,就是我们测试中使用的pytest测试框架测试用例参数化,想登录这种前置/公共配置可以直接创建一个conftest.py文件进行存放,case就存放在用例集中

近期在学习pytest框架过程种, 会将每日一点小小的积累,总结,复习,分享,有好的学习资料大家可以进行分享

对于Pytest你们现在在实际项目中有应用吗?

这篇关于Pytest框架Fixture+Parametrize参数化应用篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

电脑系统Hosts文件原理和应用分享

《电脑系统Hosts文件原理和应用分享》Hosts是一个没有扩展名的系统文件,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应... Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应

CSS 样式表的四种应用方式及css注释的应用小结

《CSS样式表的四种应用方式及css注释的应用小结》:本文主要介绍了CSS样式表的四种应用方式及css注释的应用小结,本文通过实例代码给大家介绍的非常详细,详细内容请阅读本文,希望能对你有所帮助... 一、外部 css(推荐方式)定义:将 CSS 代码保存为独立的 .css 文件,通过 <link> 标签

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件

C#通过进程调用外部应用的实现示例

《C#通过进程调用外部应用的实现示例》本文主要介绍了C#通过进程调用外部应用的实现示例,以WINFORM应用程序为例,在C#应用程序中调用PYTHON程序,具有一定的参考价值,感兴趣的可以了解一下... 目录窗口程序类进程信息类 系统设置类 以WINFORM应用程序为例,在C#应用程序中调用python程序

Java应用如何防止恶意文件上传

《Java应用如何防止恶意文件上传》恶意文件上传可能导致服务器被入侵,数据泄露甚至服务瘫痪,因此我们必须采取全面且有效的防范措施来保护Java应用的安全,下面我们就来看看具体的实现方法吧... 目录恶意文件上传的潜在风险常见的恶意文件上传手段防范恶意文件上传的关键策略严格验证文件类型检查文件内容控制文件存储

一文详解PostgreSQL复制参数

《一文详解PostgreSQL复制参数》PostgreSQL作为一款功能强大的开源关系型数据库,其复制功能对于构建高可用性系统至关重要,本文给大家详细介绍了PostgreSQL的复制参数,需要的朋友可... 目录一、复制参数基础概念二、核心复制参数深度解析1. max_wal_seChina编程nders:WAL

CSS3 布局样式及其应用举例

《CSS3布局样式及其应用举例》CSS3的布局特性为前端开发者提供了无限可能,无论是Flexbox的一维布局还是Grid的二维布局,它们都能够帮助开发者以更清晰、简洁的方式实现复杂的网页布局,本文给... 目录深入探讨 css3 布局样式及其应用引言一、CSS布局的历史与发展1.1 早期布局的局限性1.2

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

在React聊天应用中实现图片上传功能

《在React聊天应用中实现图片上传功能》在现代聊天应用中,除了文字和表情,图片分享也是一个重要的功能,本文将详细介绍如何在基于React的聊天应用中实现图片上传和预览功能,感兴趣的小伙伴跟着小编一起... 目录技术栈实现步骤1. 消息组件改造2. 图片预览组件3. 聊天输入组件改造功能特点使用说明注意事项