大话测试数据(一)

转自:skytraveler 的 大话测试数据(一)

2015-11-17、

目录:

1 测试数据为什么重要
2 测试数据的分类
  2.1 从测试数据的生命周期角度划分
  2.2 从业务角度来看数据划分
  2.3 从测试数据来源来划分
3 测试数据的生成过程

测试数据在整个测试过程中扮演着极为重要的角色,但是它却像个没有星象的演员,明明至少是男二号,但总是被观众忽略。在测试过程中,我们往往在测试计划阶段就忽略了测试数据,在起先没有给测试数据的设计、准备留出足够的时间,投入足够的精力,到了测试执行阶段追悔莫及。只有吃过大亏的测试人员,才会在下一个测试开始的初期就认真的对待它。楼主也算是吃过亏的人。因此在现在经手的测试工作中,总会提着测试数据这根弦。今天一个网上的一个同学问了一个关于测试数据的问题,随手回答了一下以后,发现自己其实已经积累了一些经验了。现在把它们总结出来,供大家讨论。欢迎提出各种建议和各种问题,我会试着作出解答。

1 测试数据为什么重要


  返回

1.最浅显的道理:说白了测试用例的执行工作主要是做一些输入操作,然后观察输出。测试数据就是输入的内容,没有测试数据,你咋执行用例?

2.测试数据是测试设计的重要组成部分,测试用例的有效性严重依赖测试数据的选取或者设计,要记住测试的本质是抽样,样品的选取其实是一门深奥的科学,有学过统计学的同学会深切明白这个道理。

3.没有把测试数据这一块儿理顺,良好的自动化测试简直是空谈。试想,测试自动化采取的最普遍默模式就是“录制-回放”模式,如果搞不定数据,回放基本上会失败,自动化验证自然也就无法有效完成了。

4.测试数据能够启发测试设计。做测试多的同学都会有过选取一组测试用例后来了感觉发现自己思如泉涌的经历。

5.如果是已上线系统,或者生命周期较长的系统,从生产系统上log下来的数据可以很好的指导测试。(通过一些统计可以帮助识别那些业务重要,为能够制定正确的测试策略提供重要信息;对数据做pattern分析的话可以用于补充测试场景、用例,同样十分有益;这些数据还可以在测试中进行复用)。

  6.其它种种好处。。。

2 测试数据的分类


  返回

     我们可以从多个维度对测试数据进行分类,下面讲一下我的分类方式:

2.1 从测试数据的生命周期角度划分

可以将测试数据分为:稳定和数据可消耗的数据混合类型数据

  • 稳定的数据:在一轮/多轮测试执行过程中几乎不会发生变化的数据,如常见的电商系统中的一些基础数据--城市,邮政编码,一些商品的属性,如衣服尺寸码等。
  • 可消耗数据:测试执行完某个步骤后,数据发生不可逆改变,或者发生逆转操作需要耗费大量精力的改变。这类数据的例子有:商品的库存,票务系统里的票,要被                    夜维程序删除的过期数据,网络数据包等等。
  • 混合类型数据:某些数据是复合型数据,如XML结构或者Json结构的某些数据,一条数据中的一部分是稳定的数据,另一部分是可消耗数据,这样的例子其实很常见,一般这样的数据会被当做可消耗数据来处理。

  从数据是否可构造的角度来看可以将测试数据分为:可直接构造数据需要间接获取的数据

  • 可直接构造的数据:常见系统的大部分数据都可以直接被构造,通过操作系统本身,或者通过调用某些接口(SQL也算接口)插入数据,有时候甚至这些数据就是文本,直接准备好他们就行了。
  • 需要间接获取的数据:手工制造成本太高(理论上我们可以制造所有测试数据,但有时候就是成本太高),如某些以二进制存储的含有信息的数据(被序列化的数据),某些非文本数据,例如音频数据,视频数据,传感器上传过来的极为复杂的带有某些pattern的数据。举个很好玩的例子,见过“猎曲奇兵”这款软件么?偶然听到一首歌,打开猎曲奇兵,十秒钟左右它就能告诉你是哪一首歌。你基本上无法自己创造一条有效的测试数据,除非你是张学友或者Lady Gaga。

2.2 从业务角度来看数据划分

可以分为:合规数据非合规数据、Fuzz数据

  • 合规数据:望文生义,就是符合业务规则的数据,如能够通过校验的身份证号。
  • 非合规数据:显然就是不符合业务规则的数据,当你被要求输入注册邮箱的时候,你给出这样的输入:skytraveler@@163.com 显然不会合规。 
  • Fuzz数据:Fuzz数据主要是利用一些工具生成的乱七八糟的数据,主要用于系统稳定性测试和安全测试。这是一个大话题,有兴趣的话推荐看《模糊测试》这本好书。

2.3 从测试数据来源来划分

可以分为:生产dump数据自己生成的数据 

上面的分类其实并不是很准确,但是分类就是为了帮助更高效的解决问题。接下来我会讲解对于上面类型的数据我是如何来处理的。

3 测试数据的生成过程


  返回

  概念上的数据:也就是抽象的数据,例如,你的被测物是一款收银软件,你知道每笔交易结束后,需要生成一张“发票”,见过发票的你大概知道 它长什么样子(如下图),“发票”就是概念上的数据,但它并不能直接使用。

  

  被细化了的数据:也就是具体的数据项。拿到发票后,我们还要分析发票里到底有哪些数据,经过需求的获取及分析,我们知道发票包含:发票日期,发票代码,付款方,收款方,金额,防伪码,二维码等。同时我们也知道了这些数据的规约,例如,发票的日期格式是:yyyy年mm月dd日。

真正能使用的数据:我们知道了数据的细节,就可以按照这些细节准备被测系统能够识别和接受的数据了。例如,上面所说的发票付款方,收款方,真正的操作可能会直接在GUI中输入,或者可以调用某些接口,或者可以直接插入数据库。这时候你要做的就是,让你的数据变得能用起来。

  从上面的解释可以得到测试数据从被识别,到能够被使用的大体步骤:

事实上,实际工作中,测试数据的准备远远不是这么简单。很多时候上面的每一步骤的推动都是一个艰苦的过程。搞定它需要柯南一样抽丝剥茧的能力和工匠的细致和耐心。我会尽量在后续的文章中讲述一些我的经验。

转载于:https://www.cnblogs.com/Ming8006/p/4971212.html

【转】大话测试数据(一)相关推荐

  1. 大话测试数据(二):概念测试数据的获取

    在大话测试数据(一)文章中,我提到,获取数据的第一步是获取概念上数据.这一步看起来简单,其实不是那么容易.获取概念数据和获取需求的过程是交织在一起的,事实上,它们其实是一个事儿,因为数据是需求中最重要 ...

  2. 大话测试数据(三):如何获取细化的测试数据?

    导读 :无论是手工测试还是自动化测试都要以良好的测试数据准备为基础.本文为霍格沃兹测试学院特邀嘉宾,某互联网巨头企业资深测试技术专家刘晓光(skytraveler)老师对测试数据管理实践的系列文章第三 ...

  3. 《大话数据结构》1、2数据结构、算法

    大话数据结构 大话设计模式 head first设计模式 Java核心技术 卷1 深入理解Java虚拟机(JVM高级特性与最佳实践) 图解HTTP 大话数据结构 数据结构介绍, 算法推导大O阶的方法, ...

  4. 数据结构与算法笔记(王卓网课+教材+大话数据结构)

    数据结构与算法笔记(王卓网课+教材+大话数据结构) ##最新整理!!! 顺序存储结构的线性表P10-P21 顺序线性表的代码实现 链式线性表笔记 串笔记 绪论.算法(P1-P9)1.4数据起源结构 数 ...

  5. 【大话设计模式】——浅谈设计模式基础

    初学设计模式给我最大的感受是:人类真是伟大啊!单单是设计模式的基础课程就让我感受到了强烈的生活气息. 个人感觉<大话设计模式>这本书写的真好.让貌似非常晦涩难懂的设计模式变的生活化.趣味化 ...

  6. 【cs229-Lecture2】Linear Regression with One Variable (Week 1)(含测试数据和源码)

    从Ⅱ到Ⅳ都在讲的是线性回归,其中第Ⅱ章讲得是简单线性回归(simple linear regression, SLR)(单变量),第Ⅲ章讲的是线代基础,第Ⅳ章讲的是多元回归(大于一个自变量). 本文的 ...

  7. 软件测试数据存储位置,关于数据存储类型的一点分析

    简介 SQL Server每个表中各列的数据类型的有各种形式,产生的效果也各有不同,我们主要根据效率兼顾性能的情况下讨论下如何规定类型. 在SQL Server中,数据的存储以页为单位.八个页为一个区 ...

  8. 论文:基于粒子群优化的测试数据生成及其实证分析-----生成过程以及实验(计算机研究与发展)

    来源:2012年版的计算机研究与发展期刊 基于PSO的测试数据生成 (1) 核心问题:  如何保证PSO搜索算法和测试过程的协作运行  算法的基本的流程: (1)对被测程序P进行静态分析并完成: 1. ...

  9. 格式化测试数据,组装用于插入表中的sql语句

    最近闲的蛋疼,每每在写测试例子的时候,万恶的测试数据需要手工书写insert语句的向表中插入,很费事,于是就像写个脚本来实现自动生成插入语句 测试数据: 100 北京 20120203123 100 ...

最新文章

  1. 抓包分析connect函数
  2. Docker 安装MySQL以及外部访问
  3. python中国内源_【文】Python更换国内镜像源
  4. python版本回退_Python爬虫之BeautifulSoup解析之路
  5. linux 关闭桌面环境,Ubuntu 14.04上的Cinnamon桌面环境PPA被关闭
  6. 大数据(9) - Flume的安装与使用
  7. 训练日志 2018.9.5
  8. windows 8.1 IE11 和 windows 10 Edge IE11 FlashPlayer 的安装与卸载
  9. ESP32 开发之旅② Arduino For ESP32说明
  10. braft中AppendEntries逻辑
  11. 解决UBUNTU NVIDIA驱动安装后循环登录问题:关闭UEFI Secure Boot选项
  12. 计算机能不装显卡么,电脑不装显卡能玩CF吗
  13. 倒计时小插件,懒人专用
  14. 2022 CNCC 中国计算机大会参会总结
  15. 大家保险发布“早下班一小时”倡议,呼吁“重阳节,不脱节”
  16. 【高德地图】iOS 开发汇总(一)
  17. 2019数据结构考研复习指导习题代码(王道论坛)
  18. python处理中文乱码现象
  19. 【SpringBoot学习】5、SpringBoot 实现文件上传,图片上传并显示功能
  20. 从零开始之驱动发开、linux驱动(六十六、内核调试篇--printk原理)

热门文章

  1. 以太坊区块包含什么?区块时间?区块大小
  2. 下一代无线局域网演进趋势
  3. [实践篇]13.14 如何在QNX侧,打印日志到slog2info缓冲区
  4. Linux下利用文件描述符恢复的成功失败实验
  5. 招沿实业投资理财二三事教你轻松钱生钱
  6. QT_C++08-Qt实战-QQ聊天
  7. 【问题与方法】联想拯救者双系统重启卡死机解决方案
  8. 【Linux】Linux超全实用指令大全
  9. Ps 初学者教程「64」如何在照片中创建纹身合成?
  10. 早起的鸟儿有虫吃-JSTL核心标签库[收藏]