Pytest 读取excel文件参数化应用

本文是基于Pytest框架,读取excel中的文件,传入页面表单中,并做相应的断言实现。

1、编辑媒体需求

首先明确一下需求,我们需要对媒体的表单数据进行编辑,步骤如下:

具体表单如下图所示

1、登录

2、点击我的媒体

3、点击媒体

4、点击编辑媒体

5、设置标题

6、设置媒体标题分类

7、设置标签001

8、设置产生日期

9、上传图片

10、描述

11、状态

12、启动评论

13、缩略图时刻

14、允许下载

然后点击"Update Media"后,就会跳转到这个媒体的界面上。可以查看提交的配置是否生效。

2、编辑媒体V1.0

第一版先定位到元素并手工实现。

2.1 登录

2.1.1  conftest.py配置

首先在conftest.py做好公共方法的配置工作,也就是登录退出等一些常用的方法。

conftest.配置特点

conftest.py配置脚本名称是固定的,不能改名称

conftest.py与运行的用例要在同一个package下,并且有————init__.py文件

测试用例文件不需要import conftest.py就能自动找到配置好的@pytest.fixture

import timeimport pytest
from selenium import webdriver@pytest.fixture(scope='session')
def driver():driver=webdriver.Firefox()driver.maximize_window()driver.implicitly_wait(10)yield drivertime.sleep(10)   # 如果需要观察程序运行过程,那么加时间等待;代码调试弯沉后,去掉时间等待。# driver.quit()@pytest.fixture(scope='session')
def login(driver):driver.get("https://svr-6-9010.share.51env.net/accounts/login/")# 3、输入用户名driver.find_element_by_id("id_login").send_keys("changcheng1211")# 4、输入密码driver.find_element_by_id("id_password").send_keys("changcheng1211")driver.find_element_by_id("id_captcha_1").send_keys("changcheng1211")# 5、点击登录driver.find_element_by_class_name("primaryAction").submit()yield driver

介绍一下

Pytest Fixture

作用

为每个测试用例完成一些公共的前置或者后置工作

限制范围

scope="function"每个方法调用一次

scope="class"每个类调用一次

scope="module"每一个.py文件调用一次

scope="session"多个.py文件只调用一次

用法

import pytest

打开浏览器  def driver():

登录功能   def login():

2.1.12 pytest之全局配置文件pytest.ini

[pytest]
addopts = -s -v
testpaths = test_cases/test_update_media.py

-s:表示输出调试信息,用于显示测试函数中print()打印的信息

-v:未加前只打印模块名,加v后打印类名、模块名、方法名,显示更详细的信息

-q:表示只显示整体测试结果

-vs:这两个参数可以一起使用

-n:支持多线程或者分布式运行测试用例(前提需安装:pytest-xdist插件)

–html:生成html的测试报告(前提需安装:pytest-html插件) 如:pytest -vs --html ./reports/result.html

testpaths 是指定执行的路径的。

2.2  编辑媒体test_update_media.py

首先在测试的目录下新建一个测试文件test_update_media.py,D:\python\autoFuncTest2\test_cases\test_update_media.py

from selenium.webdriver.support.select import Selectclass TestUpDateMedia:def test_update_meida(self,login):# 1、登录# 2、点击我的媒体login.find_element_by_partial_link_text('我的媒体').click()# 3、点击媒体login.find_element_by_class_name('item-thumb').click()# 4、点击编辑媒体login.find_element_by_link_text('编辑媒体').click()# 5、设置标题login.find_element_by_id('id_title').clear()login.find_element_by_id('id_title').send_keys('小猴子.MP4')# 6、设置媒体标题分类id_category = login.find_element_by_id('id_category')# 如果用ctrl键,可以多选,用click()方法不能多选。# Selenium给我们提供了一种方法 select_by_visible_text('Film')  可以多选select_category = Select(id_category)select_category.select_by_visible_text('Film')select_category.select_by_index(0)  # Artselect_category.select_by_value('2') # Documentary# 7、设置标签001id_new_tags = login.find_element_by_id('id_new_tags')id_new_tags.clear()id_new_tags.send_keys('001')# 8、设置产生日期id_add_date = login.find_element_by_id('id_add_date')id_add_date.clear()id_add_date.send_keys('2000/06/04 20:49')# 9、上传图片login.find_element_by_id('id_uploaded_poster').send_keys('D:\\niupeng2.png')# 10、描述id_description = login.find_element_by_id('id_description')id_description.clear()id_description.send_keys('今天我们去动物园,参观了小猴子')# 11、状态id_state = login.find_element_by_id('id_state')Select(id_state).select_by_visible_text('私有')# 12、启动评论login.find_element_by_id('id_enable_comments').click()# 13、缩略图时刻id_thumbnail_time = login.find_element_by_id('id_thumbnail_time')id_thumbnail_time.clear()id_thumbnail_time.send_keys('50')# 14、允许下载login.find_element_by_id('id_allow_download').click()# 15、点击Update Medialogin.find_element_by_class_name('primaryAction').submit()

下面介绍一下代码的实现

from selenium.webdriver.support.select import Selectclass TestUpDateMedia:def test_update_meida(self,login):

首先导入一个Select的包,因为里面有用到下拉框选择。

新建一个class TestUpDateMedia  的类。

def test_update_meida(self,login):    

并在里面声明一个‘test_update_meida’的方法,它继承自conftest.py的login的类。这里是直接调用登录功能。

        # 2、点击我的媒体login.find_element_by_partial_link_text('我的媒体').click()# 3、点击媒体login.find_element_by_class_name('item-thumb').click()# 4、点击编辑媒体login.find_element_by_link_text('编辑媒体').click()

先点我的媒体,点击媒体,再点击编辑媒体

        # 5、设置标题login.find_element_by_id('id_title').clear()login.find_element_by_id('id_title').send_keys('小猴子.MP4')

设置标题前应先清空输入框

        # 6、设置媒体标题分类id_category = login.find_element_by_id('id_category')# 如果用ctrl键,可以多选,用click()方法不能多选。# Selenium给我们提供了一种方法 select_by_visible_text('Film')  可以多选select_category = Select(id_category)select_category.select_by_visible_text('Film')select_category.select_by_index(0)  # Artselect_category.select_by_value('2') # Documentary

设置媒体的标题分类

这里涉及到下拉框的操作

下拉框操作
    假设有一个元素使select标签,这时需要选择其中一个/多个选项
    这时就不是click或者sendKeys这样的操作,而是应该使用”选择“操作
    代码实现步骤
        1.首先定位下拉框
            WebElement element = driver.findElement(By...)
        2.把定位到的元素转成下拉框类型
            Select select = new Select(element);
        3、执行”选择“操作
            select.deselectAll()
                清空选择
            选择某个元素,有三种方式
                select.select_by_visible_text('界面可见的文字')
                select.select_by_index(0) #选项的value属性
                select.select_by_value('2')  #第几个选项

        # 7、设置标签001id_new_tags = login.find_element_by_id('id_new_tags')id_new_tags.clear()id_new_tags.send_keys('001')# 8、设置产生日期id_add_date = login.find_element_by_id('id_add_date')id_add_date.clear()id_add_date.send_keys('2000/06/04 20:49')

设置标签和产生日期。

        # 9、上传图片login.find_element_by_id('id_uploaded_poster').send_keys('D:\\niupeng2.png')# 10、描述id_description = login.find_element_by_id('id_description')id_description.clear()id_description.send_keys('今天我们去动物园,参观了小猴子')# 11、状态id_state = login.find_element_by_id('id_state')Select(id_state).select_by_visible_text('私有')

正常定位元素并发送值就可以。

        # 12、启动评论login.find_element_by_id('id_enable_comments').click()# 13、缩略图时刻id_thumbnail_time = login.find_element_by_id('id_thumbnail_time')id_thumbnail_time.clear()id_thumbnail_time.send_keys('50')# 14、允许下载login.find_element_by_id('id_allow_download').click()# 15、点击Update Medialogin.find_element_by_class_name('primaryAction').submit()

到这后,第一版已经完成了。已经实现了基本的功能。

在命令行界面输入pytest,会显示执行完成。

3、编辑媒体V2.0

简要说明一下代码的结构。首先新建了一个叫autoFuncTest2的工程。里面按顺序resource下面有test_data.xlsx的测试数据文件。test_cases下面的conftest.py的配置文件和test_update_media2.py的测试用例文件,utils里面有一个专门读取xlsx文件的excel_utils.py文件。最后是一个pytest.ini的全局配置文件。

执行顺序为,首先命令行,输入pytest,会读取pytest.ini配置文件,按照里面的路径执行测试test_cases下面的测试用例test_update_media2.py。test_update_media2.py再调用conftest.py进行登录,登录完成后调用utils里面有一个专门读取xlsx文件的excel_utils.py文件,读取resource下面有test_data.xlsx的测试数据文件,进行操做。

3.1 pytest之全局配置文件pytest.ini

把代码的执行路径改了。因为我们要重新编写V2.0版本。我们要将待执行的命令指向要执行的文件。

[pytest]
addopts = -s -v
testpaths = test_cases/test_update_media2.py

3.2 测试数据文件test_data.xlsx

这个是要读取的excel文件

其中,里面有一些参数,是我们要读取的。

title, category, tag, date, image, description, state, enable_comments, thumbnail_time, allow_download,verify_state, verify_date, verify_enable_comments,verify_allow_download

3.3 test_update_media2.py

这个要从excel里面读取数据,进行参数化。

import timeimport pytest
from selenium.webdriver.support.select import Selectfrom utils import excel_utilsclass TestUpDateMedia:test_data = excel_utils.read(__file__)@pytest.mark.parametrize('title, category, tag, date, image, description, state,'' enable_comments, thumbnail_time, allow_download,'' verify_state, verify_date, verify_enable_comments,'' verify_allow_download', test_data)def test_update_media(self,login,title, category, tag, date, image, description,state, enable_comments, thumbnail_time, allow_download,verify_state, verify_date, verify_enable_comments,verify_allow_download):# 1、登录# 2、点击我的媒体if 'Media was edited!' in login.page_source:login.find_element_by_xpath('//i[text()="menu"]').click()# 如果页面出现了'Media was edited!',那么需要先点击左上角的”i“标签,三个横线的按钮login.find_element_by_partial_link_text('我的媒体').click()# except Exception as e:#     login.find_element_by_xpath('//i[text()="menu"]').click()# 3、点击媒体login.find_element_by_class_name('item-thumb').click()# 4、点击编辑媒体login.find_element_by_link_text('编辑媒体').click()# 5、设置标题login.find_element_by_id('id_title').clear()login.find_element_by_id('id_title').send_keys(title)# 6、设置媒体标题分类id_category = login.find_element_by_id('id_category')# 如果用ctrl键,可以多选,用click()方法不能多选。# Selenium给我们提供了一种方法 select_by_visible_text('Film')  可以多选select_category = Select(id_category)select_category.deselect_all()for c in category.split(','):select_category.select_by_visible_text(c)# select_category.select_by_index(0)  # Art# select_category.select_by_value('2') # Documentary# Experimental,Music,TV# 7、设置标签001id_new_tags = login.find_element_by_id('id_new_tags')id_new_tags.clear()id_new_tags.send_keys()# 8、设置产生日期id_add_date = login.find_element_by_id('id_add_date')id_add_date.clear()id_add_date.send_keys(date)# 9、上传图片login.find_element_by_id('id_uploaded_poster').send_keys(image)# 10、描述id_description = login.find_element_by_id('id_description')id_description.clear()id_description.send_keys(description)# 11、状态id_state = login.find_element_by_id('id_state')Select(id_state).select_by_visible_text(state)# 12、启动评论id_enable_comments = login.find_element_by_id('id_enable_comments')if enable_comments == '启用评论' and id_enable_comments.is_selected():passelif enable_comments == '不启用评论' and  not id_enable_comments.is_selected():passelse:id_enable_comments.click()# 13、缩略图时刻id_thumbnail_time = login.find_element_by_id('id_thumbnail_time')id_thumbnail_time.clear()id_thumbnail_time.send_keys(thumbnail_time)# 14、不允许下载                            allow_download,id_allow_download = login.find_element_by_id('id_allow_download')if allow_download == '允许下载' and id_allow_download.is_selected():passelif allow_download == '不允许下载' and not id_allow_download.is_selected():passelse:id_allow_download.click()# 15、点击Update Medialogin.find_element_by_class_name('primaryAction').submit()# 16.断言# 检查标题assert login.find_element_by_css_selector('.media-title-banner h1').text == title# 检查分类for c in category.split(','):assert c in login.page_source# 检查标签assert tag in login.page_source# 检查日期assert verify_date in login.page_source# 检查描述assert description in login.page_source# 检查状态if state == '公开':assert 'private' not in login.page_sourceassert 'unlisted' not in login.page_sourceelse:assert verify_state in login.page_source# 检查评论assert verify_enable_comments in login.page_source# 检查是否允许评论  form-textareaif 'Add a comment...' == verify_enable_comments:assert login.find_element_by_class_name('form-textarea').get_attribute('placeholder') == 'Add a comment...'else:assert verify_enable_comments in login.page_source# 检查是否允许下载if verify_allow_download == '允许下载':# login.find_element_by_xpath('//span[text()="下载"]')assert '下载' in login.page_sourceelse:assert '下载' not in login.page_source

下面解释一下

@pytest.mark.parametrize('excel中的标题',test_data)

接下来将这些参数传进去。并将里面的响应参数替换成传进去的参数。

def test_update_media(self,login,title, category, tag, date, image, description,state, enable_comments, thumbnail_time, allow_download,verify_state, verify_date, verify_enable_comments,verify_allow_download):

有时隐式等待一些元素需要用一些条件触发,可以用一些条件判断代替。

if 'Media was edited!' in login.page_source:login.find_element_by_xpath('//i[text()="menu"]').click()

有时一个参数里面有多个值,比如category里面有Experimental,Music,TV,下拉框里面需要选多个值,需要用for循环遍历,并用逗号隔开他们。

        # 6、设置媒体标题分类id_category = login.find_element_by_id('id_category')# 如果用ctrl键,可以多选,用click()方法不能多选。# Selenium给我们提供了一种方法 select_by_visible_text('Film')  可以多选select_category = Select(id_category)select_category.deselect_all()for c in category.split(','):select_category.select_by_visible_text(c)

有时需要判断同时页面上是否勾选,如果勾选,并且excel中要求启用评论,那么不操作,反之就勾选。这里面涉及到一个多重判断。

        # 12、启动评论id_enable_comments = login.find_element_by_id('id_enable_comments')if enable_comments == '启用评论' and id_enable_comments.is_selected():passelif enable_comments == '不启用评论' and  not id_enable_comments.is_selected():passelse:id_enable_comments.click()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/853220.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

electron基础使用

安装以及运行 当前node版本18,按照官网提供操作,npm init进行初始化操作,将index.js修改为main.js,执行npm install --save-dev electron。(这里我挂梯子下载成功了。),添加如下代码至package.…

ORB算法特征提取

声明:学习过程中的知识总结,欢迎批评指正。 ORB算法提取两路输入图像(图像A,图像B)的特征点,根据提取的特征点进行特征匹配得到特征对。 ​ 图像金字塔 因为在现实世界中,同一个物体可能会以…

文生视频新王登场:Luma官宣免费、电影级大片生成,Sora?可灵?SD3.0?(内附网址)

✨点击这里✨:🚀原文链接:(更好排版、视频播放、社群交流、最新AI开源项目、AI工具分享都在这个公众号!) 文生视频新王登场:Luma官宣免费、电影级大片生成,Sora?可灵&am…

Ubuntu server 24 (Linux) 安装部署samba服务器 共享文件目录 windows访问

1 安装 sudo apt update sudo apt-get install samba #启动服务 sudo systemctl restart smbd.service sudo systemctl enable smbd.service #查看服务 2 创建用户 #创建系统用户 sudo useradd test2 #配置用户密码 sudo smbpasswd -a test2 # smbpasswd: -a添加用户 …

SD3开源:AI绘画的新纪元,出图效果巨好,不容错过!(附教程)

大家好,我是画画的小强。 这两天,Stability AI 将史上最牛的AI绘画模型SD3开源了,真是有格局! 虽说只是中杯的20亿参数版本,但我已经很满足了,再高的版本,我这普通的16G 4070Ti Super 显卡也跑…

HAL库开发--串口

知不足而奋进 望远山而前行 目录 文章目录 前言 学习目标 学习内容 开发流程 串口功能配置 串口功能开启 串口中断配置 串口参数配置 查询配置结果 发送功能测试 中断接收功能测试 printf配置 DMA收发 配置 DMA发送 DMA接收(方式1) DMA接收(方式2) 总结 前言…

shell编程基础(第18篇:更多的文件操作命令介绍)

前言 对于文件来说,除了它的文件内容之外,就是对其文件本身的操作,比如我们想要重命名文件、移动文件、复制文件、已经获取文件所在目录,文件名等操作,今天一起学习更多的文件操作相关的命令 basename 用于获取文件名…

C++ 32 之 静态成员函数

#include <iostream> #include <string> using namespace std;// 特点: // 1.在编译阶段就分配了内存空间 // 2.类内声明&#xff0c;在类外进行初始化 // 3.所有对象共享一份静态成员数据 class Students02{ public:int s_c;static int s_d;// 静态成员函数&#…

YOLOv8可视化界面PYQT5

yolov8&#xff0c;可视化界面pyqt。支持图片检测&#xff0c;视频检测&#xff0c;摄像头检测等&#xff0c;实时显示检测画面。支持自定义数据集&#xff0c;计数&#xff0c;fps展示……,即插即用&#xff0c;无需更改太多代码

非关系型数据库NoSQL数据层解决方案 之 Mongodb 简介 下载安装 springboot整合与读写操作

MongoDB 简介 MongoDB是一个开源的面向文档的NoSQL数据库&#xff0c;它采用了分布式文件存储的数据结构&#xff0c;是当前非常流行的数据库之一。 以下是MongoDB的主要特点和优势&#xff1a; 面向文档的存储&#xff1a; MongoDB是一个面向文档的数据库管理系统&#xff0…

TLE9879的基于Arduino调试板SWD刷写接口

官方的Arduino评估板&#xff0c;如下图所示&#xff1a; 如果你有官方的调试器&#xff0c;应该不用关注本文章&#xff0c;如下图连接就是&#xff1a; 如果&#xff0c;您和博主一样需要自己飞线的话&#xff0c;如下图所示&#xff1a;PCB的名称在右边整理&#xff0c;SWD的…

Elasticsearch 认证模拟题 - 20

一、题目 定义一个 pipeline&#xff0c;并且将 earthquakes 索引的文档进行更新 pipeline 的 ID 为 earthquakes_pipeline将 magnitude_type 的字段值改为大写如果文档不包含 batch_number&#xff0c;增加这个字段&#xff0c;将数值设置为 1如果已经包含 batch_number&…

大模型系列:Prompt提示工程常用技巧和实践

前言 Prompt提示语是使用大模型解决实际问题的最直接的方式&#xff0c;本篇介绍Prompt提示工程常用的技巧&#xff0c;包括Zero-Shot、Few-Shot、CoT思维链、Least-to-Most任务分解。 内容摘要 Prompt提示工程简述Prompt的一般结构介绍零样本提示Zero-Shot少样本提示Few-Sho…

nginx配置https协议(测试环境)

第一步申请证书 首先申请证书这一步&#xff0c;晚上有很多种方式实现&#xff0c;可以自己用算法实现&#xff0c;也可以找在线生成的网站&#xff0c;我这里使用了在线网站 https://www.toolhelper.cn/SSL/SSLGenerate 第二步将证书放到对应的目录下 这里我们主要用cert.pe…

探索大数据在信用评估中的独特价值

随着我国的信用体系越来越完善&#xff0c;信用将影响越来越多的人。现在新兴的大数据信用和传统信用&#xff0c;形成了互补的优势&#xff0c;大数据信用变得越来越重要&#xff0c;那大数据信用风险检测的重要性主要体现在什么地方呢?本文将详细为大家介绍一下&#xff0c;…

03-appium环境配置和启动参数设置

参考文章&#xff1a;https://blog.csdn.net/lovedingd/article/details/110949993 一、appium介绍 Appium是一个开源、跨平台的自动化测试框架&#xff0c;支持Android、IOS等平台&#xff0c;同时也支持多语言&#xff0c;比如&#xff1a;Java、Python等。 Appiumu通过扩展…

图论(一)之概念介绍与图形#matlab

图论&#xff08;一&#xff09;之概念介绍与图形目录 前言 一、图论介绍 二、基本概念 2.1图的概念 2.2图形分类 2.3邻接矩阵 2.3.1无向图 2.3.2有向图 2.3.3有向赋权图 2.4出度&#xff08;Outdegree&#xff09; 2.5入度&#xff08;Indegree&#xff09; 3.四种…

C语言 | Leetcode C语言题解之第145题二叉树的后序遍历

题目&#xff1a; 题解&#xff1a; void addPath(int *vec, int *vecSize, struct TreeNode *node) {int count 0;while (node ! NULL) {count;vec[(*vecSize)] node->val;node node->right;}for (int i (*vecSize) - count, j (*vecSize) - 1; i < j; i, --j)…

结构体对齐,与 触发 segment fault 为什么是 1024*132 ,而不是1024*128

1, 简单的小示例代码 按理说 malloc 的size 是 1024*128&#xff0c;这里却需要 1024*132才能及时触发 segmentation fault #include <stdlib.h> #include <stdio.h> #define SIZE 1024*131int main() {char *p 0;p malloc(SIZE);p[SIZE -1] a;free(p);printf(…

java学习 项目篇 一

学习地址&#xff1a;https://www.bilibili.com/video/BV1TP411v7v6?p6&spm_id_frompageDriver&vd_sourcea6f7db332f104aff6fadf5b3542e5875 后端环境搭建 Entity 实体&#xff0c;通常和数据库的表对应DTO 数据传输对象&#xff0c;用于程序中各层之间传递数据 (前端…