CI/CD流水线中执行自动化单元测试

一、什么是单元测试?

单元测试什么是单元测试?单元测试是一小段代码,用于测试应用程序编写的代码的逻辑。单元测试允许对代码进行快速内存测试,闭环开发人员代码验证反馈循环。

二、C#中的单元测试示例

  1. namespace WebDevTutor

  2. {

  3. public static class Calculator

  4. {

  5. public static int Add(int addend1, int addend2)

  6. {

  7. return addend1 + addend2;

  8. }

  9. public static int Subtract(int minuend, int subtrahend)

  10. {

  11. return minuend - subtrahend;

  12. }

  13. }

  14. }

下面是为用 C# 编写的简单计算器库编写的一些单元测试的简单示例。如果你从未编写过 C#,请不要害怕这个代码示例。同样的原则适用于几乎任何其他编程语言!计算器类是将要测试的类,这称为被测单元或被测类。

  1. using Xunit;

  2. namespace WebDevTutor.Tests

  3. {

  4. public class CalculatorTests

  5. {

  6. [Fact]

  7. public void Add_ShouldReturn4When2And2AreAdded()

  8. {

  9. // Arrange

  10. int expectedSum = 4;

  11. // Act

  12. var sum = Calculator.Add(2, 2);

  13. // Assert

  14. Assert.Equal(expectedSum, sum);

  15. }

  16. [Fact]

  17. public void Subtract_ShouldReturn90When10IsSubtractedFrom100()

  18. {

  19. // Arrange

  20. int expectedDifference = 90;

  21. // Act

  22. var difference = Calculator.Subtract(100, 10);

  23. // Assert

  24. Assert.Equal(expectedDifference, difference);

  25. }

  26. }

  27. }

这两个测试针对 Calculator 类的 Add 和 Subtract 方法运行基本测试用例。这两个单元测试在内存中运行都在5 毫秒内!这是一个简单的例子,但我希望它展示了编写单元测试的基本模式。

三、我需要在CI/CD 流水线中运行自动化测试吗?

是的——你需要在 CI/CD 流水线中运行自动化单元测试。在这篇文章中,我们将讨论您需要在 CI/CD 流水线中运行自动化单元测试的 4 个原因。

  • 开发人员代码验证反馈循环

  • 预验证

  • 步步为营

  • 减少“另一个开发人员写了这段代码”的问题

四、开发人员代码验证反馈循环

通过单元测试提高开发速度判断当前代码是否修复错误的最快方法是什么? 也许你启动了 UI 并创建了一系列点击事件来模拟用户流。或者启动 Postman 并开始用请求访问你的 API。这些测试习惯在需要时非常有用,但是如果只是对代码中的一个小单元进行更改怎么办?如果正在修复应用程序底层的一个简单错误,可能根本不需要运行 UI。甚至可能不需要在本地为API 启动调试会话。我们可以通过添加平均每条不到 10 毫秒的命令行运行单元测试来缩短开发人员代码验证反馈循环。在编写验证修复错误的单元测试后,可以轻松(并重复)验证更改是否符合预期结果。不需要用UI按钮单击流,这些流对于测试小更改来说是过大的,可通过编写单元测试并通过命令行在本地运行它们来获得亚秒级的自动反馈。

五、预验证

用单元测试保护自己 现在是下午 4 点,刚从老板那里收到一个高优先级的错误。 但是你在下午 5 点有家庭聚餐。你快速编写错误修复并添加单元测试以验证代码更改,提交代码并在下午 4:45 创建拉取请求,正好赶上,可以在知道已成功修复错误后下班。提交更改,拉取请求部署到产品中,然后带着微笑与家人共进晚餐。第二天早上回来工作时,你会收到一堆电子邮件和 Slack 消息。修复的这个bug导致相当大的回归量。但是你对这个代码库了如指掌——这怎么可能发生?是因为修复的这个bug破坏了上周完成的另一个修复bug的代码!你深入研究代码,修复此问题很简单,只需要在一行代码中添加 null 或空检查。如何防止这种回归验证?答案在下一节“过度自信”中。

六、步步为营

通过单元测试添加回归测试 修复bug导致了回归验证,但是怎么知道要回归验证呢?应该手动执行每个边界测试用例吗?不,这是不可能完成的任务。是否应该手动执行尽可能多的测试用例?当然可以,但这需要相当长的时间。 在 6 个月后,当这段代码又出现了一个另外的bug,你怎么记得再次运行相同的测试用例?简而言之,没有开发人员能够记住代码库中每个类或代码片段的测试用例。 尤其是超过 6 个月的时间!开发人员以合理的速度对代码进行回归测试的唯一方法是使用自动化单元测试 如果上周修复bug有单元测试来验证更改,那么这种回归验证很可能会被CI/CD 流水线捕获——单元测试会失败。在修复bug的代码分支中添加新的单元测试或修改以前的单元测试是一个表明该 bug 已被修复很好的标志,在单元测试运行时,再次复现了这个bug则会被CI/CD流水线捕获。

七、减少“另一个开发人员写了这段代码”的问题

用单元测试保护同事代码“另一个开发人员写了这段代码”问题的概念: “另一位开发人员编写了此代码”问题是当前开发人员(你)无法完全理解另一位开发人员编写的代码中的需求、标志和模式。 这是 Web 开发的基础。 副作用是:开发速度慢,更改代码时回归的风险高,以及突然想问以前的开发人员为什么代码是这样写的。某些操作可以帮助减少此问题的影响,但此问题从未得到真正的解决。 注意:在 6 个月后,当你回过头来看自己刚刚编写的代码时,你也是“另外一个开发人员”!你刚在一家新公司,一个全新的代码库中工作。 正在尝试拉一个分支修复一个简单bug。他们要求你在一段简单的代码中进行修复一个简单的bug。但实际上,对于新开发人员来说,这种代码更改并不简单。你以前从未见过此代码! 所有这些代码都是由另一位开发人员编写的。当一个项目有单元测试时,有标准化的文档和自动化测试,可以为新开发人员提供很棒的指导。查看新代码(另一位开发人员编写了此代码)时,如果你想弄懂一段代码定义过的(和测试过的)功能,单元测试是一个很好的着手点。当您成为新代码的编写者时,请牢记这一点,其他开发人员会将你的代码视为另一个开发人员编写了此代码。为未来的新开发人员提供代码文档,为你的工程编写单元测试并在CI/CD 流水线中运行它们。PS:如果6个月后回来看你刚写的代码的“另一个开发人员”是你,你会考虑的! 这个也是给自己的一个保护。

行动吧,在路上总比一直观望的要好,未来的你肯定会感 谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入扣群: 320231853,里面有各种软件测试+开发资料和技术可以一起交流学习哦。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

  • 57
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值