热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

测试小兵成长记:守业容易创业难

本故事纯属虚构,如有雷同,纯属巧合大毛隐隐觉得自己是被提升了,但是又觉得不靠谱:这么容易就提升了?不管怎样&

本故事纯属虚构,如有雷同,纯属巧合

大毛隐隐觉得自己是被提升了,但是又觉得不靠谱:这么容易就提升了?

不管怎样,大毛毕竟是能做更为有意义的工作,起码不再是机器人了。更何况,挑毛病确实是一种赏心乐事,尤其能在一些看上去比自己资深的同事的工作里面挑出毛病。这让他精神百倍,还有一种“朝为田舍郎,暮登天子堂”的感觉,直到他发现很多挑出来的毛病其实一直都没有改正。

大毛不禁有些泄气,他的工作到底意义何在呢?

正好项目告一段落,大毛找领导谈了他的困惑。

领导没有回应他的问题,而是说,

“明天有个项目计划的会议,你也去参加,负责设计其中一个组件的测试用例。”

好吧,至少是些新的工作。

项目是做上一个项目的第二个版本,测试的方法也差不多,设计测试用例也是照葫芦画瓢的事,人手也是差不多……大毛想,原来设计和执行测试用例也就是隔层纸的区别嘛。

如果不是在复审会议上被板砖拍得半死的话,大毛还是能一直保持这种良好感觉的。

同事A:界面改成HTML了,为什么没有cross-site scripting(见作者注1)的测试用例呢?

同事B:密码输入框已经强制使用软键盘了,为什么这些测试用例还是用键盘输入呢?

同事C:用户配置文件在两个版本间的兼容性没有测试用例哦。

同事D:我们需要测试用例来保证关键点的性能相比第一版没有下降。

……

风水轮流转,大毛终于找到被挑毛病的感觉了,而且很多意见他还没搞明白是什么意思。

忙了一个星期,查阅了不少文档,大毛总算通过了复审。他不但没有如释重负的感觉,反而觉得绝望:照复审意见的精神,还有很多测试用例没有设计呢,就算都做出来,怎么可能全部执行完呢?再看看其他同事的测试用例,咦,好像也不全嘛,怎么领导就通过了呢。

领导瞄了一眼大毛的神情,说,“到我办公室来聊聊呗。”

“你觉得毛病挑的合理不?”

“挺合理的。”

“然后你觉得全部意见都接受是没法做到的?”

“呃……也是可以做到的。”

“那都有谁做到呢?”

“这个,其实没有。”

“我跟你说,其实软件根本就无法全面测试,所以要加这个那个测试用例,单个看都是合理的,全部都加是没戏的。”(见作者注2)

大毛像被敲了一棒子似的:那我忙了这一个星期还不够,得忙一辈子也不够啊。

“这……既然如此,那为什么还要复审呢?”

“既然无法全面测试,那就必须舍弃一些测试用例,同时确保重要的测试用例没有错误或者遗漏,在可能的时候减少测试用例的总量和执行需要的时间。”

“怎么区分重要不重要呢?”

领导忽然换了个话题,

“你上次说你挑出来的不少毛病都没有人去改正……

“嗯,比如……

“我知道,我都看过。这次复审通过的测试用例都是没有错误并且一直认为足够重要的,你把这些用例和你所挑出了毛病又没有得到改正的用例比较一下看看。”

一天以后,大毛心悦诚服的找到领导,

“我明白了,这些用例要么是不再重要了,要么是与新版本的功能不符,要么是执行时间太长了,反正就属于可以被舍弃的。”

“不错。当然了,这些毛病可以用来提醒同事不要在新测试用例中重犯错误,并不是没有价值的。”领导伸了个懒腰,“复审了好几次,累死了。下次好好想想怎样用更少的测试用例达到同样的效果,为了你,为了大家,还有为了我。”

作者注:第二版系统综合症(参见人月神话)不仅仅是架构设计的问题,在测试领域也有其症状。后续版本最终设计出来的测试用例不一定比第一版的要多,但是从实践上看,第一次复审能发现的测试用例错误、遗漏和冗余通常会很多。所以,软件领域的守业其实比创业需要更高的技术和工程能力。

作者注1:参见http://msdn.microsoft.com/zh-cn/partners/ms533047

作者注2:参见The Art of Software Testing, Second Edition。作者用一个简单的程序展示测试用例如何组合爆炸,使得完全测试是不可能的。http://book.douban.com/subject/1769687/



推荐阅读
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 本文介绍了如何使用PHP向系统日历中添加事件的方法,通过使用PHP技术可以实现自动添加事件的功能,从而实现全局通知系统和迅速记录工具的自动化。同时还提到了系统exchange自带的日历具有同步感的特点,以及使用web技术实现自动添加事件的优势。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • Webpack5内置处理图片资源的配置方法
    本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
author-avatar
平凡黯淡_551
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有