yaml文件格式、用 yaml 写测试用例

yaml文件格式

一、yaml简介

  yaml是一种用来写配置文件的序列化语言,跟json有些像,yaml又称作json的超集,yaml的设计则是为了友好可读性,主要用于配置信息的书写,而json设计的目的则是为了简单和通用,主要用于存储数据和应用层数据通信使用。

二、格式

  yaml主要有三种类型的数据原语:Maps,Lists,Scales(按照官方法表达:“mappings (hashes/dictionaries), sequences (arrays/lists) and scalars (strings/numbers)”),基于这三种数据原语可以组合出任何数据结构。

  • 破折号和空格( “-” ):Lists集合
  • 冒号和空格( “:” ) :Maps键值对
  • 井号( “#” ):注释
  • 三个破折号( “---” ):文档内容分隔线(多用于文档开始的地方)
  • 三个冒号( “...” ):表示文档的结束
  • 锚点(“&”),重复项抛锚(“*”):两者成对表达,像定义变量a,再引用变量a的关系,是一种重复项的替换。

  yaml基于缩进的作用域跟python语法格式比较相似,缩进块方便数据的结构化。

注意:

其中#作为注释,yaml中只有行注释

基本格式要求:

1.大小写敏感;2.使用缩进代表层级关系;

3.缩进只能使用空格,不能使用tab键,不要求空格个数,只需要相同层级左对齐(一般2或4个空格)。

对象:

使用冒号代表,格式为key:  value。冒号后要有一个空格:

特殊符号

1. ---  yaml可以在同一个文件中,使用---表示一个文档的开始:

代表定义了两个profile,一个是development,一个是production;也常使用---来分割不同的内容,比如记录日志:

2. ...和---配合使用,在一个配置文件中代表一个文件的结束:

相当于在一个yaml中连续写了两个yaml配置项

三、示例

1、Block Sequences 块序列是一个简单的一系列节点

block sequence:  
  - one
  - two : three

用 yaml 写测试用例

采用 excel 的方式写测试用例,格式比较死板,比较容易出错,采用 yaml / yml 格式来写用例。

第一步:

安装yaml,在运行里输入:pip install pyyaml

检验是否安装成功,在pycharm里输入:import yaml

第二步:

创建一个file,后缀写yaml或yml

在yml文件里写入单个用户名和密码

 打开yml文件并以字典的形式打印出来

运行结果:

在yml文件里写入多个用例,以“-”区分每个用例,以缩进控制层级

运行结果:

结果中,每个用例以字典展示,整个数据以列表展示

 多个用例和层级

运行结果:

备注:

但是,这种方法有一个弊端,在 yaml 中录入多个用例时,后面的用例会把前面的用例覆盖,如下文中的两个用例。(在 yaml 中注视同 python一样,前面加 #)

#正常登录
url: /api/user/login
method: post
data:
  username: joseph
  passwd: aA123456
headers:
  user-agent: Firefox
cookies:
  sign: ssassssss
check:
  error_code: 0
#密码错误
url: /api/user/login
method: post
data:
  username: joseph
  passwd: aaaaaaa
headers:
  user-agent: Firefox
cookies:
  sign: ssassssss
check:
  error_code: 3007

View Code

执行 a.py 后,运行结果如下:

{‘check‘: {‘error_code‘: 3007}, ‘url‘: ‘/api/user/login‘, ‘method‘: ‘post‘, ‘data‘: {‘username‘: ‘joseph‘, ‘passwd‘: ‘aaaaaaa‘}, ‘headers‘: {‘user-agent‘: ‘Firefox‘}, ‘cookies‘: {‘sign‘: ‘ssassssss‘}}

那我们采用什么方式来写多条测试用例呢,可以采用在每一个用例之前加上 ‘-’ ,如下所示:

-
  url: /api/user/login
  method: post
  datail: 正常登录
  data:
    username: joseph
    passwd: aA123456
  check:
    userId: 1
    error_code: 0

-
  url: /api/user/login
  method: post
  datail: 密码错误
  data:
    username: joseph
    passwd: aA123123
  check:
    error_code: 3007

-
  url: /api/user/login
  method: post
  datail: 密码不传
  data:
    username: joseph
  check:
    error_code: 3001

View Code

运行 a.py ,运行结果如下,可见,运行结果变成了一个列表。可以对列表进行循环,读出每一个用例。

[{‘method‘: ‘post‘, ‘check‘: {‘userId‘: 1, ‘error_code‘: 0}, ‘datail‘: ‘正常登录‘, ‘url‘: ‘/api/user/login‘, ‘data‘: {‘passwd‘: ‘aA123456‘, ‘username‘: ‘joseph‘}}, {‘method‘: ‘post‘, ‘check‘: {‘error_code‘: 3007}, ‘datail‘: ‘密码错误‘, ‘url‘: ‘/api/user/login‘, ‘data‘: {‘passwd‘: ‘aA123123‘, ‘username‘: ‘joseph‘}}, {‘method‘: ‘post‘, ‘check‘: {‘error_code‘: 3001}, ‘datail‘: ‘密码不传‘, ‘url‘: ‘/api/user/login‘, ‘data‘: {‘username‘: ‘joseph‘}}]

  • 6
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值