ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

测试平台系列(36) 使用全局变量

2021-09-15 20:36:04  阅读:166  来源: 互联网

标签:解析器 变量 36 替换 JSON 测试 全局变量 取值 我们


测试平台系列(36) 使用全局变量

大家好,这里是老克,一个想和大家一起分享测试开发相关的技术,面试经验和成长经历的博主!

欢迎大家关注我的公众号: 测试开发坑货

回顾

上篇我们已经编写好了全局变量的页面,今天我们就来学习怎么使用他。

Windows下的环境变量

其实说白了,全局变量也就是一个参数的读取->替换的过程。所以我们得先补习一下el表达式的知识。(关于jsonpath,这个我不太熟悉,我不太算Java技术栈的)

我们都知道,在Windows等操作系统里面会有环境变量的概念,比如:

当我们echo %JAVA_HOME%的时候,为什么输出的不是"%JAVA_HOME%"呢?因为windows有相关的约定,当字符串被%%包裹的话,意味着取值会从环境变量里面寻找,如果找不到,就不进行替换:

这个变量不存在,所以不进行任何替换操作

EL表达式

这是我当时在上上家公司设计的一套变量表示语法,但是意外撞了EL表达式。我约定的是用${}包裹起来的内容都算作变量,这样在接口测试中如果有需要传递变量的情况,就可以用这个方式来解决。

EL表达式源自我现在正在维护的一个JSP的项目,也算是一种猿粪吧!

思路

我们现在支持3种变量类型: JSON/YAML/STRING。我们的步骤也很简单:

  1. 拿到变量的值(取值)
  2. 替换变量为对应的真实值(替换)

编写变量解析器

  • 编写解析器基类

基类有2个方法:

  • 解析

  • 取值

    解析是一个待实现的方法,因为不同的类型解析器不一样,未来如果需要支持XML类型,那也要重写这个方法。

    取值比较通用,目前来讲,我们解析完yaml以后也是一个json对象,所以可以写在基类中。

    我们来仔细看看这段代码:

参数部分

parse接受2个参数,data是解析后的数据(一般是JSON对象),key是el表达式的路径如: JAVA_HOME。但是我们不能只做最简单的,我们还需要获取深层次路径的值。

举个例子:

全局变量INFO的值是个JSON类型:

{
  "name": "wc",
  "age": 19,
  "hobby": "play game"
}

我们如果只通过INFO取到JSON对象,那是远远不行的,我们还需要能够通过INFO.age取到对应的年龄。所以我们这里编写了get方法。

实现过程

其实道理很简单,我们先通过.去分割字符串,如果是INFO.age,那么字符串就会成为: ["INFO", "age"]数组。接着我们从数组的第2个元素去遍历,如果取到的是数字,那么我们就按照数组索引去取值,如果是普通的key,就按照map来取值。

最后做一个异常捕获,防止那种乱写变量的情况出现。如果result是字符串,我们直接返回。如果是数字类型,那我们就将它转为字符串类型。

思考

因为我们现在是取值,后期替换的时候是用replace把${INFO.age}替换为对应的值,如果你的age是19这个数字的话,想一下replace会出错吗?

分别实现3种解析器

先看string类型,因为他自己不可能再去深层次取值了。

说到这里,我突然想到它可以直接索引去取对应的字符串子串,但是我不太建议支持这样的功能。因为索引需要2个值,1个的话比较鸡肋。这样对于我们的el表达式来说不是太统一。

所以我们直接return value,也就是不需要进行更深层次取值了。

再看JSON和yaml类型,其实就是load了一下数据(将字符串数据转为JSON对象)。

编写GConfigDao获取key的方法

之前我们的查询变量的方法,都是批量的,或者说是查询一个列表。我们需要一个更精确的搜索,只要一条变量的数据。

接受key的名字和对应的环境,如果环境不传的话,则不根据环境去查询。因为目前我们用例执行的时候没有跟环境绑定,所以暂时先不传入env,后续备用的字段。

这里想到了小方的疑惑,之前可能go写多了,下意识会把err return回去,现在改成Python的写法了。

改写用例的执行部分

在我的理解里面,用例的变量替换是在用例执行的第一步,并且替换的地方只有那几处:

  • url
  • request_header
  • body

因为目前还没有前后置条件,所以后续再补充,断言里的内容也如此,它们独立于用例之外了。

改造Executor类

  • 新增fields字段,存放需要替换变量的字段。

  • 编写parse_gconfig方法

    依次去修改各个字段中的变量。

  • 编写get_parser

    这个是根据gconfig类型来获取对应的解析器,如果0则为String解析器,1则是JSON解析器,2则是Yaml解析器。

  • parse_field

    这个方法是先获取原始字段里面的el表达式,然后依次去解析到真实数据,最后再修改TestCase的字段(注意只是临时修改,不修改数据表)。

目前代码优化点### 在run方法加上有2处:

  1. 通过key获取配置的时候,一旦一个字段里面出现2个参数的时候,会获取2次key,也就是查询db2次,这样开销很大
  2. 每次跑都会执行db,开销巨大,可以考虑本地缓存或者redis缓存。

修改run方法

--

看下效果

可以看到参数都已经进行了替换,我们再来看看变量BASIC_CONFIG的内容:

--

那么,本期内容到这里就结束了。

在线演示地址: http://test.pity.fun/

前端代码仓库: https://github.com/wuranxu/pityWeb

后端代码仓库: https://github.com/wuranxu/pity

标签:解析器,变量,36,替换,JSON,测试,全局变量,取值,我们
来源: https://www.cnblogs.com/we8fans/p/15286622.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有