今晚在某个测试群,看到有人问了一个问题:把测试数据放配置文件读取和放文件通过函数调用读取有什么区别?

当时我下意识的这么回答:数据量越大,配置文件越臃肿,放在专门的数据文件(比如excel,csv),方便针对性的维护。

乍看没毛病,但回头和人讨论这个问题的时候,就认真思考了一下这个问题,下面是我的一些思考和讨论的一些结果,仅供参考。。。

自动化测试过程中,现在大多都默认测试脚本与测试数据分离的设计,这样做的好处是:降低维护成本,迁移成本以及提高效率。

因此测试数据放在哪里,如何管理,不能一概而论。个人觉得应该从以下几方面来考虑:

1、业务场景

①、比如在UI自动化测试中,需要测试某个电商网站的各个业务模块,但前提是要用户登录。这个用来执行登录的测试账号数据往往是固定的,那么专门将

  一组username和password放在一个测试数据文件或者测试数据库中,这样就显得太笨重,耗时费力。将其写入测试脚本或者写入配置文件,直接引用效率会更高。

②、同样,测试电商网站,账号体系分为普通账号,会员账号,会员还分很多等级,有时候为了测试会员中心不同的账号展示的信息是否不同,就需要使用不同的

  等级的账号登录,这种场景下,可以将测试数据放在测试文件里(比如excel、csv),通过参数化的方式来循环读取,执行后续操作。

③、在API自动化测试中,比如针对restful风格的接口,它的域名相对来说都是固定的,只是不同接口的path不同,那么也可以将域名写入配置文件,

  测试过程中只需要将实例化的域名和path进行拼接即可,这样也省却了在测试数据文件中维护的成本,一定程度上提升了测试效率。

2、数据类型

测试数据也分不同类型,大概分为以下几种类型:

base-data:即基础数据,比如电商网站的商品信息、SKU,比如物流公司的仓储管理等,这类数据往往基数比较大,可以视为持久层,储存在DB中;

test-data:测试数据,根据业务场景不同,数据无论量级还是变更频次也不同,基于测试脚本与数据分离的概念,可放在专门的测试文件中,比如excel、csv;

ephemeral-data:临时数据,即使用一次的数据,这种类型的数据可以用临时文件存储(比如dat、csv等)格式,然后进行参数化读取,或者直接写入脚本中;

3、数据量级

①、还是电商网站的某个场景,需要先执行登录,登录的账号比如是专门配置的一个测试账号,相对固定,那么将测试账号写入测试脚本也无可厚非。

  不过我本人不喜欢将测试数据直接写入脚本,这种情况我会写入配置文件,然后实例化调用,这种情况就需要根据个人习惯来设计,没有固定的套路;

②、数据量级在几十——几百上千之间,这种时候,可以写入excel文件进行存储管理,但是excel的局限在于其本身目前最大支持65500+行的数据存储,

  而且只支持单事务,如果需要多线程读取,就会变成瓶颈。

③、csv文件,结构简单、通用,可以和excel进行转换,可以减少存储文件size,且具备简单的安全性,可以在一定程度上替代excel成为数据存储文件。

  我本人目前在大多数场景下也是使用csv类型的文件进行测试数据存储管理;

④、当测试数据超过一定量级,比如性能测试中,如果要执行并发测试或者稳定性测试,那么所需测试数据量级就很大,这时使用excel或者csv就会变得很不方便。

  无论是从维护的成本还是便捷性考虑,都应该选择利用DB或其他高效的管理方式来存储和管理测试数据;

4、使用频次

测试数据的重用频次不同,也需要选择不同的存储方式,比如:

①、once:只使用一次的测试数据,那么只需要写入临时文件,用完作废或者删除即可;

②、often:即经常使用的测试数据,应根据数据量级,使用场景,数据类型选择合适的存储管理方式;

③、alway:可以理解为base-data或者持久数据,这种类型的数据因为其本身更新频次很低,或者数据量级较大,一般存储在DB中是比较好的一种管理方案。

综上所述,测试数据的存储和管理,没有固定的套路,需要结合业务场景,使用频次,数据类型和数据量级来综合考虑,设计合理高效的方案,才是正确的方式!

内容仅供参考,如有更好的建议,希望评论提出,谢谢。。。

转载于:https://www.cnblogs.com/imyalost/p/9235773.html

自动化测试中,测试数据如何管理?相关推荐

  1. JAVA 自定义注解在自动化测试中的使用

    在UI自动化测试中,相信很多人都喜欢用所谓的PO模式,其中的P,也就是page的意思,于是乎,在脚本里,或者在其它的page里,会要new很多的page对象,这样很麻烦,前面我们也讲到了注解的使用,很 ...

  2. 自动化测试中的反省与总结

    背景:这是在公司UI自动化项目结束后,个人回顾整个项目的过程时,发现走过的弯路或者个人觉得可以改进的地方. 1. 模块划分:(这个需要有一定的业务基础,梳理出初始配置,尽量将各模块划分地高类聚低耦合) ...

  3. 测试中缺陷的管理流程

    了解软件缺陷判定标准 了解项目中缺陷的管理流程 使用Excel对于缺陷进行管理 掌握禅道工具管理缺陷 一.缺陷介绍 1.缺陷定义:软件在使用过程中存在的任何问题都叫软件的缺陷,简称bug. 2.缺陷判 ...

  4. IT:前端进阶技术路线图(初级→中级→高级)之初级(研发工具/HTML/CSS/JS/浏览器)/中级(研发链路/工程化/库/框架/性能优化/工作原理)/高级(搭建/中后台/体验管理等)之详细攻略

    IT:前端进阶技术路线图(初级→中级→高级)之初级(研发工具/HTML/CSS/JS/浏览器)/中级(研发链路/工程化/库/框架/性能优化/工作原理)/高级(搭建/Node/IDE/中后台/体验管理/ ...

  5. Swift 中的内存管理详解

    这篇文章是在阅读<The Swift Programming Language>Automatic Reference Counting(ARC,自动引用计数)一章时做的一些笔记,同时参考 ...

  6. 跟着石头哥哥学cocos2d-x(三)---2dx引擎中的内存管理模型

    2019独角兽企业重金招聘Python工程师标准>>> 2dx引擎中的对象内存管理模型,很简单就是一个对象池+引用计数,本着学好2dx的好奇心,先这里开走吧,紧接上面两节,首先我们看 ...

  7. 一文详解启发式对话中的知识管理 | 公开课笔记

    来源 | AI科技大本营在线公开课 分享嘉宾 | 葛付江(思必驰 NLP 部门负责人) 整理 | Jane [导读]自然语言对话系统正在覆盖越来越多的生活和服务场景,同时,自然语言对话的理解能力和对精 ...

  8. Linux系统中的软件管理

    Linux系统中的软件管理 1 Linux中软件包的类型 2 软件包的名称结构 3 rpm命令管理软件包 4 本地软件仓库的搭建 4.1 系统软件仓库的作用 4.2 搭建方法 5 dnf 软件管理命令 ...

  9. linux系统中的日志管理

    Linux系统中的日志管理 1 实验环境 2 journald日志服务 2.1 journalctl命令的用法 2.2 用journald服务永久存放日志 3 rsyslog日志服务 3.1 自定义日 ...

最新文章

  1. STM32系列--初识寄存器1
  2. 【数据库系统概论】考研第六部分重点分析【6.1】
  3. 用户信息填写web代码_Web前端常见问题汇总
  4. person p = new person();_Python函数__new__及__init__作用及区别解析
  5. java回车不终止_java 在console行输入一串String后回车,仍无法停止。 下面的程序是计算相似度的,当用户输入关键字后...
  6. 系统升级时,数据库脚本执行注意事项,血的教训
  7. 可能有用的技术社区(转载)
  8. 分享Three.js 泛光(眩光)效果实现
  9. 第十一次作业 - Alpha 事后诸葛亮(团队)
  10. 计算机应用线型类型为虚线方点,cad怎样把线变成虚线或者点划线
  11. 最后一天了(再见了)
  12. 设置服务器防火墙对应的出入站规则
  13. SOD-323封装尺寸图
  14. 使用切换器导致一台电脑分辨率被降低的解决方法
  15. VMware Ubuntu20网络设置和DNS设置
  16. 记一次线程池引发的BUG,差点被祭天
  17. CC00016.kylin——|HadoopOLAP_Kylin.V16|——|Kylin.v16|Cube优化|检查Cuboid数量|
  18. 《电子计算机机房设计规范》(GB50174-93)
  19. 今天高考╮(╯▽╰)╭
  20. 人工智能:遗传算法稀布阵列天线

热门文章

  1. 对软连接进行cp,rm
  2. chrome浏览器插件开发经验(一)
  3. 刷题向》关于一道比较优秀的递推型DP(openjudge9275)(EASY+)
  4. TinyXml高速入门(一)
  5. Java学习之 多态 Polymorphism
  6. 计算机网络---物理层
  7. CentOS 7 + MySql 中文乱码解决方案
  8. 分别使用委托、接口、匿名方法、泛型委托实现加减乘除运算
  9. Esper系列(十二)Variables and Constants
  10. Matlab标识指令中字符的精细控制