Google软件测试之道

GTA: Google实现ACC模式建模的工具

  • Attribute 特质:产品特点
  • Component 组件:功能模块
  • Capability 能力:操作响应

每一个可测能力都可描述为:组件满足特质的一个能力


GTA可生成风险热图

  • 颜色区分测试的优先级或者隐私级别
  • 清晰的测试依据
风险热图,案例见《Google软件测试之道》90页

其中:红色高风险能力和特质组件对,要编写一系列测试用例



等价划分:把测试案例组合缩减到仍足以测试软件的控制范围

一、静态黑盒测试

测试产品说明书,在编写软件前查找问题

二、动态黑盒测试

不了解软件如何工作的前提下测试软件

1).数据测试
1.边界条件
  • 根据边界选择等价划分包含的数据
  • 测试最后一个合法数据和超过边界的非法数据
2.次边界条件
  • 边界条件位于软件内部(如输入2的乘方、ASCII表)
3.默认、空白、空值、零值、无的等价空间
4.垃圾数据 (破坏性实验,输入要求以外的数)
2).状态测试
  • 选一项,软件改变外观、菜单或某些操作,即改变状态
1.建立状态转换图,包含:
  • 软件可能进入的每一种独立状态
  • 一种状态转入另一种状态所需的输入或条件及结果
状态转换图例,案例见《软件测试》Ron Patton著 58页

其中:

  • 每种状态必须访问一次
  • 测试最常用(针对用户)及最不常用分支(针对产品及开发)
  • 测试所有错误状态及返回值
  • 测试状态随机转换
3).失败状态测试
1.竞争条件:多任务同时访问内存、硬件资源等
2.重复、压迫和重负
  • 重复:检测内存是否不足
  • 压迫:限制软件的必要条件,在不理想条件下运行(内存小、CPU慢等),检测软件对外部资源和要求的依赖程度
  • 重负:尽量提供条件,最大限度发掘软件能力
4).其他测试

在已找到缺陷的地方再找

三、静态白盒测试

通过正式的审查和检查代码的细节

1).正式审查
  • 要素:确定问题、遵守规则、准备、编写报告
  • 过程:同事审查-->公开陈述-->检验(最正式)
2).编码标准
3).通用代码审查清单
1.数据引用错误
  • 使用未经正确初始化和引用方式的变量、常量、数组、字符串
    a.是否引用未初始化变量
    b.下标是否为整数且在范围内
    c.数组下标从零开始
    d.应使用常量的地方用了变量
    e.变量是否赋于不同类型值
    f.引用的指针是否分配内存
    g.一个数据结构是否被多处引用并声明
2.数据声明错误
  • 不正确声明或使用变量、常量
    a.变量长度、类型是否正确
    b.声明时是否正确初始化
    c.相似的变量名称
    d.声明但未引用过的变量
3.计算错误

a.不同数据类型计算
b.编译器对类型、长度不同变量的转换规则
c.是否有计算溢出
d.除数为0
e.精度丢失
f.计算结果是否超过有意义的范围(概率大于1小于0等)
g.运算的优先级,可否用括号

4.比较错误
  • 大于小于等于不等于、真假
    a.精度是否影响分数/浮点值的比较
    b.求值次序
5.控制流程错误
  • 循环等控制结构未按预期工作
6.子程序参数错误
7.输入/输出错误

a.软件是否严格遵守读写专用格式
b.外设不存在、未准备好等错误情况是否处理
c.读写过程存储空间占满

8.其他检查

a.是否使用外语、拓展ASCII字符、统一编码取代ASCII
b.是否要移植到其他编译器和CPU
c.兼容性

四、动态白盒测试(结构测试)

看到软件工作方式根据获取的信息对软件进行测试

  • 根据代码功能和实现方式确定哪些要测试
  • 在白盒测试前,先建立根据说明书黑盒测试案例
  • API测试
  • 获取变量及状态访问权以便确定结果与预期是否相符
  • 估算测试命中代码量和具体代码,然后调整测试,去掉多余补充遗漏

另:测试--寻找软件缺陷、调试--修复缺陷

1.单元(模块)测试、集成测试
  • 底层进行的单元测试集成在一起进行集成测试

a.数据流:跟踪数据,在程序运行期间检查立即值
b.次边界
c.公式和等式
d.错误强制:迫使软件所有错误提示信息显示出来,不是检测错误的代码

2.代码范围分析
  • 测试程序的状态以及其中的程序流程

  • 方式:利用调试器单步执行程序查看代码或者代码范围分析器
    a.找出测试案例没有覆盖的部分则其模块代码从未执行,要额外编写该模块测试案例。
    b.执行一系列测试但未增加代码覆盖百分比,则这些案例可能处于同一等价区间

  • 分支范围:覆盖软件中所有路径

  • 条件范围:测试所有可能条件达到分支覆盖、语句覆盖

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容

  • 文章来自:http://blog.csdn.net/mj813/article/details/52451355 ...
    好大一只鹏阅读 9,186评论 2 126
  • 1.测试与软件模型 软件开发生命周期模型指的是软件开发全过程、活动和任务的结构性框架。软件项目的开发包括:需求、设...
    宇文臭臭阅读 6,702评论 5 100
  • 1.测试与软件模型 软件开发生命周期模型指的是软件开发全过程、活动和任务的结构性框架。软件项目的开发包括:需求、设...
    Mr希灵阅读 21,925评论 7 277
  • 1.问:你在测试中发现了一个 bug ,但是开发经理认为这不是一个 bug ,你应该怎样解决。 首先,将问题提...
    qianyewhy阅读 9,230评论 4 123
  • 波澜壮阔, 一直认为自己此前的生活配得上这四个字。 现在, 回归平淡。 思绪偶尔触及那些过往, 还是不由心生鸡冻。...
    昂日康勒阅读 673评论 0 1