自动化数据驱动?最全接口自动化测试yaml数据驱动实战

 

前言

我们在做自动化测试的时候,通常会把配置信息和测试数据存储到特定的文件中,以实现数据和脚本的分离,从而提高代码的易读性和可维护性,便于后期优化。

而配置文件的形式更是多种多样,比如:ini、yaml、json、toml、py、xml、properties 等。

YAML是一种轻量级的文本格式,可以用于存储结构化数据,非常适合用作测试数据。

在使用YAML数据驱动进行自动化测试时,通常需要准备一个或多个YAML文件,其中包含了测试用例的数据和预期结果。测试脚本会读取这些文件,并根据文件中的数据来执行对应的测试步骤,然后验证实际结果与预期结果是否一致。

下面我们就来详探接口自动化测试中的 YAML 数据驱动

1、什么是 YAML

YAML:YAML Ain’t a Markup Language,翻译过来就是YAML 不是一种标记语言。

它是一种以数据为中心的标记语言,比 XML 和 JSON 更适合作为配置文件。

YAML 的配置文件后缀为.yml 或.yaml,如:caituotuo.yml 或 caituotuo.yaml。

YAML 的语法和其他高级语言类似,并且可以简单表达清单、散列表,标量等数据形态。它使用空白符号缩进和大量依赖外观的特色,特别适合用来表达或编辑数据结构、各种配置文件、倾印调试内容、文件大纲等。

2、YAML 语法

1)基本语法
使用缩进表示层级关系;
缩进不允许使用 tab,只允许空格(官方说法不允许使用 tab,当然如果你使用 tab 在某些地方也是可以的,例如在 PyCharm 软件上);
缩进的空格数不重要,只要相同层级的元素左对齐即可;
大小写敏感;
前面加上 #表示注释;

  1. req:

  2. username: xxxxxx # 这是姓名

  3. gender: Boy

  4. ip: ******

  5. blog: www.xxxxxx.com

  6. res:

  7. status: 1

  8. code: 200

2)数据类型
对象:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
纯量(scalars):单个的、不可再分的值,又称字面量

纯量是指单个的,不可拆分的值,例如:数字、字符串、布尔值、Null、日期等,纯量直接写在键值对的 value 中即可。

字符串:
默认情况下字符串是不需要使用单引号或双引号的

username: 张三
  • 1

当然使用双引号或者单引号包裹字符也是可以的

  1. username: 'Hello world 张三'

  2. username: "Hello world 张三"

字符串可以拆成多行,每一行会被转化成一个空格

  1. # 字符串可以拆成多行,每一行会被转化成一个空格 '测试 张三'

  2. username3: 测试

  3. 张三

布尔值:

  1. boolean:

  2. - TRUE #true,True都可以

  3. - FALSE #false,False都可以

  4. # {'boolean': [True, False]}

数字:

  1. float:

  2. - 3.14

  3. - 6.8523015e+5 #可以使用科学计数法

  4. int:

  5. - 123

  6. - 0b1010_0111_0100_1010_1110 #二进制表示

  7. # {'float': [3.14, 685230.15], 'int': [123, 685230]}

Null:

  1. null:

  2. nodeName: 'node'

  3. parent: ~ #使用~表示null

  4. parent2: None #使用None表示null

  5. parent3: null #使用null表示null

  6. # {None: {'nodeName': 'node', 'parent': None, 'parent2': 'None', 'parent3': None}}

时间和日期:

 
  1. date:

  2. - 2023-04-18 #日期必须使用ISO 8601格式,即yyyy-MM-dd

  3. datetime:

  4. - 2023-04-18T15:09:30+08:00 #时间使用ISO 8601格式,时间和日期之间使用T连接,最后使用+代表时区

  5. # {'date': [datetime.date(2023, 4, 18)], 'datetime': [datetime.datetime(2023, 4, 18, 15, 9, 30, tzinfo=datetime.timezone(datetime.timedelta(seconds=28800)))]}

对象
使用 key:[空格]value 的形式表示一对键值对(空格不能省略),例如:blog: caituotuo.top。

行内写法:

key: {key1: value1, key2: value2, ...}

普通写法,使用缩进表示对象与属性的层级关系:

  1. key:

  2. child-key: value

  3. child-key2: value2

数组
以 - 开头的行表示构成一个数组。

普通写法:

  1. name:

  2. - 测试

  3. - 张三

  4. - 三

YAML 支持多维数组,可以使用行内表示:

key: [value1, value2, ...]

数据结构的子成员是一个数组,则可以在该项下面缩进一个空格:

  1. username:

  2. -

  3. - 测试张三

  4. - 张三

  5. - 张

  6. -

  7. - A

  8. - B

  9. - C

  10. # {'username': [['测试张三', '张三', '张'], ['A', 'B', 'C']]}

相对复杂的例子:

companies 属性是一个数组,每一个数组元素又是由 id、name、price 三个属性构成

  1. companies:

  2. -

  3. id: 1

  4. name: zhangshan

  5. price: 300W

  6. -

  7. id: 2

  8. name: 测试张三

  9. price: 500W

  10. # {'companies': [{'id': 1, 'name': 'zhangshan', 'price': '300W'}, {'id': 2, 'name': '测试张三', 'price': '500W'}]}

数组也可以使用 flow 流式的方式表示:

companies2: [ { id: 1,name: zhangshan,price: 300W },{ id: 2,name: 测试张三,price: 500W } ]

复合结构
以上三种数据结构可以任意组合使用,以实现不同的用户需求,例如:

  1. platform:

  2. - A1

  3. - A2

  4. - A3

  5. sites:

  6. A1: 测试张三

  7. A2: 测试李四

  8. A3: xxxxxx.com

  9. # {'platform': ['A1', 'A2', 'A3'], 'sites': {'A1': '测试张三', 'A2': '测试李四', 'A3': 'xxxxxx.com'}

3、引用

& 锚点和 * 别名,可以用来引用。

举个例子:
& 用来建立锚点 defaults,<< 表示合并到当前数据,* 用来引用锚点

  1. defaults: &defaults

  2. adapter: postgres

  3. host: localhost

  4. development:

  5. database: myapp_development

  6. <<: *defaults

  7. test:

  8. database: myapp_test

  9. <<: *defaults

等价于:

  1. defaults:

  2. adapter: postgres

  3. host: localhost

  4. development:

  5. database: myapp_development

  6. adapter: postgres

  7. host: localhost

  8. test:

  9. database: myapp_test

  10. adapter: postgres

  11. host: localhost

4、组织结构

一个 YAML 文件可以由一个或多个文档组成,文档之间使用 — 作为分隔符,且整个文档相互独立,互不干扰,如果 YAML 文件只包含一个文档,则 — 分隔符可以省略。

  1. ---

  2. website:

  3. name: 测试张三

  4. url: xxxxxx.com

  5. ---

  6. website: { name: 测试张三,url: www.xxxxxx.com }

  7. ---

  8. A1: 测试张三

  9. ---

  10. A2: 测试张三

  11. f7 = "./files/多文档.yml"

  12. with open(f7, "r", encoding="UTF-8") as f:

  13. content = yaml.safe_load_all(f)

  14. for i in content:

  15. print(i)

5、实战

封装思路
将 YAML 相关操作封装成 CommonUtil 公共模块,之后直接引入调用即可。

相关功能:
读取 yaml 文件数据;
将 yaml 数据转换成 json 格式;
可以动态设置参数;

这里要说一下动态设置参数
在自动化测试中,肯定不能把所有的参数都写死,因此就会用到参数化,例如:提取前一个接口的返回值作为后一个接口的入参,这里通过 Python 中的 Template 模块进行动态参数的设置

yaml 文件中通过 $变量名的形式设置变量

username: $username

给变量附上具体的值

  1. with open(yaml_path, "r", encoding="UTF-8") as f:

  2. text = f.read()

  3. # Template(text).safe_substitute(key_value)

  4. Template(text).safe_substitute({"username": "测试张三"}) # username为变量名

完整代码

  1. import os

  2. from string import Template

  3. import yaml

  4. class YamlUtil:

  5. @staticmethod

  6. def yaml_util(yaml_path, key_value=None):

  7. """

  8. 读取yml文件 设置动态变量

  9. :param yaml_path: 文件路径

  10. :param key_value: 动态变量 如:{"username": "测试张三"} yaml中的变量:$username

  11. :return:

  12. """

  13. try:

  14. with open(yaml_path, "r", encoding="UTF-8") as f:

  15. text = f.read()

  16. if key_value is not None:

  17. re = Template(text).safe_substitute(key_value)

  18. json_data = yaml.safe_load(re)

  19. else:

  20. json_data = yaml.safe_load(text)

  21. return json_data

  22. except FileNotFoundError:

  23. raise FileNotFoundError("文件不存在")

  24. except Exception:

  25. raise Exception("未知异常")

  26. @staticmethod

  27. def multiple(yaml_path):

  28. """

  29. 多文档

  30. :param yaml_path: yaml文件路径

  31. :return: list

  32. """

  33. json_data = []

  34. try:

  35. with open(yaml_path, "r", encoding="UTF-8") as f:

  36. content = yaml.safe_load_all(f)

  37. for i in content:

  38. json_data.append(i)

  39. return json_data

  40. except FileNotFoundError:

  41. raise FileNotFoundError("文件不存在")

  42. except Exception:

  43. raise Exception("未知异常")

  44. if __name__ == '__main__':

  45. f1 = "./files/初体验.yml"

  46. print(YamlUtil().yaml_util(f1))

  47. f2 = "./files/纯量.yml"

  48. print(YamlUtil().yaml_util(f2))

  49. f3 = "./files/数组.yml"

  50. print(YamlUtil().yaml_util(f3))

  51. f4 = "./files/复合结构.yml"

  52. print(YamlUtil().yaml_util(f4))

  53. f5 = "./files/引用.yml"

  54. print(YamlUtil().yaml_util(f5))

  55. f6 = "./files/参数化.yml"

  56. print(YamlUtil().yaml_util(f6, {"username": "测试张三"}))

  57. f7 = "./files/多文档.yml"

  58. for i in YamlUtil().multiple(f7):

  59. print(i)

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

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

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

相关文章

pdf structuredClone is not defined 解决

问题 部分手机系统的浏览器 pdf v2版本会出现 structuredclone is not defined 的报错&#xff0c;这是因为浏览器过低 解决 查看structuredClone的浏览器兼容性 structuredClone api 文档 polyfill 网站下方有个 polyfill的网址入口 可以解决低版本的兼容问题 相应网址…

笨蛋学算法之LeetCodeHot100_3_最长连续序列(Java)

package com.lsy.leetcodehot100;import java.util.Arrays; import java.util.HashSet; import java.util.Set;public class _Hot3_最长连续序列 {public static int longestConsecutive(int[] nums) {//创建set去重//对重复的数字进行去重Set<Integer> set new HashSet…

融合心血管系统(CVS)多视角信号的新架构新策略

随着深度学习的发展和传感器的广泛采用&#xff0c;自动多视角融合&#xff08;MVF&#xff09;在心血管系统&#xff08;CVS&#xff09;信号处理方面取得了进展。然而&#xff0c;普遍的MVF模型架构通常将同一时间步骤但不同视角的CVS信号混合成统一的表示形式&#xff0c;忽…

redis的四种模式部署应用

这里写目录标题 redis应用redis单机部署redis主从redis哨兵Cluster模式 redis应用 redis单机部署 关闭防火墙[rootzyq ~]#: yum -y install wget make gcc gcc-c ...... [rootzyq ~]#: wget https://download.redis.io/redis-stable.tar.gz --2024-01-01 19:41:14-- https:/…

TypeScript 进阶,深入理解并运用索引访问类型提升代码质量

欢迎回来继续我们的“TypeScript进阶技巧”系列。上次我们深入探讨了如何使用Extract和Exclude实用类型来优化TypeScript的类型处理&#xff08; 《如何利用 TypeScript 的 Extract 提升类型定义与代码清晰度》和 《如何利用 TypeScript 的 Exclude 提升状态管理与代码健壮性》…

论文阅读笔记:Cross-Image Relational Knowledge Distillation for Semantic Segmentation

论文阅读笔记&#xff1a;Cross-Image Relational Knowledge Distillation for Semantic Segmentation 1 背景2 创新点3 方法4 模块4.1 预备知识4.2 跨图像关系知识蒸馏4.3 Memory-based像素到像素蒸馏4.4 Memory-based像素到区域蒸馏4.5 整体框架 5 效果 论文&#xff1a;http…

Redis和Docker

Redis 和 Docker 是两种不同的技术&#xff0c;它们各自解决不同的问题&#xff0c;但有时会一起使用以提供更高效和灵活的解决方案。 Redis 是一个开源的内存数据结构存储系统&#xff0c;可以用作数据库、缓存和消息代理。它设计为解决MySQL等关系型数据库在处理大量读写访问…

MySQL数据操作与查询-T5 MySQL函数

一、数学函数和控制流函数 1、数学函数 &#xff08;1&#xff09;abs(x) 计算x的绝对值。 1 select abs(‐5.5),abs(10) &#xff08;2&#xff09;pow(x,y) 计算x的y次方的值。 1 select pow(2,8),pow(8,2) &#xff08;3&#xff09;round(x) 和 round(x,y) 对数字x进…

php遇到的问题

1、 underfined at line 3 in xxx.php , 错误提示&#xff0c;注释这行代码 // error_reporting(DEBUG ? E_ALL : 0); 目录&#xff1a;config/config.php

Ubuntu20.04部署Qwen2.openvino流程

下载代码 里面包含依赖 git clone https://github.com/OpenVINO-dev-contest/Qwen2.openvino.gitpython环境配置 创建虚拟环境 conda create -name qwen2openvino python3.10 conda activate qwen2openvino安装依赖 pip install wheel setuptools pip install -r requirem…

CCAA质量管理【学习笔记】​​ 备考知识点笔记(二)

第三节 GB/T19001-2016 标准正文 本节为ISO9001:2015 标准条款的正文内容&#xff0c;各条款中的术语参照上节内容理解时&#xff0c;会很轻松。本节不再一一对各条款讲解。 引 言 0.1 总 则 采用质量管理体系是组织的一项战略决策&#xff0c;能够帮助其提高整体绩效…

这个网站有点意思,可做SPRINGBOOT的启动图

在 SpringBoot 项目的 resources 目录下新建一个 banner.txt 文本文件&#xff0c;然后将启动 Banner 粘贴到此文本文件中&#xff0c;启动项目&#xff0c;即可在控制台展示对应的内容信息。 下面这个工具很好用&#xff0c;收藏精哦

PFA 反应罐内衬特氟龙 润滑绝缘行业加工 匠心工艺

PFA反应罐别名也叫反应瓶&#xff0c;储样罐&#xff0c;清洗罐等。可作为样品前处理实验中消解样品和中低压溶样的反应容器&#xff0c;广泛应用于半导体分析、新材料、新能源、同位素分析等。 PFA反应罐规格参考&#xff1a;250ml、300ml、350ml、500ml、1L等。 产品特点&…

官网首屏:太漂亮了,真是着了它的魔,上了它的道。

大气的企业官网致力于提供用户友好的界面和优质的用户体验。网页经过精心设计和开发&#xff0c;旨在展示客户的品牌形象和产品信息&#xff0c;并为用户提供便捷的服务和沟通渠道。 官网设计追求简洁、美观、易用的原则&#xff0c;以吸引用户的注意力并提供清晰的导航和信息…

手机丢失不惊慌,华为手机已升级至楼层级设备查找!

出门总是丢三落四&#xff0c;手机丢了怎么办&#xff1f;不要怕&#xff0c;只要你的华为手机升级至云空间新版本&#xff0c;就可以进行楼层级设备查找&#xff0c;现在可以查看到具体的楼层了&#xff01; 之前有手机丢失过的朋友&#xff0c;肯定有相似的经历&#xff0c…

【会议征稿,ACM出版】2024年云计算与大数据国际学术会议(ICCBD 2024,7月26-28)

2024年云计算与大数据国际学术会议(ICCBD 2024)将于2024年7月26-28日在中国大理召开。ICCBD 2024将围绕“云计算与大数据”的最新研究领域, 旨在为从事研究的专家、学者、工程师和技术人员提供一个国际平台&#xff0c;分享科研成果和尖端技术&#xff0c;了解学术发展趋势&…

Windows安装配置CUDA12.5

搞大模型往往都需要GPU加速&#xff0c;本次在家里的PC上安装CUDA来实现GPU加速。 一、环境准备 操作系统&#xff1a;Windows11 23H2 GPU&#xff1a;RTX 4070 Ti Super 显卡驱动&#xff1a;555.99 &#xff08;NVIDIA GeForce 驱动程序 - N 卡驱动 | NVIDIA&#xff09; …

基于JSP技术的定西扶贫惠农推介系统

开头语&#xff1a;你好呀&#xff0c;我是计算机学长猫哥&#xff01;如果有相关需求&#xff0c;文末可以找到我的联系方式。 开发语言&#xff1a;JSP 数据库&#xff1a;MySQL 技术&#xff1a;B/S架构、JSP技术 工具&#xff1a;Eclipse、MySQL、Tomcat 系统展示 首…

【python】OpenCV—Background Estimation(15)

文章目录 中值滤波中值滤波得到图像背景移动侦测 学习来自 OpenCV基础&#xff08;14&#xff09;OpenCV在视频中的简单背景估计 中值滤波 中值滤波是一种非线性平滑技术&#xff0c;主要用于数字信号处理&#xff0c;特别是在图像处理中去除噪声。 一、定义与原理 定义&am…

大模型日报2024-06-14

大模型日报 2024-06-14 大模型资讯 Meta发布Llama 3并专注大规模语言模型研发 摘要: Meta于2024年4月发布了开源的大规模语言模型Llama 3&#xff0c;并详细解释了他们在训练这些模型时关注的重点和方法。Meta目前正专注于大规模语言模型的进一步发展。 微软研究人员推出VALL-E…