南博视频
2009年春节期间,中央电视台财经频道《经济半小时》栏目重磅推出春节...
对于年轻一代来说,中国梦,是希望过上更好的生活。要实现每个心中...
北大青鸟东莞金码学校提供专业网站开发培训,WEB前端培训,网站制作培...
品牌
2014年双11成交额571亿背后的秘密? 你知道未来三年电子商务人才...
在IT行业,特别是那些并不真正从事软件测试行业的业者,对软件测试往往有一些常见的误解,对测试行业的发展和健康都有不利的影响。本文总结了10大常见误解,希望能起到一些正本清源的作用。
一、测试工程师的工作是破坏软件
“测试工程师的工作就是破坏软件”是一个常见的误解。作为程序员十大金句之首的“在我机器上是好的”往往来源于这一误解。测试人员好像有什么魔力,能够把正确运行的程序在测试环境上搞得不能工作。
但是这不是测试工程师破坏了软件,测试工程师并不能在软件中创造某些bug。他们只是做了些程序员没有考虑到的某些操作,比如在测试环境上,没有执行相关的依赖操作。程序员在自测时很多情况下会默认某些场景,或者是开发的新功能而没有考虑到对原有功能的影响。这也是为什么我们不推荐完全由开发者本人完成功能的测试。
真相
软件bug只会来源于产生它们的代码,测试工程师不实现代码,所以他们并不能破坏软件,他们只是发现了软件不工作的触发条件并且报告了出来。
“测试工程师对软件进行破坏”往往会导致团队开发和测试的对立情绪,甚至将软件没有满足客户要求和大量因解决问题的额外工作量归咎于测试工程师的劳动。这是非常不利于团队和产品成功的。
二、测试工作不需要什么专业技能
很多人认为软件测试是个简单的工作,不需要会编写程序,也不需要很深厚的专业技术能力。这也是一个很常见的误解。诚然,很多优秀的测试工程师都不会编写专业的程序,也不具备软件开发领域的一些专业技能如架构、抽象等。但是这并不是说测试就是一个简单的工作。JamesBach在《测试与检查》一文中对测试和检查的区别进行了详细的阐述。测试是一系列创造性活动的集合,包括提问、研究、建模、观察、推理、试验等多方面的技巧。
开发和测试是两个不同的技术领域,我们不能以同样的技术标准来衡量两种不同的工作 。
真相
测试工作不同于开发工作,两者会有一些技能重叠,但是也存在很大的区别。开发工作的重点是高效、高质量地实现功能,而测试工作的重点是尽可能多地将软件失效在交付用户前暴露出来。测试工程师擅长开发技能可以帮助测试工程师更加深入地理解软件或帮助自己提供辅助手段来测试软件,但是这不能作为测试工作是否专业的评判标准。
三、测试就是写测试用例,然后执行
测试就是把需求转换成测试用例,然后在软件中执行这些用例。这是一个在瀑布研发模式时代非常广泛的一个错误看法,然而在如今敏捷研发模式时代,也换了个模样,但是依然存在类似的认知。
在瀑布研发模式下,很多测试工作被严格地要求有非常完备的测试设计文档,然后依照这些文档进行覆盖式地执行验证。可能高级测试工程师负责编写,然后初级工程师来执行。这更多是工厂式的质量管理经验在软件行业的错误应用。
即使在敏捷研发模式得到大量应用的今天,我们还是可以看到类似认知的变种,比如测试由开发人员做好单元测试的充分覆盖就可以了。这其实依然是把测试工作文档化,只是这个文档变成了单元测试代码,执行变成了计算机。本质依然是测试=测试设计+执行 。
真相
输出测试设计文档,并不是真的那么重要。测试中,更重要的永远是那些创造性的东西。提问、研究、建模、观察、推理、试验等。文档是这些活动的一个输出形式,我们不应该把测试简单看作是这些文档的机械生成和执行 。
四、产品出现问题,说明没有很好地进行测试
软件发布后,如果出现问题,很多人会首先归咎于测试的失职。认为测试没有做好份内的工作。软件测试的七大原则中,重要的一条就是穷尽测试是不可能的,何况测试并没有直接编写产生bug的代码。所以产品出现bug,是整个研发过程中整体流程的作用后果,不能也不应该据此作为评判测试工作好坏的标准。
真相
任何软件都不可能被详尽地完全测试。测试工作和开发工作、需求分析工作密不可分,产品的总体质量是整个研发团队共同作用的结果。软件发布后的bug产生是评估产品研发整体质量的一个重要标准,但仅以此来评判测试工作好坏有失偏颇。
五、通过测试可以发现所有的bug
这个误解和上一条原因比较类似,都是因为认为测试应该保证产品发布的质量并提前发现所有未知的问题。这是不可能办到的。产品是否能有效工作和很多因素有关。不同的测试环境、测试场景,不同用户操作使用软件的操作习惯、使用路径都有可能引起软件不同的表现。测试人员会尽量站在用户角度来考虑软件的使用场景,但是他并不能预测所有的用户行为,也不可能提前预知所有的运行环境和场景。所以在测试工作中,限定测试范围并告知用户经过验证的场景是相对严谨的做法。
真相
测试人员不可能估计到所有的可能性,也不可能预测到所有的用户行为。而软件会因为不同的用户行为和不同的运行场景产生超出预期的问题或bug。所以不可能要求测试人员提前发现所有的潜在bug。一个优秀的团队,会尽可能多地考虑到不同的用户场景,并根据发布目标调整覆盖场景的优先级。简单要求所有bug都能提前检测是不可能办到的任务。
六、自动化测试可以代替测试
这个误解在现如今几乎已经成为信条了。确实,理论上,所有的测试用例都可以通过技术手段来实现并自动执行,但是正如我们在前面提过的,测试并不是测试用例+测试执行的叠加。测试还包括大量的创造性的活动。所以自动化测试代替测试是个伪命题(除非有朝一日,人工智能发展到能够打败人类的创造性。那时可能整个IT行业都不需要人力劳动了)
除此之外,即使自动化测试能把所有的测试用例都实现通过机器执行,也不意味着应该这么做。因为自动化测试本身也是一项投资,有大量的投入在其中。很多测试场景通过自动化测试可以产生很大的价值,比如大量重复性的验证。但是也有很多场景,不需要通过自动化的投入来实现,比如很多一次性的功能验证,还有依赖人进行主观判断的功能等。
真相
测试中的检查工作,很大一部分可以通过自动化测试代替,但是测试工作不会被自动化测试代替。即使可以实现自动化测试的场景,我们也要通过ROI的衡量(如测试金字塔)来确定实施自动化测试的必要性 。
七、测试应放在开发环境后期进行
传统的瀑布研发模式中,在研发后期会有专门的测试阶段,包括集成测试、系统测试、验收测试等。所以长期形成一个误解,测试是在开发阶段后发生的。
可是这是一个错误的认识,这依然是传统工厂流水线思想的产物,并不适用于软件研发。即使在瀑布研发模式下,前期的开发阶段和需求设计阶段也都明确了测试人员参与的必要性。在现代敏捷研发模式下,更加强调测试工作的迁移,测试在需求澄清、系统设计、代码走查、结对编程等等阶段都扮演着重要的角色。
真相
测试是贯穿在研发生命周期全流程的一项活动,并不是某一个割裂开的独立阶段。测试越早介入对产品最终质量就更能产生积极的效果。
八、任何人都可以做好测试
这句话就好像《21天精通X语言》,《你也能做CEO》,《XXX三天速成》等故事一样,任何事情,懂得些鸡毛蒜皮都很容易,并不一定是测试,任何行当其实都是这样。10000小时定律对任何行业都适用。
真相
做一个好的测试工程师,一定是需要专业的技能训练以及经验积累。测试是一个广泛的范畴,各种各样不同的测试概念以及对应的测试方法、测试工具都需要大量的实践和学习才能在需要的时候应对自如。
九、测试工程师是质量守门员
这个误解几乎在所有IT企业都存在。测试工程师被当做质量守门员(背锅侠),测试人员需要为所测试的软件质量背书。测试人员被当做产品质量的最后一道防线,测试结果似乎决定了软件产品最终的交付质量。
真相
实际情况下,测试无法决定产品质量,只能将产品中当前发现的问题暴露出来,并据此进行质量评估。而且无论是因为研发周期还是问题修复成本等问题,测试人员并不能左右产品是否能够交付给用户。测试人员针对测试过程的总结和报告,更多是体现当前测试场景和测试范围下,软件产品的质量评估情况,测试工程师其实无法充当守门员角色。
十、测试即QA(质量保证)
在很多企业,往往会混淆QA和Testing两种角色,认为Testing就是QA(QualityAssurence)。应该说两者有相关性,或者说QA>testing。
前面说过,质量不会由测试来决定,质量更多是从需求、设计、开发环节就确定的。所以QA工作除了包含测试外,更主要的是流程改进,通过流程关键节点的管控来保证质量水准。
真相
QA涵盖的范围比测试更大,二者侧重点也不同。QA更关注软件研发全流程的质量管控,测试则更关注将当前软件中的缺陷暴露出来。二者的关注点不同,所需要的技能也不相同。不能简单地把测试和QA工作划等号。
总结
测试是一门涵盖范围广泛的专业,但是业界对测试工作却普遍存在或多或少的误解。
2016年4月1日,北大青鸟东莞金码学校的老师们参加了嘉华教育集团组织的茶溪谷一日游。在风景优美的东部华侨城茶溪谷,老师们不仅进行了团队
北大青鸟东莞金码学校第十届校友会在报告厅顺利举行,本次校友会主题为为职场加点‘料’,出席本次校友会的嘉宾有:安卓主管方老师
北大青鸟东莞金码每年都会举办文化艺术节,以各种活动形式贯穿其中,让学员感受到浓浓的文化艺术氛围,并亲自参与到文化节的活动中来,也是
北大青鸟东莞金码学校不定期组织学员开展精彩的文娱活动,通过K歌比赛、晚会节目表演、艺术节活动,以及平时的文娱表演,让学员可以通过各种活动展现自
北大青鸟东莞金码经常组织各种形式的学术活动,包括辩论赛、编程大赛、PPT比赛、知识竞赛、学术讲座、程序开发比赛等等。让学员通过参与各
很多学生求职难,不是因为素质不好、能力不行、经验不够被刷掉,而是因为简历不够闪!找出写简历的突破口、切入点,才能在HR的筛选过程中脱
1、用很怪异的邮箱名字发送简历例如司机投递简历时名字是没油了或迷路了,年轻人投简历用什么彻夜跳舞、狂欢这类的文字,或者带脏字,等等
一些职业限制因素是我们无法掌控的。新产品发布有可能被经济不景气拖累,你的导师在公司重组中失业,你必须在高层另找个新的获胜者作为导师
大学毕业找工作,你选择了哪个城市作为自己职业生涯的出发点?最近正值毕业求职季,前程无忧论坛(bbs 51job com)用这个话题带网友们回忆了往
最近好多人都在问,面临暑期实习,应该去大公司还是小公司?原以为现在公司名气大平台高,但是入职后发现各种问题,好坏公司如何
有了这些法宝,妈妈以后再也不用担心我加班了~一、产品狗、运营猫的数据处理中心1 infogr am infogr am是一个强大的数据可视化图表创作
预 备测试环境: AMD 毒龙1 4G OC 1 5G、256M DDR333、Windows2000 Server SP4、Sun JDK 1 4 1+Eclipse 2 1+Resin 2 1 8,
1 字符基础1 1 单字节字符集(single-byte character set(SBCS))顾名思义,在这种模式下,所有的字符都只用一个字节表示,常见的如,ASC
众所周知,新站一般排名稳定的时间大概在3个月左右,所以seo教程以新站上线三个月的时间来阐述下外链思想,以及如何发外链来让关键词更早的...
DDoS带来的破坏是巨大的,你无法阻止黑客对你的网站发动DDoS攻击,除非主动断开Internet连接。如果我们无法防止这种攻击,那么,怎样做才能最大限度地保护我们的企业网络呢?
横沥镇北大青鸟:打工多年想学技术学什么有前途?来自东莞横沥镇的孟小冬走进东莞北大青鸟校区,讲起了他在东莞横沥打工的经历,从18岁就来
初中毕业学啥技术好?在东莞,很多工厂的工人们都只有初中学历,但是他们仍然有一颗敢于奋斗的心,他们期望通过自己的努力为自己赢得精彩的
春节过后是招聘旺季,对于东莞北大青鸟毕业学生来说,这样的机遇必须好好把握。
一年一度的灾难片来袭,因为要开学啦!同学们,暑假作业完成没,摸底考试又要来了,是不是感到又彷徨,又紧张?如果说假期是为了放松和调整
时光犹如停留在半年前,我不知道该怎么形容我现在的心情,因为一切都太出乎我的意料了,当初还在犹豫北大青鸟学校学费的时候,还在犹豫北大
女生高考落榜怎么办?在2016年的今天,上大学已经不再是改变命运的唯一方式,读职业培训学校也是一种出路。上职业教育,可以学到一门专业技
众所周知,随着互联网日新月异的发展,随着网络的科技发达,电脑的应用成了我们生活中不可的一件物品了,经常在一些贴吧论坛上看到很多人提出这样的问题,“本人已经成年了,还可以再学习电脑吗?”“电脑学起来难度大吗?”“现在学习会不会太晚了”等一系列的问题,其实,成人学习电脑并不算太晚,关键看你选择什么成人电脑培训班!
1 只在电脑上练习如果面试官要考核你的技术,很有可能会要求你在白板上写代码,而不是电脑上。所以,你就不能只在电脑上练习。电脑上的编译
高考落榜读大专还是学技术好呢?不少人会有这样的疑问。就小编看来,如今大学升学率高达90%,高考落榜的学生,通过一些渠道也有大学上。人
“To be,ornot to be:thatis thequestion”(生存还是毁灭:这是一个问题),这是著名的莎士比亚悲剧《哈姆雷特》中的主人公一句非常经典的独白,也是数百年来经常困扰人们的选择问题。这段哈姆雷特式问题的台词,经常用来形容一个人在犹豫在思考时候的两难情况,用现代人的说法就是“选择困难症”。人们经常纠结于各种选择,生怕选错了,就会陷入“蓝瘦香菇”的困境。