《Google软件测试之道》之学习笔记01

时间:2022-09-22 13:32:19

Google软件测试介绍

软件测试团队->工程生产力(Engineering Productivity)

http://googletesting.blogspot.com/2011/01/how-google-tests-software.html

1.1 质量不等于测试

质量不是被测试出来的,质量不等于测试,每写完一段代码立刻测试这段代码,当完成更多的代码时做更多的测试,直到开发和测试融为一体,才能得到质量。

1.2 角色

"You build it, you break it, you fix it"

软件开发工程师(SWE: Software Engineer)

增加功能性的代码或提高性能的代码

对容错设计、故障恢复、测试驱动设计、单元测试负责

软件测试开发工程师(SET: Software Engineer in Test)

关注于质量的提升和测试覆盖率的增加,增加可测试性,甚至进行代码重构,编写单元测试框架和自动化测试框架

提供测试支持

软件测试工程师(TE: Test Engineer)

专注于用户角度的测试,模拟用户使用场景、编写自动化脚本或代码,组织各种类型的测试,分析、解释测试运行结果,驱动测试执行

模块级别和功能级别的测试应有SWE和SET完成

TE需要确认开发人员的测试工作是否到位,任何明显的bug都表明早期开发人员的测试工作存在不足或比较马虎

TE应更注意常见用户使用场景,是否满足性能期望,在安全性、国际化、访问权限等方面是否满足用户需求

与各方讨论基本设计带来的风险、功能逻辑复杂性和错误避免的方法

1.3 组织结构

一般,测试和开发人员隶属于同一个工程产品团队,管理者通常来自产品经理或开发经理,测试总是给开发让路

SET和TE没有遵循这个模式,测试成为一个独立的部门,平行于各个产品部门,测试人员以租借的方式进入产品团队,不直接向产品团队汇报

1.4 爬、走、跑

Google在一个产品的核心功能实现后立即发布,然后根据用户反馈再进行迭代

Chrome开发过程中的版本:

金丝雀版本:每日构建,排除明显不适宜的版本,这个版本可能无法使用应有的基本功能

开发版本:开发人员日常使用的版本,每周一个。具备一定的功能并通过了一系列的测试。所有相关的工程师都需安装,在日常使用,如不满足日常工作的需求,会被打回金丝雀版本

测试版本:通过了持续测试的版本,是最近一个月里最好的版本,也是工程师在日常使用中最稳定最信任的版本。可作为内部尝鲜(dog food)版本,若变现持续优良,可作为beta版本的候选

beta版本或发布版本:有非常稳定的版本演变而来,经历了内部使用和通过了所有质量考核

1.5 测试类型

小型测试

一般都是自动化实现的,用来验证一个单独函数或独立功能的代码是否按照预期工作,着重于典型功能性问题、数据损坏、错误条件和大小差一(off-by-one)等错误

运行时间短,通常在几秒或更短的时间内完成

由SWE来实现,少量有SET参与,TE几乎不参与,但TE会运行这些测试

测试一般需使用mock和fake才能运行

mock对象是指对外面依赖系统的模拟,在运行时刻可以根据假设的需求提供期望的结果

fake对象是一种虚假的实现,内部使用来固定的数据和逻辑,只能返回特定的结果

中型测试

一般也都是自动化实现的,会涉及两个或两个以上的模块之间的交互

测试重点在于验证这些“功能近邻区”之间的交互,以及彼此调用时功能是否正确

SET会驱动这些测试的实现和运行,SWE会深度参与,编码、调试和维护这些测试,开发后期,TE会通过手动或自动的形式执行这些测试

大型测试

涵盖三个或以上的模块,使用真是用户使用场景和实际用户数据

一般需消耗数小时或更长时间才能运行完成

SWE、SET、TE都会参与其中

关注端到端的使用场景以及在整个产品或服务之上的操作行为

小中大型测试,相当于单元测试、集成测试和系统测试

能够自动化的应以自动化的方式实现,包括日常工作

回归测试中手动部分可通过定点点击或录制技术实现自动化,手动测试更倾向于关注新功能

《Google软件测试之道》之学习笔记01的更多相关文章

  1. 《Google软件测试之道》心得笔记1

    Google软件测试介绍 把开发和测试融合在一起——开发和测试必须同时展开 开发人员自己要对自己写的代码负责,比专职的测试人员更适合做测试工作. 测试开发工程师SET 对于Google拥有很少量的测试 ...

  2. 《Google软件测试之道》基础

    <Google软件测试之道>,一直听朋友讲起这本书,出于琐事太多,一直没机会拜读,最近部门架构觉得我们IT部门的技术太low,就给我们挑选了一些书籍,让我们多看看... 个人的一种学习习惯 ...

  3. 《Google软件测试之道》简介

    <Google软件测试之道>,一直听朋友讲起这本书,出于琐事太多,一直没机会拜读,最近部门架构觉得我们IT部门的技术太low,就给我们挑选了一些书籍,让我们多看看... 个人的一种学习习惯 ...

  4. 小课堂week14 Google软件测试之道

    读<Google软件测试之道> 在IT领域,Google是一面旗帜,是一家非常善于思考善于尝试的公司.随着面临挑战的不断增大,传统的测试开展方式也越来越力不从心,这本书讲述的就是一次完整的 ...

  5. google软件测试之道读后感(一)

    这几天在抽空读一本新书,久负盛名的<google软件测试之道>.之前在网络上一点一点地看过它的英文版,很受触动,还做了很长的读书笔记,现在看到了中文版,才恍觉之前的好些理解存在不恰当的地方 ...

  6. 《Google软件测试之道》【PDF】下载

    <Google软件测试之道>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230382198 内容介绍 每天,Google都要测试和发布 ...

  7. 《Google软件测试之道》测试开发工程师

    拖延了将近半年的草稿,断断续续的写完了.之前草草翻看完这本书,关注点主要在TE上,而关于SET的部分则只是浏览,最近后知后觉,又翻出了这本书,重新看了一遍,又有新收获. 就说说Google的SET是如 ...

  8. 《Google软件测试之道》摘录

    以下是最近看的一本书<Google软件测试之道>里的一些摘录,收获很多. 1.讨论测试开发比并没有什么意义,如果你是一名开发人员,同时也是一名测试人员,如果你的职位头衔上有测试的字样,你的 ...

  9. 《Google 软件测试之道》摘录

    最近刚刚看完<Google 软件测试之道>,受益颇多,遂记录下: 只有在软件产品变得重要的时候质量才显得重要 第一章:谷歌软件测试介绍 角色介绍 SWE(Software Engineer ...

  10. google软件测试之道--读后笔记

         看完google软件测试之道,以前有认真看过一次,今天又重新看了一遍.   在google,测试人员严格区分为SET和TE.SET前期深度参与项目的开发,推动开发人员的自测,从破坏者的角度寻 ...

随机推荐

  1. Nginx编译配置杂记

    1.http://nginx.org/download/nginx-1.6.3.tar.gz 2. [root@track nginx-1.6.3]#./configure --prefix=/usr ...

  2. getFields&lpar;&rpar;和getDeclaredFields&lpar;&rpar;的区别

    getFields()获得某个类的所有的公共(public)的字段,包括父类. getDeclaredFields()获得某个类的所有申明的字段,即包括public.private和proteced, ...

  3. maven仓库有jar包,还是找不到类

    开始,网上的所有方法都没用. 我用的eclipse-32位的,jdk也是.然后今天换了个sts和jdk.64位的.然后就没有那个问题了.

  4. Python学习笔记-Day3-set集合操作

    set集合,是一个无序且不重复的元素集合.定义方式类似字典使用{}创建 目前我们学过的数据类型: 1.字符串(str),2.整型(int),3.浮点型(float),4,列表(list) 5.元组(t ...

  5. &period;&sol;configure &colon; &sol;bin&sol;sh&Hat;M &colon; bad interpreter

    用命令行来编译Qt的时候发生标题尚的错误. 原因是文件中带有DOS行结束符,必须把它转换成UNix结束符 references: http://*.com/questions/ ...

  6. poj 1990

    题目链接 借鉴cxlove大神的思路 题意:听力v,位置x,2个牛交流声音为max(v1,v2)*(x1-x2),求总的 10000^2 tle 用的树状数组做的,排序,2个,小于vi的牛的总数和距离 ...

  7. hdfs常用的命令

    查看hadoop的状态hdfs haadmin -getServiceState nn1切换主从 hdfs haadmin -failover nn1 nn2查看hdfs是否安全模式hdfs dfsa ...

  8. tensorflow&lowbar;目标识别object&lowbar;detection&lowbar;api&comma;RuntimeError&colon; main thread is not in main loop&comma;fig &equals; plt&period;figure&lpar;frameon&equals;False&rpar;&lowbar;tkinter&period;TclError&colon; no display name and no &dollar;DISPLAY environment variable

    最近在使用目标识别api,但是报错了: File "/usr/local/lib/python2.7/dist-packages/tensorflow/python/ops/script_o ...

  9. 【洛谷】【动态规划&sol;01背包】P2925 &lbrack;USACO08DEC&rsqb;干草出售Hay For Sale

    [题目描述:] 约翰遭受了重大的损失:蟑螂吃掉了他所有的干草,留下一群饥饿的牛.他乘着容量为C(1≤C≤50000)个单位的马车,去顿因家买一些干草. 顿因有H(1≤H≤5000)包干草,每一包都有它 ...

  10. 基于CentOS搭建VNC远程桌面服务

    系统要求:CentOS 7.2 64 位操作系统 安装.启动 VNC VNC 远程桌面原理 名词解释: Xorg:在 Linux 用户中非常流行,已经成为图形用户程序的必备条件,所以大部分发行版都提供 ...