测试工程师如何帮助开发域的质量变好

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
应用实时监控服务-用户体验监控,每月100OCU免费额度
性能测试 PTS,5000VUM额度
简介: 测试工程师如何帮助开发域的质量变好

1、SonarQube的技术债务

SonarQube扫描出来Gitlab的repo的技术债务需要清零,在迭代过程中,团队需要持续关注技术债,保持技术债稳定下降的趋势,建立修复技术债的技术故事卡(举例如下),在对应的提交中需要将代码提交的commit message中的需求id填写该技术故事卡的ID。

前后端技术债务减少10%
AC1:后端代码库减少 sonar 扫描问题,BUG、漏洞、坏味道减少10%
AC2:后端开发配置 idea 本地 sonarlint 插件(开发时注意不引入新的问题)

2、单元测试

单元测试的两种实践:

  • 普通的开发模式实现开发实现故事卡的逻辑代码,然后再根据写好的代码编写单元测试,对单元模块进行测试。
  • 采用测试驱动开发的开发人员,根据用户故事中的AC或测试用例,先进行测试用例的编写,再进行功能模块的开发。

单元测试的一些规则:

  • 被测函数的外部函数调用,外部服务调用,都需要解耦(java推荐mockito)。
  • 被测试函数访问数据库、消息中间件、redis等中间件的,都需要解耦。
  • 测试类在test目录下所在的路径应与被测试的类在src/main/java下的路径保持一致。通过约定的规则,测试类和被测试类相对应,方便查看和定位。
  • 测试类的命名和被测试类保持一致,后缀加上Test。
  • 测试用例的命名应该采用should_get_when的方式:should_get_number_when_score_given_equal_60()。
  • 每一个测试用例必须有断言,用断言验证测试结果。
  • 单元测试代码和被测试业务逻辑代码最好再一次commit中提交,如果分开,也建议前后2-3个commit中提交,避免先写完逻辑代码,批量补单元测试的情况。

3、CodeReview

代码评审比较常用的有:

  • 基于Gitlab的Merge Request,相关评审人员走查通过后,代码合并到release分支中
  • 集体代码走查,在开发人员提交测试前,组织团队成员进行集体评审。目前组织级的实践要求通过Gitlab进行代码评审,各团队可以自行选择是否开展集体代码走查,并制定执行集体代码走查的条件和规则
    两种实践可以混合使用。

3.1 基于Merge Request的评审

    1. 开发人员在feature开发分支上完成代码提交,并推送到gitlab服务器
    1. 开发人员在Gitlab上发起Merge Request,目标分支为release分支。选择Assignee(指定Reviewer),选择审核人(approvers)及最小批准人数(Approvals required)。根据描述模板中的内容检查代码状况,然后进行提交。

image.png

    1. 代码审核人员审查提交的Merge Request,评审时为存疑的代码片段添加注释comments,MR的创建者应对相应的注释及时解答。
    1. 审核通过,可以提交Merge,将代码合并到目标分支。

3.2 集体代码走查

3.2.1 集体代码走查的意义

    1. 传播知识,避免对特定模块/特定人员的依赖。
    1. 达成共识,避免重复,改善设计。
    1. 让新人从讨论中学习到解决问题的思路和技术要点。
    1. 培养新人的最直接和最有效的途径,对已有代码的讨论,既实例化,又能直接提升质量。

3.2.2 集体代码走查的频次

频率建议一开始每天做一次代码走查。如果大家时间很难协调, 也要保证每周两到三次。时长根据团队大小决定,如果小团队(2~3人),时间控制在半小时以内。如果团队人员较多,1小时为宜。根据发现问题的情况,及时调整评审的范围和时长。频率和时⻓可以根据团队情况不断调整,最终找到最合适你团队的实践。

3.2.3 评审议程

    1. 检查上次代码走查所记录的改进点是否已经修复,更新记录表
    1. 代码作者简要介绍所走查的代码的业务上下文和开卡验卡验收条件
    1. 展示代码规范标准工具扫描结果
    1. 作者展示所修改的代码,参与者提问,作者答疑
    1. 作者记录改进点
目录
相关文章
|
2月前
|
测试技术 持续交付 UED
软件测试的艺术:确保质量的实战策略
在软件开发的舞台上,测试是那把确保每个功能如交响乐般和谐奏响的指挥棒。本文将深入探讨软件测试的重要性、基本类型以及如何设计高效的测试策略。我们将通过一个实际的代码示例,展示如何运用这些策略来提升软件质量和用户体验。
|
2月前
|
jenkins 测试技术 持续交付
软件测试中的自动化与持续集成:提升效率与质量的关键
在快节奏的软件开发环境中,自动化测试和持续集成已经成为不可或缺的部分。本文将探讨自动化测试和持续集成的重要性,以及它们如何协同工作以提高软件开发的效率和质量。通过分析自动化测试的策略、工具选择以及持续集成的实践,我们将揭示这些技术如何帮助开发团队快速响应变化,减少错误,并加速产品上市时间。
|
2月前
|
测试技术 开发者 Python
自动化测试之美:从零构建你的软件质量防线
【10月更文挑战第34天】在数字化时代的浪潮中,软件成为我们生活和工作不可或缺的一部分。然而,随着软件复杂性的增加,如何保证其质量和稳定性成为开发者面临的一大挑战。自动化测试,作为现代软件开发过程中的关键实践,不仅提高了测试效率,还确保了软件产品的质量。本文将深入浅出地介绍自动化测试的概念、重要性以及实施步骤,带领读者从零基础开始,一步步构建起属于自己的软件质量防线。通过具体实例,我们将探索如何有效地设计和执行自动化测试脚本,最终实现软件开发流程的优化和产品质量的提升。无论你是软件开发新手,还是希望提高项目质量的资深开发者,这篇文章都将为你提供宝贵的指导和启示。
|
3月前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
2月前
|
敏捷开发 监控 测试技术
软件测试中的自动化策略:提升效率与质量
在软件开发过程中,测试是确保产品质量的关键环节。随着敏捷开发模式的普及,自动化测试成为提升测试效率和质量的重要手段。本文将介绍自动化测试的基本概念、实施步骤以及如何通过自动化测试提高软件测试的效率和质量,同时分享一些实用的自动化测试工具和技巧。
67 3
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
自动化测试的新篇章:利用AI提升软件质量
【10月更文挑战第35天】在软件开发的海洋中,自动化测试犹如一艘救生艇,它帮助团队确保产品质量,同时减少人为错误。本文将探索如何通过集成人工智能(AI)技术,使自动化测试更加智能化,从而提升软件测试的效率和准确性。我们将从AI在测试用例生成、测试执行和结果分析中的应用出发,深入讨论AI如何重塑软件测试领域,并配以实际代码示例来说明这些概念。
77 3
|
3月前
|
敏捷开发 监控 jenkins
自动化测试之美:打造高效的软件质量保障体系
【10月更文挑战第20天】在软件开发的海洋中,自动化测试如同一艘精准的导航船,引领项目避开错误的礁石,驶向质量的彼岸。本文将扬帆起航,探索如何构建和实施一个高效的自动化测试体系,确保软件产品的稳定性和可靠性。我们将从测试策略的制定、工具的选择、脚本的编写,到持续集成的实施,一步步描绘出自动化测试的蓝图,让读者能够掌握这一技术的关键要素,并在自己的项目中加以应用。
42 5
|
3月前
|
测试技术
软件质量保护与测试(第2版)学习总结第十章 黑盒测试
本文是《软件质量保护与测试》(第2版)第十章的学习总结,介绍了黑盒测试的基本概念和方法,包括等价类划分、边界值分析和因果图法,并通过具体例子展示了如何设计测试用例来验证软件的功能性需求。
85 1
软件质量保护与测试(第2版)学习总结第十章 黑盒测试
|
3月前
|
人工智能 人机交互 数据库
软件质量保护与测试(第2版)学习总结第一章
本文是《软件质量保护与测试》(第2版)第一章的学习总结,概述了软件的特征、分类、软件工程的层次化技术、现代软件开发的变化,以及软件质量的概念和评价体系,包括黑盒、白盒和灰盒测试方法。
43 1
软件质量保护与测试(第2版)学习总结第一章
|
3月前
|
Java 测试技术 持续交付
探索自动化测试的奥秘:提升软件质量的关键
【10月更文挑战第20天】 在当今快速发展的软件行业中,自动化测试已成为确保产品质量和加速开发周期的重要工具。本文将深入探讨自动化测试的核心概念、实施策略及其对软件开发生命周期的影响,旨在为读者提供一种全面理解自动化测试的视角,并展示如何有效地将其应用于实际项目中以提高软件质量和效率。
35 2