M04_HttpRunner中文乱码问题:悟空CRM 中文断言乱码问题处理

M04_HttpRunner中文乱码问题:悟空CRM 中文断言乱码问题处理

 

明白了乱码的成因,接下来就好办啦。

 

HttpRunner 中没有进行字符编码和解码的现成函数,所以我们需要自己手工编写代码进行处理。自己编写的处理函数可以直接定义到一个叫“debugtalk.py”的文件中。

 

注意:

  • 该文件名是固定的“debugtalk.py”,不要自己随便起名。
  • 如果进行规范的项目测试,需要整理一个专门的文件目录结构(可以用 HttpRunner的脚手架功能自动生成),用不同的目录分别保存用例文件、配置文件等。
  • 本次我们以练习为主,直接将“debugtalk.py”和用例的yml文件放到同一目录即可。

 

设计思路:

  • 先将中文字符转换为对应的 UTF-8 编码
  • 再将编码按字节分别解码为 ISO8859-1 字符

 

在用例文件所在相同目录下新建 debugtalk.py 文件(保存时使用 UTF-8 编码),

  • encode 编码函数:将字符按参数中的字符集方式进行编码。

如:“ 悟空..encode("utf8") ”,则返回编码为:E6 82 9F E7 A9 BA

  • decode 解码函数:将字节编码转换为指定字符集所对应的字符

如:“E6.decode("iso8859-1")”,则返回字符为: æ

 

def toISO(t):
	return t.encode("utf8").decode("iso8859-1")

 

在同目录下编写 wuk_001_login_validate.yml 测试用例文件(保存时使用 UTF-8 编码)

  • 先将“悟空”二字存储为一个变量“p”
  • 调用 debugtalk.py 文件文件中的函数 toISO(),返回值存储到变量 x 中
  • 通过正则表达式提取返回页面的标题文字,和 x 变量进行比较断言
- config:
    name: 悟空CRM

- test:
    name: 登录
    request:
      url: http://192.168.1.102/72crm/index.html#/workbench/index
      method: POST
      data:
        username: 13888888888
        password: 123456
    variables:
      p: 悟空
      x: ${toISO($p)}
    validate:
      - eq: [status_code, 200]
      - eq: [(.*)CRM, $x]
 

 

 

执行测试用例,成功

M04_HttpRunner中文乱码问题:悟空CRM 中文断言乱码问题处理_第1张图片

 

查看测试报告

M04_HttpRunner中文乱码问题:悟空CRM 中文断言乱码问题处理_第2张图片

 

你可能感兴趣的:(接口自动化测试之,-,HttpRunner框架)