测试人如何做单元测试

简介: 经验

昨天在技术交流群里,有同学说自己还想多学点技术,打算去做单元测试,写单测代码来提升技术,然后群里的同学就测试要不要做单元测试展开了很多讨论。

单元测试这方面我没有太多的实践经验,但工作过的几家公司在单元测试的上都有不同程度的落地实践。

这篇文章,我会基于自己的一些实践经验和经历,谈谈我对单元测试的理解和观点。


测试要做单元测试吗

首先聊聊第一个问题:测试要做单元测试吗?

我的回答:测试需要做单元测试,但要综合评估团队成员技能、个人意愿、项目迭代周期以及协作默契程度等很多因素,用合适的方法和手段在合适的时机切入,而不是一味强推

很多同学有一个误区:只要是名字带个测试,就觉得我也要做这件事,而忽略了事物的本质。

比如验收测试,一般指的是QA同学经过多轮测试后,交付给产品同学来进行验收交付的产出物是否满足预期设计。

比如全链路压测,很多测试同学都希望自己能主导落地,但忽略了为什么做全链路压测,怎么做,落地有哪些难点,自己能否解决,需要哪些角色和团队配合。

单元测试(unit testing),是指对软件中的最小可测试单元进行检查和验证,最初都是由开发来完成,即保障自己所在的环节交付的产出物满足进入下一阶段的标准

所以关于测试是否要做单元测试这个问题,我的观点是测试需要介入这个环节,尽可能早的去测试验证发现问题,但并不表示测试需要在这个环节什么都自己来做


单元测试落地的挑战

接下来聊第二个问题:单元测试落地要面临哪些挑战,或者说需要考虑哪些问题?

常见的落地挑战因素有下面几点:

1、开发不知道如何写单元测试

国内大部分公司缺乏单元测试环节,甚至code review都很缺乏,没有实践经验很难推动;

2、单元测试如何有效的进行检查

又回到了最初的问题:做了单元测试,如何有效检查单元测试的执行结果和效果表现呢?

3、如何评估和度量单元测试的质量

没有数据没办法衡量做单元测试的效果,度量的话从哪些维度和指标去评估单元测试的质量?

4、做单元测试对整个项目的交付周期是否有影响

现在的互联网行业大多迭代周期较快,做单元测试意味着需要投入一定时间,对deadline有一定影响;

5、开发个人的意愿(时间投入、个人技能、物质回报)

很简单的一个逻辑,谁愿意吃力不讨好做一件短期内没什么明显收益还没啥好处的事情?


单元测试如何有效落地

下面是我总结的关于单元测试落地的一些方法,会从不同维度去实施,仅供参考。

管理

  • 提高研发对于质量保障的认可度,加强宣讲;
  • 优先选择有意愿和有精力的团队进行推广试点;
  • 自上而下推动,和OKR挂钩,并且是持续的挂钩;
  • 参与的同学在需求和工时评估方面需要做一定调整;
  • 新入职员工或新参与员工的单元测试工作由师兄负责引导实现;

协作

  • QA和DEV针对单元测试case级别达成共识;
  • QA和DEV在单元测试环节进行合作共建和职责边界划分;
  • QA提供用例,DEV进行实现;
  • QA提供的用例需要经过评审并通过;
  • QA进行Check和校验(度量维度和评估指标与开发达成一致);

实施

  • 设定优先级,从P0核心模块开始实现;
  • 覆盖范围以service核心模块,新增功能优先;
  • 在code review阶段,对单元测试实现情况进行检查;
  • 需要通过实施前后不同维度的比较度量来评估能否带来收益;
  • 数据度量:覆盖率、通过率;
  • 发现bug数:线上问题、线下发现的block bug;
  • 度量粒度:小到最底层函数级别,大到代码类方法;
  • 测试用例:单元测试的实现和度量,一定是case by case的;


目录
相关文章
|
12天前
|
测试技术 开发者 UED
探索软件测试的深度:从单元测试到自动化测试
【10月更文挑战第30天】在软件开发的世界中,测试是确保产品质量和用户满意度的关键步骤。本文将深入探讨软件测试的不同层次,从基本的单元测试到复杂的自动化测试,揭示它们如何共同构建一个坚实的质量保证体系。我们将通过实际代码示例,展示如何在开发过程中实施有效的测试策略,以确保软件的稳定性和可靠性。无论你是新手还是经验丰富的开发者,这篇文章都将为你提供宝贵的见解和实用技巧。
|
3月前
|
JSON Dubbo 测试技术
单元测试问题之增加JCode5插件生成的测试代码的可信度如何解决
单元测试问题之增加JCode5插件生成的测试代码的可信度如何解决
55 2
单元测试问题之增加JCode5插件生成的测试代码的可信度如何解决
|
2月前
|
IDE 测试技术 持续交付
Python自动化测试与单元测试框架:提升代码质量与效率
【9月更文挑战第3天】随着软件行业的迅速发展,代码质量和开发效率变得至关重要。本文探讨了Python在自动化及单元测试中的应用,介绍了Selenium、Appium、pytest等自动化测试框架,以及Python标准库中的unittest单元测试框架。通过详细阐述各框架的特点与使用方法,本文旨在帮助开发者掌握编写高效测试用例的技巧,提升代码质量与开发效率。同时,文章还提出了制定测试计划、持续集成与测试等实践建议,助力项目成功。
85 5
|
3月前
|
JSON 测试技术 数据格式
单元测试问题之使用JCode5插件生成测试类如何解决
单元测试问题之使用JCode5插件生成测试类如何解决
129 3
|
3月前
|
测试技术
单元测试问题之使用TestMe时利用JUnit 5的参数化测试特性如何解决
单元测试问题之使用TestMe时利用JUnit 5的参数化测试特性如何解决
47 2
|
3月前
|
测试技术 C# 开发者
“代码守护者:详解WPF开发中的单元测试策略与实践——从选择测试框架到编写模拟对象,全方位保障你的应用程序质量”
【8月更文挑战第31天】单元测试是确保软件质量的关键实践,尤其在复杂的WPF应用中更为重要。通过为每个小模块编写独立测试用例,可以验证代码的功能正确性并在早期发现错误。本文将介绍如何在WPF项目中引入单元测试,并通过具体示例演示其实施过程。首先选择合适的测试框架如NUnit或xUnit.net,并利用Moq模拟框架隔离外部依赖。接着,通过一个简单的WPF应用程序示例,展示如何模拟`IUserRepository`接口并验证`MainViewModel`加载用户数据的正确性。这有助于确保代码质量和未来的重构与扩展。
76 0
|
3月前
|
测试技术 Java Spring
Spring 框架中的测试之道:揭秘单元测试与集成测试的双重保障,你的应用真的安全了吗?
【8月更文挑战第31天】本文以问答形式深入探讨了Spring框架中的测试策略,包括单元测试与集成测试的有效编写方法,及其对提升代码质量和可靠性的重要性。通过具体示例,展示了如何使用`@MockBean`、`@SpringBootTest`等注解来进行服务和控制器的测试,同时介绍了Spring Boot提供的测试工具,如`@DataJpaTest`,以简化数据库测试流程。合理运用这些测试策略和工具,将助力开发者构建更为稳健的软件系统。
59 0
|
3月前
|
测试技术 Java
全面保障Struts 2应用质量:掌握单元测试与集成测试的关键策略
【8月更文挑战第31天】Struts 2 的测试策略结合了单元测试与集成测试。单元测试聚焦于单个组件(如 Action 类)的功能验证,常用 Mockito 模拟依赖项;集成测试则关注组件间的交互,利用 Cactus 等框架确保框架拦截器和 Action 映射等按预期工作。通过确保高测试覆盖率并定期更新测试用例,可以提升应用的整体稳定性和质量。
74 0
|
3月前
|
测试技术 数据库
探索JSF单元测试秘籍!如何让您的应用更稳固、更高效?揭秘成功背后的测试之道!
【8月更文挑战第31天】在 JavaServer Faces(JSF)应用开发中,确保代码质量和可维护性至关重要。本文详细介绍了如何通过单元测试实现这一目标。首先,阐述了单元测试的重要性及其对应用稳定性的影响;其次,提出了提高 JSF 应用可测试性的设计建议,如避免直接访问外部资源和使用依赖注入;最后,通过一个具体的 `UserBean` 示例,展示了如何利用 JUnit 和 Mockito 框架编写有效的单元测试。通过这些方法,不仅能够确保代码质量,还能提高开发效率和降低维护成本。
52 0
|
3月前
|
Java 测试技术 API
SpringBoot单元测试快速写法问题之复杂的业务逻辑设计有效的单元测试如何解决
SpringBoot单元测试快速写法问题之复杂的业务逻辑设计有效的单元测试如何解决