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
    评论
### 回答1: Jenkins、GitLab和Kubernetes是三个常用的开源工具。它们能够相互协作形成一个完整的构建自动化CI/CD发布流水线。 首先,开发者在GitLab的代码仓库提交代码,触发GitLab的Webhook,告知Jenkins需要进行构建。 接下来,Jenkins开始执行构建任务,它会拉取GitLab的代码仓库,并在Kubernetes集群创建一个构建环境。在构建环境,Jenkins会进行一些构建工作,如编译代码、运行测试、打包程序等。 当Jenkins构建成功后,它会将构建好的程序镜像推送到Kubernetes上,Kubernetes将在自己的集群创建一个新的Pod,并将新的程序部署到这个Pod。当程序运行成功后,Kubernetes自动更新负载均衡器路由。 这样,整个构建自动化CI/CD发布流水线就完成了,从代码仓库提交到程序部署,全部都是自动完成的,可以大大提高开发效率,减少出错的可能性。同时,由于使用了Kubernetes,可以实现水平扩展和高可用性,保证了程序稳定运行。 ### 回答2: Jenkins、GitLab和Kubernetes(k8s)是如今广泛应用于软件开发和部署的热门工具。这三个工具的结合,为软件开发的自动化构建、持续集成和持续交付(CI/CD)提供了更加高效、可靠的方法。 当我们考虑如何将这三个工具集成到一起时,以下是一种建议的CI/CD发布流水线: 1. GitLab仓库维护代码版本控制 GitLab是一个代码托管平台,它提供了完整的Git存储库管理工具,包括代码审查、问题跟踪和持续集成。我们可以在GitLab设置一个仓库,用于维护我们的应用程序代码。我们的代码将被存储在该仓库,可以利用GitLab提供的版本控制和分支管理功能方便地进行协作和开发。 2. Jenkins构建应用程序 Jenkins是一个流行的自动化构建工具,它可以与GitLab集成,以便在GitLab存储库的变更上触发自动化构建。Jenkins从GitLab仓库获取代码并自动构建我们的应用程序。如果构建成功,则可以将构建后的应用程序存储在构建存储库或者将其部署到Kubernetes集群,否则通知开发者维护代码。 3. 部署到Kubernetes集群 Kubernetes (k8s)是一个开源容器编排管理器,它可以帮助我们管理和部署容器化的应用程序。我们可以将我们的应用程序容器化,并将其部署到Kubernetes集群上,这将为我们提供高可用性、可伸缩性和自动化容器调度等好处。 我们可以使用Kubernetes的K8s自动化部署工具,以通过各种环境阶段(测试、预生产和生产)自动部署容器化应用程序的不同副本,从而完成全面部署。 4. 自动化测试应用程序 在部署应用程序部署之前,应使用不同的测试阶段对其进行测试,包括单元测试、集成测试和端到端测试。在一个CI/CD管道,我们可以添加多个虚拟机代表不同的测试阶段,来自动化测试应用程序。如果某种类型的测试失败,则将在构建次数的下面进行记录和报警,以便修复应用程序的问题。 通过使用上述流程,我们可以实现一个自动化构建和部署的CI/CD流水线,从而形成一个协调的工具链集成,使软件开发活动化和规范化。这将为我们提供更高效、可靠的开发和部署环境,从而缩短开发周期、减少对人力的依赖,以及提高应用程序质量和交付速度。同时,我们的代码将始终被版本控制,让我们随时翻查历史,充分发掘之前的知识和经验。 ### 回答3: 现代软件开发过程,持续集成、持续交付和持续部署成为了不可或缺的重要环节,对于构建自动化 CI/CD 发布流水线,使用 Jenkins、GitLab 和 Kubernetes 是目前主流的选择。 Jenkins 是最经典的自动化构建工具之一,它可以无缝集成 GitLab,实现代码检出、运行测试、打包构建、发布部署等操作。此外,Jenkins 也支持插件化的扩展,可以方便的与第三方工具进行集成并自动化构建。对于 Jenkins,我们需要建立一个 Jenkins 服务器,配置好 GitLab 仓库的访问权限,并在 Jenkins 配置 WebHook,使其能够接收 GitLab 代码提交的通知触发自动化构建。 GitLab 是一款完整的 CI/CD 工具链,除了支持源码管理、合并请求和协作功能外,还内置了 CI/CD 功能,可以集成测试、构建、发布等自动化流程。与 Jenkins 集成,可以实现更强大的自动化构建和交付流程。我们需要在 GitLab 项目配置自动化构建流水线,并在相对应的流程配置 Jenkins 以触发相关的构建、测试和发布操作。 Kubernetes 是一款流行的容器编排及部署工具,可以极大地简化应用程序的部署和扩展。对于自动化构建和交付,Kubernetes 的作用在于将应用程序打包为 Docker 镜像,然后自动部署到云端集群环境,完成持续部署的流程。我们需要在 Kubernetes 配置相应的应用程序部署文件,并将其注册到 Kubernetes 集群,以便实现自动化部署和发布。通常我们需要部署 Kubernetes 应用程序的一个运行环境,如 Harbor 仓库,容器运行时等。 在应用程序的构建和交付过程,最重要的是持续监测和优化,我们需要使用可视化和统一的工具来监测应用程序的性能和健康状况。对于这个目的,我们可以选择一些可视化的 APM 工具,如 New Relic,将其集成到我们的 CI/CD 流程,以监测和优化应用程序的性能。此外,我们也可以使用一些 CI/CD 管理平台,例如 Jenkins X,来简化整个流程,并提供一个更全面的工具来监测和管理应用程序的构建和交付流程。 总之,构建自动化 CI/CD 发布流水线是现代软件开发的必要环节,使用 Jenkins、GitLab 和 Kubernetes 可以大大简化这个过程,提高开发流程的自动化和效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值