pytest文档30-功能用例与自动化用例完美对接(allure)
前言
做自动化做久了,经常会思考一个问题,到底别人是怎么做的自动化,跟自己的有啥不一样,看过不少书和资料,都是停留在demo的层面。
真正把自动化做的好的大牛又不屑于分享自己的劳动成果,所以大部分情况就是一群菜鸡在群里互啄,停留在初级入门的demo层面上。
到底自动化要达到什么样的效果呢?这里我把最近的研究成果分享下,有经验的小伙伴也可以一起交流下。
功能用例
我一直认为一切的自动化用例是基于功能测试用例的, 脱离了功能测试用例,你的代码写的再漂亮,那也仅仅是show代码的。
面试的时候经常会遇到一个问题,一般领导型的面试官会问:你们自动化做到了什么程度?自动化用例覆盖率达到了多少?
自动化用例覆盖率是一个很好的衡量标准,比如你功能测试用例有100条,你的自动化用例写了90条,用例覆盖率是90%?当然不是!!!
你的自动化用例如果跟功能用例搭不上边,那都是无效用例,覆盖率也许是0%,仅仅是你自己瞎写的!
所以自动化用例是去翻译你的功能用例 ,一个一个去覆盖,让功能case,变成自动化用例的case,一一对应起来的(没写过功能用例的,后面就不用看了)。
写功能用例的平台有很多,比如jira,禅道,testlink等,这里以禅道系统为例,比如我的"编辑文章分类"模块下了3个用例
其中的一条用例是这样的,有前置条件,用例的步骤和期望结果,这才是一个标准的用例
自动化用例
功能用例写完之后,接着是如何去用代码去实现功能用例,这里用的是pytest框架+allure报告,其中一条用例的部分代码应该如下
- feature 对应模块名称
- story 对应用例的标题
- testcase 对应禅道系统的bug用例url地址,关联起来
- issue 如果这个用例有bug,应该关联对应的bug地址
- 用例描述: 对应def下的描述步骤
import allure
# 上海-悠悠,QQ交流群:750815713
# 博客地址:https://www.cnblogs.com/yoyoketang/
@allure.feature("编辑分类文章")
class TestArticleclassify():
'''编辑文章分类'''
@allure.story("登录-编辑文章分类,重复保存,保存失败")
@allure.issue("http://49.235.92.12:8080/zentao/bug-view-1.html") # 禅道bug地址
@allure.testcase("http://49.235.92.12:8080/zentao/testcase-view-5-1.html") # 禅道用例连接地址
def test_edit_classify5(self, login):
'''用例描述:编辑文章分类-输入重复的分类,保存失败,不能添加重复的
setup: 登录login
step1: 编辑文章分类,输入文章类别,如:计算机
step2: 点保存按钮
step3: 重新打开编辑页,输入:计算机
step4: 再次点保存按钮
assert: 保存失败,提示:已存在
'''
driver = login
edit = ArticleclassifyPage(driver)
edit.click_classify_nav()
edit.edit_classify("计算机")
res2 = edit.is_edit_classify_success("计算机")
print("编辑是否成功:%s"%res2)
assert res2 # 断言
前置条件:login,应该是单独抽出来的写到conftest.py,作为一个前置fixture功能
import pytest
from selenium import webdriver
from pages.login_page import LoginPage
import time
# 上海-悠悠,QQ交流群:750815713
# 博客地址:https://www.cnblogs.com/yoyoketang/
# request 内置的fixture
@pytest.fixture(scope="session")
def driver(request):
'''只打开浏览器和关闭浏览器'''
driver = webdriver.Chrome()
driver.maximize_window() # 最大化
def end():
print("全部用例执行完后 teardown quit dirver")
time.sleep(5)
driver.quit()
request.addfinalizer(end)
return driver
@pytest.fixture(scope="session")
def login(driver):
web = LoginPage(driver)
web.login()
return driver
LoginPage 页面的封装,可以添加操作步骤,step对应每个步骤,我这里登录几个步骤写一起了,也可写的更详细
# 上海-悠悠,QQ交流群:750815713
# 博客地址:https://www.cnblogs.com/yoyoketang/
class LoginPage(Base):
loc_用户名 = ("id", "id_username")
loc_密码 = ("id", "id_password")
loc_登录按钮 = ("xpath", "//*[text()='登录']")
# 判断登录成功
loc_后台页面 = ("xpath", "//*[text()='后台页面']")
@allure.step("登录")
def login(self, username="admin", password="yoyo123456"):
'''登录'''
self.driver.get(login_url)
self.send(self.loc_用户名, username)
self.send(self.loc_密码, password)
self.click(self.loc_登录按钮)
@allure.step("登录结果判断")
def is_login_success(self):
'''判断是否登录成功 True False'''
result = self.is_element_exist(self.loc_后台页面)
return result
测试报告
接着查看运行结果的测试报告,展示效果如下
这样我们只需拿着测试报告,就可以交出完美的答案了!
pytest文档30-功能用例与自动化用例完美对接(allure)的更多相关文章
- pytest文档59-运行未提交git的用例(pytest-picked)
前言 我们每天写完自动化用例后都会提交到 git 仓库,随着用例的增多,为了保证仓库代码的干净,当有用例新增的时候,我们希望只运行新增的未提交 git 仓库的用例. pytest-picked 插件可 ...
- pytest文档50-命令行参数--durations统计用例运行时间
前言 写完一个项目的自动化用例之后,发现有些用例运行较慢,影响整体的用例运行速度,于是领导说找出运行慢的那几个用例优化下. --durations 参数可以统计出每个用例运行的时间,对用例的时间做个排 ...
- pytest文档7-pytest-html生成html报告
前言 pytest-HTML是一个插件,pytest用于生成测试结果的HTML报告.兼容Python 2.7,3.6 pytest-html 1.github上源码地址[https://github. ...
- Java导出freemarker实现下载word文档格式功能
首先呢,先说一下制作freemarker模板步骤, 1. 在WPS上写出所要的下载的word格式当做模板 2. 把模板内不固定的内容(例:从数据库读取的信息)写成123或者好代替的文字标注 3. 把固 ...
- pytest文档3-pycharm运行pytest
前言 上一篇pytest文档2-用例运行规则已经介绍了如何在cmd执行pytest用例,平常我们写代码在pycharm比较多 写完用例之后,需要调试看看,是不是能正常运行,如果每次跑去cmd执行,太麻 ...
- Taurus.MVC 2.3 开源发布:增强属性Require验证功能,自带WebAPI文档生成功能
背景: 上周,把 Taurus.MVC 在 Linux (CentOS7) 上部署任务完成后. 也不知怎么的,忽然就想给框架集成一下WebAPI文档功能,所以就动手了. 以为一天能搞完,结果,好几天过 ...
- iDoc「文档」功能强势升级!一键分享,即刻预览!(201903-1版本更新)
小摹很想知道小伙伴们在面对众多杂乱的文档时,都是如何管理起来的呢?iDoc的「文档」功能,很多小伙伴还没有用起来,甚至都没有注意到iDoc还有这样一个功能.今天小摹就给大家介绍一下iDoc的「文档」功 ...
- pytest文档15-使用自定义标记mark
前言 pytest可以支持自定义标记,自定义标记可以把一个web项目划分多个模块,然后指定模块名称执行.app自动化的时候,如果想android和ios公用一套代码时, 也可以使用标记功能,标明哪些是 ...
- Taurus.MVC 2.3.2 :WebAPI 文档集成测试功能及附加<%# JS执行功能语法 %>
前言: 前些天有网友提到了那个界面丑陋的SwaggerUI,让我想起了多年前实现的WebAPI文档未完成的功能点,于是,动手了,便有了本文的内容. 开源地址:https://github.com/cy ...
随机推荐
- 树型DP(2)
声明 https://blog.csdn.net/no1_terminator/article/details/77824790 参考课件和讲授来自Accelerator 找树的直径 树的直径定义为一 ...
- jacoco统计自动化代码覆盖率
jacoco统计自动化代码覆盖率 1. 简介 1.1. 什么是Jacoco Jacoco是一个开源的代码覆盖率工具,可以嵌入到Ant .Maven中,并提供了EclEmma Eclipse插件,也可以 ...
- vue高频面试题(面试路上踩过的坑)
### Vue 双向绑定原理 mvvm 双向绑定,采用**数据劫持结合发布者-订阅者模式**的方式,通过 `Object.defineProperty()` 来劫持各个属性的 setter.gette ...
- centos7.6离线安装mysql5.7(附下载链接)
本来打算直接用原生yum源安装,但是跨国访问网络太慢,只好采用离线安装的方式,原理就是把所需的rpm下载下来再上传服务器安装. 1.rpm文件下载地址: 目录: http://repo.mysql.c ...
- Potyczki Algorythmiczne 2019
Runda próbna: A + B 设$f[i]$表示两数相加得到前$i$位的方案数,由$f[i-1]$和$f[i-2]$转移得到. #include<cstdio> #include ...
- SQL查询--简单了解SQL(结构化查询语言)
以下内容是从其他地方摘抄过来的哈,原文地址忘记了,当时把内容记在了笔记中 SQL分类: 数据查询语言(DQL) 数据定义语言(DDL) 数据操纵语言(DML) 数据控制语言(DCL) 1.数据查询语言 ...
- 经典排序 python实现
稳定的排序算法:冒泡排序.插入排序.归并排序和基数排序. 不是稳定的排序算法:选择排序.快速排序.希尔排序.堆排序. 冒泡 def bobble(arr): length = len(arr) for ...
- win7 下docker 镜像加速
打开 Kitematic 运行 docker cli 注册镜像 https://www.daocloud.io/mirror#accelerator-doc 上有镜像地址 sudo sed -i &q ...
- idea2019最新注册码(亲测有效)
序言 最近发现经常用的idea注册用的License Server 又不能用了,估计是被"约谈了".内容如下: 虽然Community版本是免费使用的,但是在使用的过程中会出现各种 ...
- oracle like模糊查询不能走索引?
这里要纠正一个网上很多教程说的模糊匹配不能走索引的说法,因为在看<收获,不止SQL优化>一书,里面举例说到了,并且自己也跟着例子实践了一下,确实like一些特殊情况也是可以走索引的 例子来 ...