你不知道的软件测试那些事?

你不知道的软件测试那些事?

 一、写在前言

作为开发人员,我们都知道我们应该测试我们的代码。我们应该写单元测试,但这也通常是我们发现没时间时跳过的第一步。

  作为团队的领导者或者管理者我们都知道测试是必要的,但是当截止日期临近的时候,我们倾向于减少测试,而把更多的重点放到编码上。这样看测试领域似乎很紧张。我们都知道测试对我们是有利的,但是一旦项目面临压力时我们就不再测试了。

  二、我们为什么测试?

  Edsger W Dijkstra 说过:测试可以用来找到显式的缺陷(bug),但是无法显示潜伏的软件缺陷(bug)。这意味着测试不能百分百保证你的软件没有缺陷(bug),但是它确实很有帮助。

  我们也可以换种说法,如果我们不进行测试我们几乎可以百分百保证我们的软件会有缺陷(bug),除非我们是在编写像“hello world!”那样简单的程序。但是即使这么简单的程序你也会测试,因为一旦你输入完你的代码你就会很好奇它的输出是不是真的是“hello world!”。

  而这就是第一类形式的测试,也是我们一直在做的: 手工测试. 我们编写程序,然后启动它去检验运行结果。 对于一个简单的“hello world”这可能是足够的,但是对于复杂度更高的程序这可能会导致时间的浪费,这是对一个已知的行为结果集的手工重复。这难道不是我们发明计算机的初衷吗?

对于“hello world”这不是大问题,但是当你创建一个web应用时,测试场景是在翻页十次,点击某些按钮,在大量表单中输入(正确的)数据之后再测试某些特定条件,你就看到自动化会节省大量的时间。如果你能通过测试运行器(testrunner)直接执行你想要测试的函数,而不是必须花费半分钟手工执行到那个函数,你会节省很多时间!但这也意味着我们需要多一点点编程,而更多的编程意味着更多的时间和精力。所以它会花费更多的时间而你的项目可能因此完工的晚些。

三、也许未必

  让我们创建一个控制台应用程序来计算最大公约数(GCD)的两个整数。有很多方法可以解决这个问题,但为简单起见,我们将

  1.输入两个整数

  2.不管其算法怎么样,计算一下 GCD

  3.显示输出

  让我们浏览一下正常的开发周期。我们通常写一个 main() 函数,得到了两个整数,以及调用一个函数来计算一下 GCD,然后显示结果。测试。在你的控制台中输入 2 个整数会花一些时间,这将变得相当无聊,如果你需要多次重复你的代码。这也很容易在控制台应用程序中输入出错,导致程序崩溃。这意味着你必须重新启动程序,输入两位数,然后再次验证结果。请你要记住,我们讨论的是一个控制台应用程序,只需要两个输入值,不需要点击(在 web 应用程序中),我们已经看到,这将需要花费一些时间。

  然后,我们很可能会想要测试一些更多意味着重启程序的值,进入两位数(正确地),然后测试。。。所以我们即使看到也不会立即这样做,因为它要花费太多的时间。Edge 案例将会被遗忘,错误只会在生产中被发现!此外,当我们改变一些我们需要再次运行所有的测试(手动),使用一个被遗忘的,或者使用快捷键的高风险的测试。在那儿,不会有跟踪我们的测试工作。不写入日志文件,在整个测试期间,除非你增加这个你做的事情列表工作(手动)。

 四、消极反馈循环

通常,当项目(因为某种原因)延期了,则容易陷入一种消极反馈循环。有时我们会先决定跳过编写测试代码,而这则会造成情况。

项目延期,造成我们不得不去编写更多的代码。所以与其“浪费时间”去不停地测试代码,不如不停地去开发项目。而这样做的结果就是代码质量进一步下降,并最终(或早或晚)导致返工。返工又通常会在最有限的时间里变得十分紧急(有些人叫这种现象为“墨菲是个乐天派!”)。其实返工什么也改变不了,项目现在只会进一步被延迟。很奇怪吧,我们编写越多的代码,我们的项目完工越晚。一种常用应对措施是让更多的开发人员被参与到项目的研发中,然而这样的作用也只是加剧消极反馈循环而已。

  若项目缺乏测试,在验收和生产环境时,通常用户则会发现许多 bug,这将会快速地降低用户对项目的信任度,从而产生消极反馈。这种反馈传递给(工作过度的)开发人员,就造成开发人员“疲劳”现象。后果就是开发人员工作积极性下降,开发人员离职,……,项目又进一步延迟了。

 五、打破消极循环

  我想你已经想到有一个办法可以解决这种现象。让我们来绘制一幅不同的场景:我们可以从一个理想计划“项目按时完工”开始。我们开发代码,然后立即测试它。测试最好是自动化(编码实现)的,这样我们可以轻松有效的去执行它们。我们把开发和测试紧密的结合在一起,每个开发测试循环可以很快速的执行。当一个开发测试循环结束时我们有信心保证代码质量是很高的,因为它已经通过了测试。而且用户因为发现缺陷(bug)的数目变少而对我们继续高度信任。即使他们发现了一个缺陷(这依然是有可能的),我们也可以扩充我们的测试集合,去避免相关缺陷的重现。如此下去,返工将不再是必须的,项目得有继续。如果我们的项目已经延期了,就需要我们花些时间来采用这种方法论。对新功能的冻结也许是必须的。停止开发新的代码,取而代之去为最严重的(恼人的-清晰的-高代价的)缺陷编写测试。

项目延期的情况下再去为你完整的代码库编写测试是不可行的,只针对其中的一些部分就可以,不要去浪费你的时间。但是要记住其它部分也还是需要编写测试的。我在这种情况下会去找出最严重的问题(划分优先级),然后为它们编写测试。之后“快速”修改代码就会变的更容易,并且可以保证在修改其他部分是它不会出错。自动化测试可以很频繁的执行,从而降低了缺陷(bug)重现的风险。大讲台,最实用的 IT 职业在线学习平台。好了,现在可以开始去有效的强健我们项目了

六、总结

大部分的项目中,会考虑测试和编码之间的平衡。不过我希望大家都能清楚,测试其实是项目的加速器,而不是在浪费时间。

​       如果有任何疑问,欢迎添加qq群测试入门到大神 755431660 共同学习~

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