敏捷测试理论以及实践(3)

简介:

现在先来总结一下到底上面说的模型存在着哪些问题:

  1、客户生气地说:这个产品好像不是我们想要的吧!早知你们给我这样子的产品,我才不会下单了,你们也早点跟我说这个产品是这样子,到现在才给我看,浪费我时间,精力,我不买了!(客户到交付后来发现产品与当初他们提的需求不一致,所以很生气,后果很严重)

  2、设计团队激动地说:都开发了这么长时间了,你们还要改功能加功能啊,这样子会影响到很多其他功能的,会影响最后发布时间的,而且最后的质量如何,我不能保证。(老兄,我出钱买你们产品的好吧,我想加什么功能改什么功能当然得给我弄好,不然我不付钱了!)

  3、开发人员暴跳如雷地说:你们这帮测试,早不提晚不提,总是在最后要发布前给我们提这么多Bug,是不是存心给我们找茬啊!要是不能准时发布,你们负责啊!(测试人员委屈地说:我们也想能早点发现这个Bug,早点修好这个Bug啊,但是之前你们也没我Build测啊!)

  就这样,不断地出现相互的抱怨,也就是所谓的矛盾,哲学上说,矛盾是事物发展的动力,所以这些矛盾的出现,也就是预示着,我们需要有解决这些矛盾的方法,很庆幸,我们的很多前辈已经帮我们解决了这方面的问题,准确地说是从理论上解决了这种问题,且听我慢慢道来。

  首先,对于客户能否得到自己想要的产品这个问题,以前得不到的原因无非就是两点:

  第一个就是我们一开始设计的需求点其实跟客户所想要的需求不一致。这一点,我们可以通过需求设计完成后马上跟客户确认就可以解决。

  第二点就是客户只能等到最后时刻才能看到这个产品,也就意味着,即使他们发现自己以前的想法是不对的,想要改一下自己的想法却来不及了,因为产品已经出来了,再去改可能又要等很长时间了,这个谁也拖不起。这一点,我们可以通过经常给客户交付一个可用的Build,让客户去看已经实现的功能,来研究是否还需要更改。

  而对于我们的设计团队来说,上面的第二点也正好可以解决他们的问题,由于有可用的Build,所以我们设计好的功能一做完就可以马上让客户看到,一旦要修改些什么,就不会再像以前那样由于所有功能点都做完了,改一个就牵一发而动全身了,这点也类似之前说的,一个Bug发现的越早修得成本越低。

  而对于咱们的开发人员和测试人员而言,为了帮助客户得到自己想要的产品,也需要做些改变,不过也很简单,几句话而已,开发完成一个功能以后,测试人员就要测试这个功能,然后开发人员需要把发现的Bug马上修掉,最后测试需要把修复的Bug确认修复。这样子的话,就可以解决以前最后阶段才能开展测试,才能发现大量Bug,导致发布成本增加、延期等不确定因素的发生。

  当然,这里还有一点必须说一下,即使采用了新方法,成本增加,时间延期这种事情还是有可能发生,但是新的方法可以让你预测到可能发生的成本与时间问题,不会像以前那样到最后时刻才会发现,这样子对于领导层做决策还是会有很大帮助的。

  讲到这里,大家应该发现,测试流程已经完全与开发流程并行了,之前说的W模型虽然也会有并行,但是只是属于“伪并行”,因为它需要一个阶段结束才能进行下个阶段,比如开发完所有的功能以后才能开始测试,而对于这个模型,测试自始至终一直在参与着测试,不会去管哪个阶段是否完成,只在乎哪个功能已经设计好,已经开发好。对于设计好的功能,测试里也有专门的设计测试工程师(Design QA)去专门检查这个设计是否符合客户的要求,甚至会去和客户做沟通;对于开发好的功能,一方面代码完成后开发需要马上进行单元测试,然后专职测试人员拿到Daily Build以后就要马上常规测试,看看是否工作,发现严重Bug马上提上去让开发修;最后所有功能都已经确认和测试完毕后,测试人员还要再继续进行集成测试、系统测试和压力测试等等;甚至到了后来的维护阶段还需要测试人员继续参与,因为很多技术支持人员对产品没有测试人员了解地多,所以碰到难的问题,还需要测试人员的帮忙。

  所以从一开始的设计到最后的发布,测试人员一直全程参与着,这个跟以前的模式已经有了非常大的改变了,对测试人员的要求和压力已经是不可同日而语了。这个新的模式也就是敏捷测试模式的雏形了,当然还并非完全的敏捷测试模式,所以我暂时先把它称之为准敏捷模式。

  既然有了准敏捷模式,那什么才是真正的敏捷测试模式呢?呵呵,还是听下回分解吧。

  (未完待续)

本文出自seven的测试人生公众号最新内容请见作者的GitHub页:http://qaseven.github.io/

目录
相关文章
|
29天前
|
安全 Linux 测试技术
提升龙蜥内核测试能力!探究持续性模糊测试优化实践
清华大学软件学院对Anolis OS使用靶向模糊测试方法将测试工作引向修改的代码,进而提高对业务代码的测试能力。
|
2月前
|
SQL 搜索推荐 测试技术
【Havenask实践篇】完整的性能测试
Havenask是阿里巴巴智能引擎事业部自研的开源高性能搜索引擎,深度支持了包括淘宝、天猫、菜鸟、高德、饿了么在内几乎整个阿里的搜索业务。性能测试的目的在于评估搜索引擎在各种负载和条件下的响应速度、稳定性。通过模拟不同的用户行为和查询模式,我们可以揭示潜在的瓶颈、优化索引策略、调整系统配置,并确保Havenask在用户数量激增或数据量剧增时仍能保持稳定运行。本文举例对Havenask进行召回性能测试的一个简单场景,在搭建好Havenask服务并写入数据后,使用wrk对Havenask进行压测,查看QPS和查询耗时等性能指标。
65391 6
|
3月前
|
安全 测试技术
测试团队的一次复盘实践
测试团队的一次复盘实践
147 0
|
1天前
|
敏捷开发 设计模式 Devops
深入探索自动化测试框架的设计原则与实践
【4月更文挑战第29天】在追求软件开发效率和质量的当下,自动化测试成为确保软件可靠性的关键步骤。本文旨在剖析构建高效自动化测试框架的设计原则,并通过具体实例展示如何在实际项目中应用这些原则以提高测试效率和准确性。文章首先介绍了自动化测试的重要性及其对持续集成/持续部署(CI/CD)流程的贡献,随后详细探讨了模块化、可扩展性、易用性和可维护性四个核心设计原则。最后,通过一个案例研究,演示了如何将这些原则融入到自动化测试框架的构建中,以及实施后的效果评估。
10 1
|
3天前
|
jenkins 测试技术 持续交付
深入探索软件测试中的持续集成与自动化测试实践
【4月更文挑战第27天】 在当今软件开发的快速迭代过程中,持续集成(CI)和自动化测试已成为确保代码质量和加快交付速度的关键因素。本文将探讨如何通过实施持续集成流程,并结合自动化测试策略来优化软件测试工作。我们将分析持续集成的原理、自动化测试的最佳实践以及如何将这些方法应用于实际项目中,旨在为读者提供一套完整的解决方案,以提高软件项目的效率和质量。
11 3
|
3天前
|
Web App开发 IDE 测试技术
深入理解自动化测试框架Selenium的设计与实践
【4月更文挑战第27天】在软件开发周期中,确保代码质量和功能正确性至关重要。随着敏捷开发的普及和持续集成/持续部署(CI/CD)的实践,自动化测试已成为现代开发工作流程的核心部分。本文将探讨一个广泛使用的开源自动化测试工具——Selenium,并剖析其设计原理、架构以及在实际中的应用。我们将通过具体案例分析,展示如何有效利用Selenium进行跨浏览器测试,并讨论在真实环境中可能遇到的挑战及解决方案。
|
5天前
|
敏捷开发 Devops 测试技术
深入理解自动化测试框架设计原则与实践
【4月更文挑战第25天】在快速演变的软件行业中,自动化测试已成为持续集成和交付过程中不可或缺的一环。本文旨在探讨构建高效自动化测试框架的设计原则,并通过实际案例分析如何在实践中应用这些原则以提高测试效率和可靠性。通过深入剖析自动化测试框架的核心组件、架构设计和最佳实践,读者将获得构建和维护健壮自动化测试系统的深刻见解。
3 0
|
14天前
|
敏捷开发 监控 前端开发
深入理解自动化测试框架Selenium的架构与实践
【4月更文挑战第16天】 在现代软件开发过程中,自动化测试已成为确保产品质量和加快迭代速度的关键手段。Selenium作为一种广泛使用的自动化测试工具,其开源、跨平台的特性使得它成为业界的首选之一。本文旨在剖析Selenium的核心架构,并结合实际案例探讨其在复杂Web应用测试中的高效实践方法。通过详细解读Selenium组件间的交互机制以及如何优化测试脚本,我们希望为读者提供深入理解Selenium并有效运用于日常测试工作的参考。
|
15天前
|
自然语言处理 测试技术 API
深入理解自动化测试框架Selenium的设计理念与实践
【4月更文挑战第15天】 在现代软件开发过程中,自动化测试已成为确保产品质量和加速迭代的关键手段。Selenium作为一种广泛使用的自动化测试框架,提供了对多种浏览器和平台的支持,极大地促进了Web应用的功能测试。本文旨在剖析Selenium的核心设计理念,探讨其在实际项目中的应用,并指出常见的误区及最佳实践,以期帮助测试工程师更高效地利用Selenium进行测试工作。
|
21天前
|
机器学习/深度学习 人工智能 算法
深入白盒测试:提升软件质量的策略与实践
【4月更文挑战第9天】在追求软件产品质量的道路上,白盒测试作为一项重要的验证手段,其价值和影响力日益凸显。本文将深入探讨白盒测试的核心概念、实施策略以及面临的挑战,旨在为软件开发和质量保证的专业人士提供一套系统化的白盒测试方法论。通过对代码逻辑结构、执行路径以及内部算法的严密审查,我们揭示了如何有效发现并修复潜在的缺陷,确保软件的稳定性和性能满足用户期待。文章还将分享一系列创新工具和技术,助力测试人员提高测试覆盖率,减少人工干预,最终实现自动化和智能化的软件测试流程。

热门文章

最新文章