BDD - Python Behave 用户自定义配置文件

news2025/1/16 7:42:18

BDD - Python Behave 用户自定义配置文件

  • 引言
  • 默认 behave.ini 配置文件
  • 自定义配置文件
    • json 格式的配置文件
    • ini 格式的配置文件
  • 实例应用
    • 项目结构
    • 代码
      • BDD/Features/user_data.feature 文件
      • BDD/steps/user_data_steps.py 文件
      • BDD/environment.py 文件
      • 默认配置文件 behave.ini
      • 自定义配置文件
      • vscode 环境下 behave 设置 .vscode/settings.json 文件
    • 执行
      • 用默认 behave.ini 自定义的变量值
      • 命令行自定义变量值

引言

前面《BDD - Python Behave 配置文件 behave.ini》有介绍默认配置文件 behave.ini 一些通用配置。《BDD - Python Behave 用户自定义命令行选项 -D》通过命令行或默认配置文件 behave.ini 自定义参数。在实际自动化测试项目中,不同环境测试配置也不一样,例如:服务器地址,数据库名,API URL 等等,Behave 测试框架怎么自定义配置文件并应用到不同的测试环境中,今天就来了解一下,这也是框架设计的一部分,非常重要。

想了解更多 Behave 相关的文章,欢迎阅读《Python BDD Behave 系列》,持续更新中。

默认 behave.ini 配置文件

在项目根目录下,创建 behave.ini 文件,在 behave.userdata 处用户自定义参数。这里的用户参数通常是整个项目的全局参数,不区分环境。

[behave.userdata]
env = dev

脚本可以通过 context.config.userdata[‘env’] 便可访问到

自定义配置文件

官网 User Data,用户可以自定义配置文件 json 格式或 ini 格式,只是需要在 before_all() hook 中加载解析后才能应用的测试用例中。

json 格式的配置文件

新建一个 userconfig.json 文件,内容如下:

{
    "user": "user_name",
    "pw": "password"
}

environment.py 文件中,before_all hook 中加载该配置文件
configfile_json = userdata.get(“configfile”, “BDD/config/userconfig.json”)
获取配置文件,后面参数是配置文件的相对路径。

from behave import *
import os
import json
from behave.configuration import ConfigParser

def before_all(context):
    userdata = context.config.userdata
    # get json config
    configfile_json = userdata.get("configfile", "BDD/config/userconfig.json")
    if os.path.exists(configfile_json):
        config = json.load(open(configfile_json))
        userdata.update(config)

这样就可以通过 context.config.userdata[‘user’]context.config.userdata[‘pw’] 来访问了

ini 格式的配置文件

新建 dev_userconfig.ini 文件用来配置 dev 环境,内容如下:

[behave.userdata.more]
db = dev_db

新建 prod_userconfig.ini 文件用来配置 prod 环境,内容如下:

[behave.userdata.more]
db = prod_db

environment.py 文件中,before_all hook 中加载该配置文件
可以根据默认配置文件 behave.ini 中 或通过命令行参数自定义的 env 变量来加载相应的配置文件

env = userdata.get("env")    
configfile = userdata.get("configfile", f"BDD/config/{env}_userconfig.ini")
section = userdata.get("config_section", "behave.userdata.more")

以上是用来获取配置文件并指定 section 部分,然后通过 ConfigParser 解析加载配置项。

from behave import *
import os
import json
from behave.configuration import ConfigParser

def before_all(context):
    context.before_all = "before all"
    userdata = context.config.userdata
  
    # get ini config
    env = userdata.get("env")    
    configfile = userdata.get("configfile", f"BDD/config/{env}_userconfig.ini")
    section = userdata.get("config_section", "behave.userdata.more")
    parser = ConfigParser()
    parser.read(configfile)
    if parser.has_section(section):
        userdata.update(parser.items(section)) 

这样就可以通过 context.config.userdata[‘db’] 来访问了

实例应用

综合上面的讲解,来个完整的案例吧,基本上可以解决不同环境的配置问题。

项目结构

在这里插入图片描述

代码

BDD/Features/user_data.feature 文件

# user_data.feature 
Feature: Context User Data Example

	@user_data
	Scenario: User data scenario
		Given user data is set
		Then get the user data

BDD/steps/user_data_steps.py 文件

# user_data_steps.py

from behave import *

@given('user data is set')
def step_user_data_is_set(context):
    pass

@then('get the user data')
def then_get_user_data(context):
    print(f"env:{context.config.userdata['env']}")
    print(f"user:{context.config.userdata['user']}")
    print(f"pw:{context.config.userdata['pw']}")
    print(f"pw:{context.config.userdata['db']}")

BDD/environment.py 文件

# environment.py

from behave import *
import os
import json
from behave.configuration import ConfigParser

def before_all(context):

    userdata = context.config.userdata

    # get json config
    configfile_json = userdata.get("configfile", "BDD/config/userconfig.json")
    if os.path.exists(configfile_json):
        config = json.load(open(configfile_json))
        userdata.update(config)
    
    # get ini config
    env = userdata.get("env")    
    configfile = userdata.get("configfile", f"BDD/config/{env}_userconfig.ini")
    section = userdata.get("config_section", "behave.userdata.more")
    parser = ConfigParser()
    parser.read(configfile)
    if parser.has_section(section):
        userdata.update(parser.items(section))     

    print("userdata", userdata)  

默认配置文件 behave.ini

# behave.ini
[behave]
paths=BDD/Features/user_data
dry_run = false
format = my_html
outfiles = output/my_report.html
stdout_capture = False

[behave.formatters]
my_html = behave_html_formatter:HTMLFormatter

[behave.userdata]
env = dev

自定义配置文件

BDD/config/userconfig.json 文件,内容如下:

{
    "user": "user_name",
    "pw": "password"
}

BDD/config/dev_userconfig.ini 文件用来配置 dev 环境,内容如下:

[behave.userdata.more]
db = dev_db

BDD/config/prod_userconfig.ini 文件用来配置 prod 环境,内容如下:

[behave.userdata.more]
db = prod_db

vscode 环境下 behave 设置 .vscode/settings.json 文件

{
    "behave-vsc.featuresPath": "BDD/Features"
}

执行

当前是项目根目录 C:\Automation\Test

用默认 behave.ini 自定义的变量值

执行命令:behave

默认取 env = dev,所以会加载到 dev_userconfig.ini,
所以 db = dev_db

PS C:\Automation\Test> behave
userdata {'env': 'dev', 'user': 'user_name', 'pw': 'password', 'db': 'dev_db'}
Feature: Context User Data Example # BDD/Features/user_data/user_data.feature:2

  @user_data
  Scenario: User data scenario  # BDD/Features/user_data/user_data.feature:5   
    Given user data is set      # BDD/steps/user_data_steps.py:5
    Then get the user data      # BDD/steps/user_data_steps.py:9
env:dev
user:user_name
pw:password
pw:dev_db

1 feature passed, 0 failed, 0 skipped
1 scenario passed, 0 failed, 0 skipped
2 steps passed, 0 failed, 0 skipped, 0 undefined
Took 0m0.000s

命令行自定义变量值

执行命令:behave -D env=prod
会覆盖默认配置文件 behave.ini 中 env=dev 的值,用最新的 env=prod,会加载到 prod_userconfig.ini 文件,db=prod_db

PS C:\Automation\Test> behave -D env=prod
userdata {'env': 'prod', 'user': 'user_name', 'pw': 'password', 'db': 'prod_db'}
Feature: Context User Data Example # BDD/Features/user_data/user_data.feature:2

  @user_data
  Scenario: User data scenario  # BDD/Features/user_data/user_data.feature:5
    Given user data is set      # BDD/steps/user_data_steps.py:5
    Then get the user data      # BDD/steps/user_data_steps.py:9
env:prod
user:user_name
pw:password
pw:prod_db

1 feature passed, 0 failed, 0 skipped
1 scenario passed, 0 failed, 0 skipped
2 steps passed, 0 failed, 0 skipped, 0 undefined
Took 0m0.001s

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

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

相关文章

京东护网面试题汇总

1 、JNI 函数在 java 中函数名为 com.didi.security.main,C 中的函数名是什么样的? com_didi_security_mian java.com.didi.security.main 2 、Frida 和 Xposed 框架? 3 、SSRF 利用方式? 4 、宏病毒? 5 、APP 加壳&a…

吐血整理!操作系统【处理机调度】

🌈个人主页:godspeed_lucip 🔥 系列专栏:OS从基础到进阶 1 基本概念1.1 总览1.2 什么是调度1.2.1 调度1.2.2 处理机调度 1.3 调度的三个层次1.3.1 高级调度1.3.2 中级调度(内存调度)1.3.3 低级调度&#xf…

如何给最小化安装的CentOS主机装个远程桌面?

正文共:888 字 18 图,预估阅读时间:1 分钟 前面我们领微软云Azure的免费主机时(白嫖党618福利!来Azure领200美刀!外加云主机免费用一年!),发现“有资格免费试用服务”的主…

无人机地面站技术,无人机地面站理论基础详解

地面站作为整个无人机系统的作战指挥中心,其控制内容包括:飞行器的飞行过程,飞行航迹, 有效载荷的任务功能,通讯链路的正常工作,以及 飞行器的发射和回收。 无人机地面站总述 地面站作为整个无人机系统的作战指挥中心…

Cannot resolve symbol ‘@+id/modifyAvatar‘

问题 Cannot resolve symbol id/modifyAvatar详细问题 笔者进行Android开发,创建组件id,报红。 鼠标放置报红处,提示 Cannot resolve symbol id/modifyAvatar解决方案 顶部菜单栏 → \rightarrow →Build → \rightarrow →Rebuild proje…

每日一题 力扣107 二叉树的层序遍历Ⅱ

107. 二叉树的层序遍历 II 题目描述: 给你二叉树的根节点 root ,返回其节点值 自底向上的层序遍历 。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历) 示例 1: 输入:root [3,9,20…

《UE5_C++多人TPS完整教程》学习笔记6 ——《P7 在线会话控制(Online Sessions)》

本文为B站系列教学视频 《UE5_C多人TPS完整教程》 —— 《P7 在线会话控制(Online Sessions)》 的学习笔记,该系列教学视频为 Udemy 课程 《Unreal Engine 5 C Multiplayer Shooter》 的中文字幕翻译版,UP主(也是译者&…

【Java多线程案例】定时器

1. 定时器简介 定时器:想必大家一定对定时器这个概念不陌生!因为它经常出现在我们的日常生活和编程学习中,定时器就好比是一个"闹钟",会在指定时间处理某件事(例如响铃),而在编程世界…

Obsidian Publish的开源替代品Perlite

前几天就有网友跟我说,freenom 的免费域名不可用了,10 号的时候老苏进后台看了一下,还有一半的域名显示为 ACTIVE,似乎是以 2024年6月 为限。但到 11 号,老苏发现博客 (https://laosu.cf) 已经访问不了了,这…

Django学习笔记教程全解析:初步学习Django模型,初识API,以及Django的后台管理系统(Django全解析,保姆级教程)

把时间用在思考上是最能节省时间的事情。——[美]卡曾斯 导言 写在前面 本文部分内容引用的是Django官方文档,对官方文档进行了解读和理解,对官方文档的部分注释内容进行了翻译,以方便大家的阅读和理解。 概述 在上一篇文章里&#xff0…

C#,生成字符串整数校验码(Checksum)的谷歌(Google)算法与源代码

如题。 校验码系统是产生校验码并校验包括校验码在内的字符串的一套规则。 它可以防止在抄录和键入字符串时产生的错误。 一般生成 MD5 校验,也可以生成、进行简单、快速的 整数 校验。 谷歌开源,很实用的整数校验码生成代码。 1 文本格式 using Sy…

Python免费下载安装全流程(Python 最新版本),新手小白必看!

前言 今天换了新的电脑,需要重新安装python和PyCharm,就简单的写个教程吧~ 一、Python下载 1、进入Python官网 官网地址:https://www.python.org 2、点击【Downloads】展开后点击【Windows】跳转到下载python版本页面,选择&qu…

物联网技术的崛起:驱动智慧景区的新篇章

随着科技的飞速发展,物联网技术逐渐成为推动各行各业创新的重要力量。在旅游业中,物联网的应用为智慧景区的建设提供了有力支持,为游客带来了更加便捷、智能的旅游体验。本文将探讨物联网技术在智慧景区中的应用及其对旅游业的影响&#xff0…

[职场] 求职如何设置预期 #笔记#经验分享

求职如何设置预期 在求职的道路上,无论处于哪个年龄阶段,合理的就业期望值才能使我们的愿望与社会的需求相吻合,才能让自己在今后的工作中发挥出最大的实力与能力。 一、结合测评软件,明确求职目标 根据霍兰德职业兴趣测试结果&a…

解密ERP业务架构:打造高效运营与持续增长的关键

在当今竞争激烈的商业环境中,企业需要有效管理和整合各个部门的业务流程和信息,以实现高效运营和持续增长。而ERP(企业资源规划)系统作为一种集成的业务管理平台,扮演着至关重要的角色。本文将探讨ERP业务架构的重要性…

[经验] 欧阳修唐宋八大家之首是谁 #微信#知识分享#学习方法

欧阳修唐宋八大家之首是谁 1、唐宋八大家之首是谁 唐宋八大家是中国文学史上最具代表性的八位大文豪,他们的文学成就在中国文学史上占有重要地位,被誉为文学史上的“巨人”。 唐宋八大家之首,无疑是唐代著名诗人杜甫。他出生在一个贫苦的家…

RK3568笔记十五:触摸屏测试

若该文为原创文章,转载请注明原文出处。 使用正点原子的ATK-RK3568板子,一直在测试屏幕和视频,突然想到触摸屏测试,一直没有用过,原子给的demo跑的是QT系统,触摸功能是正常的,测试一下&#xf…

C语言strlen和sizeof的区别

strlen和sizeof没有联系 前者是库函数,统计长度的标志是是否有\0 后者是操作符。计算长度的标志是字节数量。

电脑监控屏幕软件有哪些(监控电脑屏幕的软件)

随着信息技术的迅猛发展,电脑屏幕监控软件已成为企业、家庭以及教育机构保护数据安全、提升工作效率以及进行行为分析的重要工具。本文将详细介绍几款主流的电脑屏幕监控软件,包括它们的功能、特点以及适用场景,帮助读者更好地了解并选择合适…

31.File文件

File文件 1. 概述2. 构造方法2.1 方法2.2 代码示例 3. 成员方法3.1 判断、获取的方法3.1.1 方法3.1.2 代码示例 3.2 创建、删除的方法3.2.1 方法3.2.2 代码示例 3.3 获取、遍历的方法3.3.1 重点方法3.3.1.1 方法3.3.1.2 代码示例 3.3.2 所有方法3.3.2.1 方法3.3.2.2 代码示例 4…