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

简介:

上面已经谈到了准敏捷测试模式了,离咱们所说的敏捷测试已经无限接近了,但是要了解真正的敏捷测试,还是需要回到敏捷开发上来讲,前面一开始已经说过,敏捷测试严格上来说其实是属于敏捷开发的一部分,所以敏捷开发的价值观也会同样适用于敏捷测试,那么敏捷有哪些价值观呢?总共是五个,分别是简单、沟通、反馈、勇气、谦逊。

  光看这五个词,我想大部分人可能会晕乎了,不知所云的,难道敏捷就五个词能概括了?就像电影里出现的武功秘籍一样,一招就一个图,我们看了根本就不知道是啥,人家一看就能炼成神功了。

  其实呢,这几个价值观并不是教你怎么去实现敏捷,而是教你用一种什么样的态度去对待开发:要时刻想着最简单的方法去处理需要解决的问题,要经常与和开发/客户沟通,对于积极对待反馈,要有勇气去做决策,对团队各个成员都要尊重。这么几个价值观,对于你去初次理解敏捷而言,我相信几乎没有用处,甚至会让你觉得很迷茫,到底敏捷是啥,但是一旦当你已经真正理解了敏捷的时候,你就会发现,诶,的确是这样子的,说得很好!(哲学上说,事物的发展总是需要经历否定之否定阶段,对知识的理解也是一样,一开始看一下概念觉得很简单,觉得自己已经理解了(肯定);深入下去,发现问题越来越多,觉得自己没办法去理解(否定);到最后经过不断地思索与实践,终于彻底理解后,你就会觉得一开始那些简单的概念很精辟,就应该那么简单!(否定之否定=肯定))

  不过相对于当初的先行者而言,我们又是幸运的,因为很多前辈已经帮我们理解了这些价值观,并且研究出了很多实现的方式, 但是我们也不能去奉行拿来主义,毕竟是人家想出来的,是基于人家的实际情况,对于我们的情况不一定会适合,最好的办法就是取其精华,去其糟粕,结合实际,加以改进。

  接下来我就开始讲什么是真正的敏捷测试模式和我们公司怎么结合它来取其精华,去其糟粕,结合实际,加以改进。

  当然这个所谓的真正的敏捷测试模式也是业内主流的模式,我们公司的实际运用中还是有所区别的,下面都会提到。

  跟前面讲到的准敏捷测试相比,真正的敏捷测试其实也只是加以改进和丰富,所以与客户的沟通、积极响应需求的变更、以及开发与测试的同步,这些都还是存在的,当然敏捷测试改进和增加了许多地方,主要有:

  1、过程需要实现迭代:每个迭代周期需要完成一定量的功能,没有完成的功能不能Check In代码,这些功能需要经过严格测试,并且开发需要修复主要的严重Bug,这样子在最后就得到一个可以工作的并且相对稳定的Build,这个迭代周期就算完了,然后开始下一个迭代周期。这样就类似与我们修路一样,修路的话需要打好几层地基,每层地基打严实后,再铺上面一层,这样子即使最上层破了,只要修一下最上层就好了,不会影响到下面层的质量,如果是最下面那层没打严的话,一出问题每层都会损坏,要修的话,要全部扒掉这么多层地基才能修好。所以迭代对于测试的要求就特别高了,因为只有把这个迭代的主要Bug找到并修好,下面的迭代周期才能不受影响,才能确保以后出现的问题不用“打到最底层”才能被修好,“打到最底层”意味着就是人力,物力,时间以及最重要的产品的质量!

  下面是一个迭代的简单示意图,应该可以理解的,就不多讲了。

  2、测试不单单要和客户沟通,也要跟公司里的人经常进行沟通,因为一个公司的所有人其实都只有一个共同目标,就是把公司发展好,这样子其他的比如自己的发展,待遇等等才有可能实现。那么体现在实际的工作中就是:

  a)测试需要完全理解需求讲的知识点,不懂或者有疑虑要及时跟设计沟通,这样子可以让你更好地理解需求,甚至帮助设计人员发现错误;

  b)测试人员需要经常跟开发人员沟通,看看做的功能,修的Bug主要会影响哪些其他模块,主要出现问题的原因是什么,怎么弄可以最快速度重复出Bug来,这样子就帮助自己掌握测试的方向以及帮助开发快速修复Bug以及避免以后出现类似Bug。

 c)测试也需要跟测试人员之间进行沟通,来探索怎么能发现有质量的Bug,怎么能覆盖到很多的测试点,怎么解决自己没办法解决的问题,帮助他人也帮助自己。(每日立会是其中一个好办法)

  d)测试还需要跟自己沟通,不断地经常反思自己的优点和缺点,反思团队的优点和缺点,反思公司的优点和缺点,大胆提出和实施改进意见,为以后更好地开展工作做准备。(反思会是一种办法)

  沟通,只有沟通才能了解双方的想法,才能及时消除前进中的阻力和困难,让大家在同一方向上用同一个信念前进。

  3、建立有效的监测机制:这里所谓的检测机制主要有两点,一个是对测试的监测,另外一个就是对产品的监测。对于测试的监测主要在于检查测试的覆盖面是否全面,发现的Bug与测试覆盖面的一些对比数据,这些有助于提高测试的覆盖面从而提高Bug发现率;而对于产品的监测就是主要有两点,一点就是做功能和修Bug的进度是否是可控的,可预判的;另一点就是发现Bug的情况,也就是产品的质量是怎样的,质量发展的趋势是怎样的。

  我主要想补充的是这么三点,当然要是我想到其它的,我还是会修改这篇文章的。看过网上也有很多人来写关于敏捷测试的一些文章,很多都是国外英文解释的标准中文翻译,当然也有很多是自己的一些想法,所以远近高低各不同,不过既然敏捷只是一种思想,也就不会拘泥于何种实现方式,所以各人有不同想法都Ok的。其实说的再过一点,只要你自己认为你的方法是敏捷的,那你就可以认为是敏捷的,不用关心人家怎么想,人家的方法不一定适合你的,你只要有办法能在正确的时间交付正确的产品,那就Ok了。

  所以我接下来就会按照我们公司的流程来实际介绍一下敏捷测试在我们公司的实现,中间可能会有一些地方为主流敏捷测试所不容的,但是我觉得他们比较符合我们公司的实际,如果大家有不同的意见或者更好的方法,我也会悉心接受。

  (未完待续)


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

目录
相关文章
|
26天前
|
jenkins 测试技术 持续交付
提升软件测试效率的创新实践
在软件开发过程中,测试环节扮演着至关重要的角色。本文探讨了如何通过创新的方法和工具,提高软件测试的效率和质量。我们将从自动化测试、持续集成与持续部署(CI/CD)、测试驱动开发(TDD)三个方面,详细介绍这些技术如何改变传统的测试流程,帮助团队更快地发现和修复缺陷,最终实现更高质量的软件交付。
148 67
|
12天前
|
Java 测试技术 开发者
初学者入门:掌握单元测试的基础与实践
【10月更文挑战第14天】单元测试是一种软件测试方法,它验证软件中的最小可测试单元——通常是单独的函数或类——是否按预期工作。单元测试的目标是确保每个模块在其自身范围内正确无误地运行。这些测试应该独立于其他模块,并且应该能够反复执行而不受外部环境的影响。
36 2
|
20天前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
30天前
|
SQL 测试技术 持续交付
探索软件测试的多维度——从理论到实践
【9月更文挑战第35天】在软件工程的世界中,测试是一个不可或缺的环节。它不仅保障了软件产品的质量,而且确保了用户体验的一致性和可靠性。本文将从不同的角度切入,探讨软件测试的多个方面,包括测试的目的、类型、工具以及最佳实践。通过深入浅出的方式,我们旨在为读者提供一个全面的测试知识框架,帮助他们更好地理解并执行软件测试工作。
31 2
|
17天前
|
测试技术 UED
软件测试的艺术与实践
【10月更文挑战第9天】 在数字时代的浪潮中,软件成为了我们生活和工作不可或缺的一部分。然而,高质量的软件背后,是无数测试工程师的默默付出。本文将通过深入浅出的方式,探讨如何进行高效的软件测试,确保软件产品的质量与稳定性。我们将一起揭开软件测试的神秘面纱,从基础理论到实际操作,一步步走进这个充满挑战与创造的世界。
|
3天前
|
机器学习/深度学习 人工智能 自然语言处理
探索软件测试的边界:从基础到高级的实践之旅
【10月更文挑战第21天】 在当今数字化时代,软件已成为我们生活和工作中不可或缺的一部分。随着技术的快速发展,对软件质量的要求也日益提高。本文旨在通过深入浅出的方式,带领读者踏上一场从基础到高级的软件测试实践之旅。我们将探讨软件测试的基本概念、重要性以及如何有效地进行测试规划和执行。通过具体案例分析,揭示常见错误及其解决方案,同时展望未来软件测试领域的发展趋势。无论你是软件开发新手还是经验丰富的测试工程师,这篇文章都将为你提供宝贵的见解和启发。
19 8
|
2天前
|
监控 安全 jenkins
探索软件测试的奥秘:自动化测试框架的搭建与实践
【10月更文挑战第24天】在软件开发的海洋里,测试是确保航行安全的灯塔。本文将带领读者揭开软件测试的神秘面纱,深入探讨如何从零开始搭建一个自动化测试框架,并配以代码示例。我们将一起航行在自动化测试的浪潮之上,体验从理论到实践的转变,最终达到提高测试效率和质量的彼岸。
|
5天前
|
测试技术 C# 数据库
C# 一分钟浅谈:测试驱动开发 (TDD) 实践
【10月更文挑战第18天】测试驱动开发(TDD)是一种软件开发方法论,强调先编写测试代码再编写功能代码,以确保代码质量和可维护性。本文从 TDD 的基本概念入手,详细介绍了其核心步骤——编写测试、运行测试并失败、编写代码使测试通过,以及“红绿重构”循环。文章还探讨了 TDD 的优势,包括提高代码质量、促进设计思考、减少调试时间和文档化。此外,文中分析了常见问题及解决方案,如测试覆盖率不足、测试代码过于复杂、忽视重构和测试依赖过多,并通过一个简单的计算器类的代码案例,展示了 TDD 的实际应用过程。
13 1
|
12天前
|
机器学习/深度学习 人工智能 自然语言处理
探索AI在软件测试中的创新应用与实践###
本文旨在探讨人工智能(AI)技术如何革新软件测试领域,提升测试效率、质量与覆盖范围。通过深入分析AI驱动的自动化测试工具、智能化缺陷预测模型及持续集成/持续部署(CI/CD)流程优化等关键方面,本研究揭示了AI技术在解决传统软件测试痛点中的潜力与价值。文章首先概述了软件测试的重要性和当前面临的挑战,随后详细介绍了AI技术在测试用例生成、执行、结果分析及维护中的应用实例,并展望了未来AI与软件测试深度融合的趋势,强调了技术伦理与质量控制的重要性。本文为软件开发与测试团队提供了关于如何有效利用AI技术提升测试效能的实践指南。 ###
|
21天前
|
测试技术
软件测试中的探索性测试(ET)实践
【10月更文挑战第5天】本文将深入探讨一种与传统脚本化测试不同的测试方法——探索性测试(Exploratory Testing,简称ET)。我们将通过一个实际案例来展示ET的有效性,并分享如何将ET融入日常的软件测试流程中。文章旨在为测试人员提供一种灵活、高效的测试策略,帮助他们更好地发现软件中的缺陷。