在当今的软件开发领域,行为驱动开发(Behavior Driven Development,BDD)作为一种新兴的测试方法,逐渐受到越来越多开发者的关注和青睐。Python作为一门功能强大且易于使用的编程语言,在实现BDD方面也有着独特的优势。那么,如何利用Python实现BDD自动化测试呢?本文将为你详细解析。

如何用Python高效地实现行为驱动开发(BDD)自动化测试?有哪些工具和方法可以帮助我们在实际项目中应用BDD?

Behave 作为一种支持python编写行为驱动开发的工具,通过将测试用例用自然语言编写,降低了技术门槛,促进了团队协作。结合步骤定义和测试运行器,Behave 可以方便地集成到自动化测试框架中,为各类应用的测试提供支持。无论是 Web 应用、移动应用还是 API 测试,Behave 都能提供强大的功能和灵活的扩展性,是自动化测试的不二选择

什么是BDD?

行为驱动开发 (BDD, Behavior-Driven Development) 是一种软件开发过程,旨在通过鼓励协作和沟通,提高软件质量。BDD 的核心理念是用自然语言描述软件的行为,使得业务人员、开发人员和测试人员都能参与其中。BDD 是由测试驱动开发 (TDD, Test-Driven Development) 演变而来的,强调从业务价值和用户需求出发来编写测试。BDD 使用自然语言编写测试用例,能够更加容易理解和维护。

BDD 的主要组成部分包括:

1.特性 (Feature)

描述软件的一部分功能,比如:用户登录功能

2.场景 (Scenario)

描述特性中的具体情景或用例,每个场景包含一系列步骤。比如:成功登录和失败登录

3.步骤 (Steps)

描述具体的操作和预期结果,使用 Given-When-Then 语法。

  • Given 用户在登录页面

  • When 用户输入有效的用户名和密码

  • Then 用户应看到主页

Behave: 类似 Cucumber 的 Python BDD 框架

在业界中Cucumber是非常流行的适合BDD的框架,但是Cucumber 本身并不直接支持 Python,Python社区有一个类似的工具叫做 Behave,它是一个专为 Python 设计的 BDD 框架,功能和使用方式与 Cucumber 非常相似。它允许你用自然语言编写测试用例。这些测试用例称为“特性文件” (Feature Files),使用的是一种叫做 Gherkin 的语法。Gherkin 语法简单易懂,可以让非技术人员也能参与编写测试用例。在自动化测试领域中结合Behave BDD框架有着十分广泛的应用:

  1. Web 应用自动化测试

  • 使用 Selenium 等工具,结合 Behave 实现 Web 应用的端到端自动化测试。

2.App应用自动化测试:

  • 结合 Appium,使用 Behave 编写和运行移动端应用自动化测试。

3.接口自动化测试:

  • 使用 requests 等工具,结合 Behave 实现接口自动化测试。

Behave使用

1、安装 Behave

使用 pip 安装 Behave:

pip install behave

2、安装自动化测试对应的库

比如web应用自动化测试selenium:

pip install selenium

3、创建python项目,目录结构参考如下:

my_bdd_project/
|-- features/
| |-- steps/
| | |-- login_steps.py
| |-- login.feature
|-- tests/
| |-- test_runner.py

4、定义特性文件

特性文件使用 Gherkin 语法编写,用来描述具体的测试用例。场景是特性文件中的一部分,每个场景包含一系列的步骤,用于模拟用户行为并验证预期结果。场景使用 Gherkin 语法编写,通常包含三个部分:Given(假设)、When(当)和 Then(那么)。

例如,创建一个 login.feature 文件,内容如下:

Feature: 用户登录功能

  Scenario: 成功登录
Given 用户在登录页面
When 用户输入有效的用户名和密码
Then 用户应看到主页 Scenario: 登录失败
Given 用户在登录页面
When 用户输入无效的用户名和密码
Then 用户应看到错误消息

5、编写步骤定义

步骤定义是将 Gherkin 语法映射到具体的代码实现,每个步骤对应一个方法,方法中包含具体的测试逻辑。例如,使用 behave 和 Selenium 实现上述特性文件中的步骤:

创建 login_steps.py 文件,内容如下:​​​​​​​

 1 from behave import given, when, then
2 from selenium import webdriver
3 from selenium.webdriver.common.by import By
4
5 @given('用户在登录页面')
6 def step_given_user_on_login_page(context):
7 context.driver = webdriver.Chrome()
8 context.driver.get('http://example.com/login')
9
10 @when('用户输入有效的用户名和密码')
11 def step_when_user_enters_valid_credentials(context):
12 context.driver.find_element(By.ID, 'username').send_keys('valid_username')
13 context.driver.find_element(By.ID, 'password').send_keys('valid_password')
14 context.driver.find_element(By.ID, 'submit').click()
15
16 @then('用户应看到主页')
17 def step_then_user_should_see_home_page(context):
18 assert 'Home' in context.driver.title
19
20 @when('用户输入无效的用户名和密码')
21 def step_when_user_enters_invalid_credentials(context):
22 context.driver.find_element(By.ID, 'username').send_keys('invalid_username')
23 context.driver.find_element(By.ID, 'password').send_keys('invalid_password')
24 context.driver.find_element(By.ID, 'submit').click()
25
26 @then('用户应看到错误消息')
27 def step_then_user_should_see_error_message(context):
28 error_message = context.driver.find_element(By.ID, 'error').text
29 assert 'Invalid username or password' in error_message

6、运行测试

在项目根目录下运行 behave 命令,执行测试:​​​​​​​

 1 PS D:\workspace_pycharm\my_bdd_project> behave
2 Feature: 用户登录功能 # features/login.feature:1
3
4 Scenario: 成功登录 # features/login.feature:3
5 Given 用户在登录页面 # features/steps/login_steps.py:7
6 When 用户输入有效的用户名和密码 # features/steps/login_steps.py:14
7 Then 用户应看到主页 # features/steps/login_steps.py:20
8
9 Scenario: 登录失败 # features/login.feature:8
10 Given 用户在登录页面 # features/steps/login_steps.py:7
11 When 用户输入无效的用户名和密码 # features/steps/login_steps.py:24
12 Then 用户应看到错误消息 # features/steps/login_steps.py:30
13
14 1 feature passed, 0 failed, 0 skipped
15 2 scenarios passed, 0 failed, 0 skipped
16 6 steps passed, 0 failed, 0 skipped, 0 undefined
17 Took 0m13.667s

或者可以在tests目录下新建test_runner.py文件:​​​​​​​

import os
import subprocess def run_behave_tests():
result = subprocess.run(['behave'], cwd=os.path.join(os.path.dirname(__file__), '../features')) if __name__ == "__main__":
run_behave_tests()

再执行命令:

python tests/test_runner.py

通过本文的介绍,我们了解了Python在BDD自动化测试中的应用,从基本概念到具体实现,再到实际案例,全面覆盖了BDD测试的方方面面。掌握这些知识,不仅能够提升你的测试技能,也有助于在项目中更好地应用BDD方法。

BDD不仅是一种测试方法,更是一种思维方式。利用Python实现BDD自动化测试,让你的开发流程更加高效和可靠。

Python 实现行为驱动开发 (BDD) 自动化测试详解的更多相关文章

  1. Linux驱动开发必看详解神秘内核(完全转载)

    Linux驱动开发必看详解神秘内核 完全转载-链接:http://blog.chinaunix.net/uid-21356596-id-1827434.html   IT168 技术文档]在开始步入L ...

  2. 基于python的互联网软件测试开发(自动化测试)-全集合

    基于python的互联网软件测试开发(自动化测试)-全集合 1   关键字 为了便于搜索引擎收录本文,特别将本文的关键字给强调一下: python,互联网,自动化测试,测试开发,接口测试,服务测试,a ...

  3. 基于Python的WEB接口开发与自动化测试 pdf(内含书签)

    基于Python的WEB接口开发与自动化测试 目录 目 录O V目 录章 Python 学习必知 ................................................... ...

  4. Python中操作mysql的pymysql模块详解

    Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...

  5. p2p网贷项目开发全过程技术详解,应用框架是ci2.2

    p2p网贷项目开发全过程技术详解,应用框架是ci2.2 很标准的mvc开发代码,代码也很简单,方便二次开发 这篇文章会不断更新

  6. 七牛云存储Python SDK使用教程 - 上传策略详解

    文 七牛云存储Python SDK使用教程 - 上传策略详解 七牛云存储 python-sdk 七牛云存储教程 jemygraw 2015年01月04日发布 推荐 1 推荐 收藏 2 收藏,2.7k  ...

  7. Spark Streaming揭秘 Day28 在集成开发环境中详解Spark Streaming的运行日志内幕

    Spark Streaming揭秘 Day28 在集成开发环境中详解Spark Streaming的运行日志内幕 今天会逐行解析一下SparkStreaming运行的日志,运行的是WordCountO ...

  8. 【转】【Android UI设计与开发】之详解ActionBar的使用,androidactionbar

    原文网址:http://www.bkjia.com/Androidjc/895966.html [Android UI设计与开发]之详解ActionBar的使用,androidactionbar 详解 ...

  9. Python调用C/C++动态链接库的方法详解

    Python调用C/C++动态链接库的方法详解 投稿:shichen2014 这篇文章主要介绍了Python调用C/C++动态链接库的方法,需要的朋友可以参考下 本文以实例讲解了Python调用C/C ...

  10. VS2010开发程序打包详解

    VS2010开发程序打包详解 转自:http://blog.sina.com.cn/s/blog_473b385101019ufr.html 首先打开已经完成的工程,如图: 下面开始制作安装程序包. ...

随机推荐

  1. Rainbond 携手 TOPIAM 打造企业级云原生身份管控新体验

    TOPIAM 企业数字身份管控平台, 是一个开源的IDaas/IAM平台.用于管理账号.权限.身份认证.应用访问,帮助整合部署在本地或云端的内部办公系统.业务系统及三方 SaaS 系统的所有身份,实现 ...

  2. INFINI Labs 产品更新 | Gateway 支持基于 Kafka 的复制能力,发布 Helm Charts 部署方式

    INFINI Labs 产品又更新啦~.本次更新概要如下:Easysearch 新增了索引字段相关统计 API,优化了 source_reuse 提升压缩效率:Gateway 新增诸多新特性,如:支持 ...

  3. ASP.NET MVC 出现: Uncaught ReferenceError: $ is not defined

    ASP.NET MVC 出现: Uncaught ReferenceError: $ is not defined 错误 将 _Layout.cshtml 中的三行代码,移动到 <head> ...

  4. 小米 红米 Redmi MIUI14 ANDROID 系统 耗电

    小米 红米 Redmi MIUI14 ANDROID 系统 耗电 在系统更新里,点右上角三点,下载完整更新包,安装好.再把电量用到关机,充电,充满开机,别拔线,继续充10分钟.我就是这么解决的,今天用 ...

  5. 企业级私有仓库Harbor

    仓库的概念也就是用于存储,docker仓库用于存储镜像. 镜像构建完成后,很容易可以在宿主机上运行,但是如果要在其他服务器上运行,则需要考虑镜像的分发,存储的问题. 共有/私有/仓库 Docker R ...

  6. 【前端求助帖】关于使用element-plus select 模板嵌套popover中使用select选择后,上一个select自动关闭的问题

    主页代码如下 项目使用的是Vue3+vite, 下载后,直接pnpm  i安装依赖,  pnpm dev 就是可以跑起来 <el-button type="warning" ...

  7. springboot项目配置多数据源

    springboot项目配置多数据源 //关键:mybatis文件的目录需要区分开来 sqlSessionFactoryBean.setMapperLocations(new PathMatching ...

  8. 认真学习CSS3-问题收集-102号-关于定位

    css中有关于定位的一个属性position. 在w3cschool中,position的介绍如下: 值 描述 absolute 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定 ...

  9. Mysql 使用(一)

    一.数据库的种类 关系型数据库 非关系型数据库 二.常见关系型数据库 oracle:在以前的大型项目中使用,银行,电信等项目 mysql:web时代使用最广泛的关系型数据库 ms sql server ...

  10. python爬虫-bs4基础

    # 下面的一段HTML代码将作为例子被多次用到.这是 爱丽丝梦游仙境的 的一段内容(以后内容中简称为 爱丽丝 的文档): html_doc = """ <html& ...