- 纳思达:目前公司正全面推进智能制造升级已经拥有通用耗材自动化产线FB体育 FB体育平台
- 利用自动化平台可以FB体育 FB体育平台做的那亿点事
- FB体育 FB体育平台广西贵港:田间“无人驾驶”耕田5公里内可以实现远程全自动化
- FB体育 FB体育平台大语言模型自动化平台 Fixie 获得 1700 万美元融资:支持 OpenAI 的 GPT-4 开箱即用
联系人: 张生
手机: 13800000000
电话: 400-123-4567
邮箱:
地址: 广东省广州市天河区88号
利用自动化平台可以FB体育 FB体育平台做的那亿点事
相信大家对接口自动化已经不陌生了,这是几乎我们每个迭代都会投入的事情,但耗费了这么多精力去编写和维护,实际的收益如何呢?如果收益不好,是不是说明我们自动化case的实现方式、使用方式还有改进的地方呢?以下是接入得物接口自动化平台后的一些实践和想法,欢迎大家积极交流~
在接入自动化平台前,我们只能本地拉取代码-执行用例,所以执行者也只有测试人员。接入平台后,通过宣导or分享,开发可以方便的找到需要的用例(用例模块和标题需描述清晰),从而帮助他们造数或自测。
对于一些核心场景,即使业务迭代,通常结果也不会发生太大变化,这一类的场景case如果设计地较为稳定(当然这里的稳定不是只校验code=200就行),可以分享给开发用于自测,根据开发同学使用后的反馈,他们自测简单了许多,也有帮助他们发现过问题。
另外有一些本迭代内的新增接口,在接口评审完成后,我们可以提前编写好,根据具体情况决定是先保证接口状态的正常,后续再补充数据逻辑的校验,还是直接先把case写好。因为很多时候开发自测都只是调用本地代码,提测后连接口都调不通,如果提测前可以先进行基本的校验,就能减少冒烟测试被阻塞的概率。
冒烟测试:针对改动点挑出涉及的接口case,再加上P0级别case,提测后先执行一遍看看是否正常,如果核心链路异常,阻塞了后续测试,就可以直接打回了。
验证bug:有些复杂场景,测试链路较长,测试数据准备又很困难,很容易出现bug,而出现bug也就算了,偏偏改一遍还不一定能改好...这时候自动化的价值就体现了,把这些场景利用自动化实现,验证bug时直接一键执行就能得出结果,大大节省了时间,同时也稳定了自己濒临暴躁的情绪。
回归测试:在每次的bvt测试、覆盖率跟进中,有些case可能并不涉及本次需求改动范围,场景又比较简单基础,我们就可以利用自动化去覆盖。执行通过,视具体情况可以简单看一眼或者不再回归。
虽然我们现在有了造数平台,但实现起来有一定的成本,一些场景可能除了自己没有别的业务方有造数需求,并且场景很简单,只需调个接口,改个数据表就行,那么最快的造数方法就是自动化脚本。现在有了自动化平台,我们可以更好地分享给有造数需求的开发、产品、测试。
当然,以上效果的前提是我们的自动化case比较 稳定 ,不能每次执行都一堆不通过,这样时间都耗费在排查问题上了,效果会大打折扣,别人也不会再愿意使用。
通常一部分同学会在用例评审结束,开发提测之前进行case编写,此时需要实现自动化的场景已经明确,基本上涉及的接口和出入参都已确定,自动化case的大致框架就形成了。 这时候实现自动化,就可以最大化地发挥其价值,在上述涉及到的几个场景都能投入使用。如果因为时间不够或接口尚未明确,可以先梳理好需要实现自动化的场景步骤,在提测后一边手动执行用例一边补充接口参数和校验点。针对级别较低的接口场景,也可以放在版本结束后再实现,只是效果会降低一些。
我们维护的case一般有两种,一是自己写的,二是别人写的。 自己写的,含着泪也要日常维护。 别人写的,由于大家的编码风格千差万别,在接入自动化平台前,维护起来简直困难重重,当我们为了通过率去推进case更新时,往往这一类的难以推进。 现在接入了平台,基本上统一了case模板,当因为需求变动需要更新时,有时只需要修改出入参和断言即可,一定程度上已经降低了维护成本。
另外,当case经常报错时,可以看看设计上是否能优化。 有些依赖性强的数据,是否可以通过其他手段让这部分数据稳定下来。 比如发优惠券的场景,前提需要一张有效的券,那我们在发券前可以先获取一张有效的券信息,或者在发券前先创建一张券,发完券后如果需要对券信息进行校验,也通过变量的方式。 针对单个测试点实现自动化时,可以尽可能地与其他测试点解藕,充分利用前置脚本,通过修改数据表等方式较少依赖。 case中也可以设置失败重试次数,减少由于环境不稳定等原因造成的失败。
举个例子:“得物App新客人群领取优惠券并触发金额膨胀,多次触发膨胀应该只有一次膨胀成功”。
这个case在迭代中提高了测试效率,并且在后续需求变更时,帮助开发自测,解决造数问题并发现了bug。
由于业务特性,只有命中实验组的新用户才可领券。那么首先需要创建一个新用户,并添加到ab白名单。然后在领券前先对领券状态、用户身份进行校验;
因为后台会配置3套券,初次领券成功后,只会发放其中一套,所以在对领券接口的出参进行基本校验后,还需对券记录进行详细的检查,就需要使用后置脚本,获取到券配置后再对数据表进行核对,需要校验的表包括业务本身的领券记录表和优惠业务侧的账户表;
领券成功后进行膨胀。查询优惠侧账户表,将查询结果作为变量,在下一个接口的前置脚本中,进行券到账的校验;
再次膨胀,应膨胀失败,校验接口code非200,再次核对券表,校验确实只到账了一张券。
2.2 公共组件的编写一些需要重复调用的功能,我们可以写成公共组件,不仅方便自己,也方便他人。 在编写组件时,如果有入参,需要考虑参数值有可能是局部变量的场景。以下面的组件为例,实现的功能是通过数据库查询优惠券发放记录表,可以针对用户ID、优惠资产ID进行查询。考虑到这两个参数有可能是局部变量,由于目前公共组件类型的入参不支持${}参数类型,所以换一种方式来实现 —— 设置2个入参,一个为对应的value,一个为局部定义的key。脚本中,如果value未获取到,则去变量空间中获取局部变量。 拿到查询结果后也要尽可能的把结果存到变量空间,以供后续步骤的使用。
配置平台用例计划,选择依赖应用,按照自己的需要选择执行频次。然后再编辑计划,配置匹配规则,可以看到关联的自动化用例。
在用例平台绑定自动化case,在转测单平台添加自动化计划,已关联的用例在执行结束后会自动更新执行状态,提高手动执行的效率。
解决方法二:redis平台工具返回是数据是 bytes 类型,需要encoding一下
接入自动化平台后,方便了很多,也还有更多的使用场景待探索和交流。自动化最主要的目的是提效,时间节省下来后我们可以有更多的时间去思考异常场景以及复杂场景,做一些探索测试,减少因为用例设计遗漏而发生的问题。
特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。
周鸿祎突然离婚,被质疑“离婚式减持”,360董秘怒斥:谁要说我给老板出这种套现策略,我跟谁玩命!
周鸿祎离婚,20多年前,他们从网恋开始,他是小工程师,她是“方正之花”
广东省2023年春季高考录取正式开始 志愿资格线年普通高等学校招生 体育专业考试准考证打印通道开启
微软Surface Dock 3照片泄露:换用Type-C接口,支持雷电4