多版本并行,测试如何做好质量保障?

简介: 第一个是成本问题,单独搭建一套可用的测试环境,包括云服务器、缓存、消息队列和数据库,成本是很高的;

昨天的文章总结了从软件工程角度,如何进行项目管理相关的知识。正好上周末星球内部直播时候,有同学问了一个问题:他们公司经常存在多版本并行的项目,不知道怎么做好质量保障工作。


这篇文章就以昨天文章中提到的项目管理的方法,结合我自己的实际经历,来聊聊多版本并行,质量保障工作面临哪些挑战以及如何保障交付质量。


我们日常工作中版本迭代一般都是按照时间进行排版迭代的,但偶尔也会遇到其他情况,比如新业务拓展需要紧急上线,但日常的迭代也不能停止。这个时候就会出现多版本或者说多项目并行的情况,这也给质量保障工作带来了很大的挑战。总结一下,比较大的挑战主要有如下四点。


640.png


环境问题


如上图所示,当时我们遇到了这样一个问题:在一个迭代周期内有2个业务迭代版本和3个独立项目差不多要同时上线。这个时候面临的第一个问题是测试环境的问题。


原则上来说,为了避免不同项目之间的互相影响,在测试环境上要做到彼此隔离。但要做到环境隔离,又面临2个挑战:


第一个是成本问题,单独搭建一套可用的测试环境,包括云服务器、缓存、消息队列和数据库,成本是很高的;


第二个是时间问题,搭建环境涉及到运维、研发和测试团队,需要运维准备资源、研发配合测试进行发布联调;


当时我们的测试环境很混乱,很多环境处于不可用状态,面临这个问题,我当时是这样解决的。


首先,4.1和4.2版本的时间可以错开,因此该两个版本可以共用一套环境,只是在代码部署上跟进下细节即可;


其次,独立版本1由于横跨了4.1和4.2版本,且涉及的业务域和对应服务和其他项目差异较大,因此独占T1环境;


最后,独立版本2和独立版本3提测及上线日期接近,且涉及的业务域和对应服务相差不多,可以将范围内的所有服务发布到T2环境,共用一套环境。


关于环境问题,我之前写过一篇详细的文章《被忽视的问题:测试环境稳定性治理》,大家可以参考。


业内比较好的解决方案是通过流量染色+stable环境来解决,架构图如下:


640.png


分支问题


多版本并行,其实最大的难点就在于代码分支问题。关于代码分支,主要考量如下几点:


  • 每个项目是否都需要单独拉一个分支出来进行开发;
  • 上线前代码merge,如果冲突较多,就需要尽早去做代码合并尽早发现问题;
  • 如果没有明显的代码冲突,在UAT阶段做一轮快速的回归验证即可;


边界问题


这个问题其实很容易忽略,但在实际的工作中,面临多版本并行的情况,划分清楚边界其实是很重要的。这样一方面可以减少不必要的工作量,另一方面也可以避免测试过程中遇到不同项目的交互区域,责任划分以及问题跟进问题。


边界划分,我个人的处理经验主要遵循如下几点:


  • 需求评审时明确本次需求涉及的业务域;
  • 按照业务域去确定该项目对应的应用服务名(便于区分代码分支);
  • 综合不同项目的调用依赖,判断公共服务是否有变更(如有可考虑mock等手段);
  • 解决不同项目在测试过程中的测试数据问题(测试数据准备也是多项目并行的一大难点);


回归问题


其实多版本并行最大的工作量就在于回归验证,一方面要确保每个项目涉及到的变更影响部分都要回归到,避免遗漏;另一方面针对不同项目的不同代码分支,还要考虑代码冲突的问题。针对这种情况,一般来说解决方法无非下面几种:


  • 大量的自动化测试来节省回归测试的时间和工作量;
  • 短期内通过增加人力的方式去尽可能覆盖涉及的业务场景;


结合上篇文章讲到的项目管理知识,可以看到:


  • 在项目前期识别面临的问题,这是风险评估和风险管理;
  • 在面临多项目并行时制定项目计划并逐步拆解为最小的可执行任务;
  • 通过流程规范去约束代码分支和提测发布过程,并时时跟进;
  • 通过工具去提升过程效率(如自动化等手段);


综合来说,软件工程的方法论在实际的工作中,给了我们更高的一个观察视角,能让我们解决更复杂的问题。

相关文章
|
5天前
|
设计模式 测试技术 持续交付
深入白盒测试:提升软件质量与性能的关键策略
【4月更文挑战第20天】 在软件开发的复杂世界中,确保产品的质量和性能始终是至关重要的任务。白盒测试,作为软件测试领域的重要分支,提供了对程序内部结构和逻辑的深入分析手段。本文将探讨如何通过有效的白盒测试策略来优化软件性能,减少缺陷,并最终提高用户满意度。通过剖析代码检查、单元测试、集成测试等白盒测试技术,我们将了解这些方法如何揭示潜在的问题点,并为改进提供方向。
|
5天前
|
算法 安全 测试技术
深入探索白盒测试:提升软件质量与效率的关键策略
【4月更文挑战第11天】 在软件开发的生命周期中,确保代码质量和功能的正确性是至关重要的。白盒测试,作为一项关键的验证手段,允许测试者通过检查内部结构、设计和编码逻辑来识别软件中的缺陷和漏洞。本文将探讨白盒测试的核心概念、方法及其在提升软件测试效率和质量上的重要性。我们将分析静态分析和动态测试的策略,并讨论如何通过白盒测试优化软件开发过程。
|
5天前
|
测试技术
【测试】构建质量保证之路:编写测试用例的艺术
【测试】构建质量保证之路:编写测试用例的艺术
|
5天前
|
jenkins Devops 测试技术
单元测试与质量保证:确保Visual Basic代码的健壮性
【4月更文挑战第27天】在VB开发中,单元测试是保证代码质量和软件健壮性的关键。本文介绍了单元测试的基础,包括其定义和好处,如提高代码质量、促进重构。接着,讨论了MSTest、NUnit和xUnit等VB单元测试工具。遵循TDD原则和最佳实践,编写独立、有针对性的测试,并注重测试速度和覆盖率。通过示例展示了如何在Visual Studio中设置和运行测试。最后,提到了持续集成和自动化测试工具,如Jenkins和静态代码分析工具,以提升软件开发效率和质量。单元测试不仅是技术手段,更是提升团队协作和软件工程水平的文化体现。
|
5天前
|
设计模式 前端开发 测试技术
软件质量的守门人——接口测试
接口作为API,是后端预定义的函数,用于系统间通信和数据交换。接口测试验证不同组件间的交互,确保其准确、可靠。常见应用场景包括集成测试、版本迭代测试、性能测试、安全测试和错误场景测试。随着服务端复杂性的增加,传统测试方法面临挑战,因此引入分层测试(如马丁福勒的测试金字塔模型)和自动化测试,以降低成本并提高效率。接口测试成为确保后端服务质量的关键,学习接口测试可从理解其价值、协议、工具使用及Mock测试等方面逐步进阶。
4 1
|
5天前
|
Java 测试技术 开发者
深入理解与应用单元测试:软件质量的守护者
【4月更文挑战第30天】 在现代软件开发过程中,单元测试作为保障代码健康的重要环节,其地位日益凸显。本文将探讨单元测试的核心概念、实施单元测试的重要性以及如何高效地设计并执行单元测试。通过实例分析,我们将揭示单元测试在确保软件产品质量和加速开发周期中的关键作用。
|
5天前
|
Java 测试技术 Shell
单元测试3.0实践之Golang质量生态建设
研发是否必须写单测?文章提到,单元测试对于确保代码质量、提高软件可靠性至关重要。在顶级互联网公司中,单元测试被认为是必要的,因为它能快速执行、降低维护成本,并能发现代码中的问题。文章还讨论了Go语言中单元测试的优化,如支持不同版本的Go、提高测试覆盖率、处理并发问题等。此外,文章介绍了一个用于Go语言单元测试的插件,该插件可以集成到持续集成流程中,提供详细的测试报告和覆盖率信息。通过这个插件,团队可以方便地管理和执行单元测试,提升开发效率和代码质量。
|
5天前
|
算法 测试技术 持续交付
深入白盒测试:提升软件质量与效率的关键策略
【4月更文挑战第23天】 在软件开发的复杂多变的环境中,确保产品的质量和可靠性是至关重要的。白盒测试作为一种重要的软件测试方法,允许测试者通过检查内部结构、设计和编码来验证软件的功能性和正确性。本文将探讨白盒测试的关键概念、技术及其在提升软件测试效率和质量中的应用。我们将重点讨论如何借助白盒测试发现潜在缺陷、优化测试用例设计,并通过具体案例分析展示其在实际中的应用效果。
|
5天前
|
存储 算法 测试技术
深入探索白盒测试:提升软件质量与效率的关键
【4月更文挑战第23天】 随着软件开发的复杂性日益增加,确保代码质量和性能的压力也随之升高。在多种软件测试方法中,白盒测试以其对内部结构和工作原理的透明性而受到重视。本文旨在探讨白盒测试的核心概念、技术及其在提升软件测试效率和质量中的应用。通过分析控制流测试、数据流测试以及静态分析等关键技术,我们将揭示如何有效运用白盒测试以发现潜在的逻辑错误和缺陷。
|
5天前
|
算法 Java 测试技术
深入解析白盒测试:提升软件质量与效率的关键
【4月更文挑战第22天】 在软件开发的复杂多变的世界中,保证代码质量和功能的正确性是至关重要的。白盒测试作为一种重要的软件测试方法,提供了一种透视软件内部逻辑结构的途径。本文将详细探讨白盒测试的概念、技术手段和实际应用,旨在帮助读者理解如何通过这种测试提高软件系统的稳定性和性能。文章还将讨论白盒测试中面临的挑战以及应对策略,以期为软件质量保证提供实用的指导。
57 2

热门文章

最新文章