CI/CD 管道中的自动化测试:类型和阶段

news2025/1/23 7:05:23

在上一篇文章中,我们讨论了敏捷团队自动化测试用例的各种用例。其中一种情况是,团队希望将测试与每个构建集成,并将持续集成作为构建过程的一部分。

在本文中,我们将讨论持续集成/持续交付平台中的集成测试。

让我们先从基础知识开始。

什么是自动化测试?

软件测试是指根据一组测试用例执行测试,并将实际结果与预测结果进行比较。在此过程中遵循几个步骤和测试技术。测试对于确保产品质量至关重要。此过程通常由测试人员团队手动完成。然而,在自动化测试中,该过程是使用软件工具和技术实现自动化的。在这里,不再需要手动操作,而是自动创建脚本并运行测试用例。自动化测试消除了人为错误、覆盖范围等许多问题。它还节省了时间,提高了进行测试的便利性,提高了效率和效果。

CI/CD 管道中的自动化测试

自动化测试是CI/CD 管道的核心部分,因为快速运行的测试可以为开发人员提供早期反馈。及早发现的问题或错误有可能及早得到纠正。因此,发布的产品将更加准确且无错误。这提高了产品的整体质量,从而赢得了客户的满意度。简而言之,CI/CD管道中自动化测试的优势如下:

  • 符合“快速构建,快速失败”的 CI/CD 理念
  • 减少人工,从而节省时间并降低出错的可能性。
  • 随着测试用例数量的增加,测试结果更加准确,并且可以覆盖更广泛的区域。
  • 立即获得任何问题的反馈
  • 可以生成并比较多个测试结果,以确保质量和一致性

CI/CD 管道中使用的自动化测试类型

  • 单元测试:这是在模块编码和审查后进行的低级测试。测试用例旨在测试各个组件。目的是确保每个组件在任何情况下都能按预期工作。
  • 集成测试:集成是指测试应用程序内组件的交互。此测试是在所有模块都经过单元测试后进行的。主要目的是测试模块接口并检查当一个模块调用另一个模块的功能时参数传递没有错误。
  • 系统测试:测试旨在验证完全开发的系统并确保其符合需求规范文档。通常,在此阶段,软件已准备好供潜在用户使用。这些类型的系统测试称为 alpha(由组织内的开发团队执行)、beta(由选定的一组用户/客户执行)或验收测试(由用户/客户执行以确定交付的接受情况)系统)。

什么是持续集成和持续交付?

简而言之,持续集成允许开发团队将他们的代码集成到共享存储库中。这有助于维护代码质量并尽早识别本地版本代码的潜在问题。

持续交付通常也称为“持续部署”。开发团队不断合并的所有内容都会不断部署到实际环境中。

由于大多数开发人员都是并行工作的,因此不断地将他们的代码集成到一个存储库中意味着主分支会不断更新新功能。为了确保代码质量不会因如此快速发生的变化而受到影响,测试必须以相同的速度进行。

毫无疑问,在这种环境下进行手动测试并不是实现这一目标的最佳方法。自动化测试是 CI/CD 管道中成功测试的关键。

9 个持续交付阶段

  1. 开发: 开发人员根据项目需求或功能请求构建代码。
  2. 编写测试:一旦编写了代码,就需要编写测试。此时,这些测试通常是开发人员编写的单元测试。
  3. 本地测试:然后进行本地测试,以检查所有测试是否通过并确保代码不会中断。通常,会设置一个百分比作为运行测试需要达到的通过率。
  4. Rebase和解决冲突:在实际的开发场景中,会有多人合并他们的代码。开发人员需要确保他们的分支始终更新。用最新的合并代码更新分支称为“变基”。一旦重新定位,可能会出现一些需要解决的冲突。之后,针对重新调整基础的代码再次运行测试。
  5. 提交:测试通过后,代码就可以提交所有更改。
  6. 构建:然后将开发的源代码组合起来,构建一个可以在实例上运行的部署工件,如果环境在本地,则该工件可以在服务器上运行。此代码现在可以部署到不同的测试环境中。
  7. UAT:然后将代码部署到测试服务器,测试人员开始测试该功能。这些测试可以是自动化的,也可以是手动的。
  8. 合并:如果正在测试的提交得到测试人员的批准,则会将其合并到主分支中。
  9. 生产部署:合并代码后,就会将其部署到生产中。

开发人员编写的每个构建代码都需要执行上述过程。

自动化测试在 CI/CD 管道中处于什么位置?

自动化测试最好在构建阶段完成并可以部署代码后进行。单元测试、UI 测试和集成测试都可以在此阶段运行。这些测试有助于确保代码符合质量标准。

此阶段可能持续几分钟到几个小时,具体取决于自动化的架构方式。

测试可以并行运行以更快地执行它们。如果代码在测试阶段失败,则可以拒绝构建,而无需进一步投入任何手动测试时间。

CI/CD 使用的工具

  • Jenkins: Jenkins 是一个用于持续集成的开源工具。它可以免费使用,并且可以通过界面和脚本配置作业。
  • Travis CI: 该工具对于由 GitHub 托管的开源项目是免费的。
  • Gitlab: Gitlab 是一款版本控制工具,拥有自己的基于云的 CI 方法。它支持多个平台,有免费版和付费版。
  • Bamboo: Bamboo 是 Jira 的 CI 工具。如果您的组织使用 Jira,那么检查一下这个工具将会很有帮助。它还支持票证批准时的自动合并。

CI/CD 管道的最佳实践,以充分利用测试自动化

  • 增量更改:始终建议遵循逐个功能的方法。如果功能确实很大,最好将其分解为更小且测试速度更快的功能。这对于自动化来说很重要,因为如果出现问题,更容易找出根本原因。如果您的承诺太大,那么找出问题的原因将是一项艰巨的任务。
  • 确定什么可以自动化:团队快速潜入并说“让我们自动化一切”是很常见的,但这是一个常见的错误。我们必须了解自动化的目的并确定应该自动化的测试用例。
  • 并行测试: 测试应该并行运行,以使测试更加高效和及时。它可以大大减少运行测试所需的时间,从而更快地给出结果。但仅仅并行执行这些测试是不够的;扩展运行测试的服务器大小也很重要,这样才能真正提高测试速度。

结论

自动化测试是成功部署项目同时保持质量标准的重要组成部分。确保在每个阶段都运行测试可以使代码质量具有良好的透明度。可以在早期发现错误,并且可以及时解决可能由错误引起的任何延迟。拥有集成测试的 CI/CD 管道有助于加快测试和部署过程。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1697358.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Cloud | 服务 “注册与发现“ 框架 : Eureka框架

目录: Eureka 的 "工作机制" :一、Eureka 的 "工作原理" ( 两大组件 ) :1.1 Eureka Server ( 服务注册中心 )1.2 Eureka Client ( 服务/服务实例,其存在 "两种角色" : ①服务提供者 ②服务消费者 ) :Eureka Client 的 含义…

【LeetCode刷题】滑动窗口思想解决问题:长度最小的子数组、无重复字符的最长子串

【LeetCode刷题】Day 7 题目1:209.长度最小的子数组思路分析:思路1:暴力枚举 O(N^2^)思路2:滑动窗口 O(N) 题目2:3. 无重复字符的最长子串题目分析:思想1:暴力枚举哈希表O(N^2^)思想2&#xff1…

时间(空间)复杂度(结构篇)

目录 前言: 一、时间复杂度 1.1 时间复杂度的定义 1.2 时间复杂度的分析 表示方法: 1.3 常见的时间复杂度 1.4 时间复杂度的计算以及简单的分析 冒泡排序 折半查找(二分查找) 斐波那契数列(递归&#xff09…

Android卡顿丢帧低内存与adb shell内存状态

Android卡顿丢帧低内存与adb shell内存状态 卡顿丢帧除了CPU/GPU层面,另外,也需要特别注意整机低内存情况。kswapd0 是一个内核工作线程,内存不足时会被唤醒,做内存回收工作。 当内存频繁在低水位的时候,kswapd0 会被频…

人类最友好语言? YAML 深入解析:从语法到最佳实践

什么是YAML YAML(YAML Ain’t Markup Language)是一种人类可读的数据序列化语言。它的设计目标是使数据在不同编程语言之间交换和共享变得简单。YAML采用了一种简洁、直观的语法,以易于阅读和编写的方式表示数据结构。 YAML广泛应用于配置文…

C语言题目-添加逗号(详解)

前言 今天来看看如何使用C语言对一串数字添加逗号吧&#xff0c;在我们电子账户上的余额都是每3位数有一个逗号吧&#xff0c;今天让我们来使用C语言实现这个功能。 题目描述 对于一个较大的整数 N(1<N<2,000,000,000) 比如 980364535&#xff0c;我们常常需要一位一位数…

8、Qt—Log4Qt使用小记2(每日产生文件)

前言&#xff1a; 开发平台&#xff1a;Win10 64位 开发环境&#xff1a;Qt Creator 13.0.0 构建环境&#xff1a;Qt 5.15.2 MSVC2019 64位 例如&#xff1a;上一篇文章中笔者记录了Log4qt的编译及配置使用&#xff0c;这篇文章重点写下每天产生文件到指定文件夹中&#xff0c;…

软考高级架构师:数据库案例篇 - ER 图和数据流图

一、讲解 从数据流图&#xff08;DFD&#xff09;转换为实体关系图&#xff08;ER图&#xff09;是一个重要的步骤&#xff0c;可以帮助将系统的动态流程转换为静态的数据模型。以下是一些经验和步骤&#xff0c;帮助你完成这一过程&#xff1a; 1. 理解数据流图 识别进程&a…

【操作系统】基本概念 解析+思维导图(特征、概念、功能)并发 共享 虚拟 异步

1.操作系统基本概念 思维导图 1.1 概念和功能 概念 操作系统&#xff08;Operating System&#xff0c;OS&#xff09; 1.操作系统是系统资源的管理者&#xff1a; ​ 操作系统是指控制和管理整个计算机系统的硬件和软件资源&#xff0c;并合理组织调度计算机的工作和资源分…

跟TED演讲学英文:How to escape education‘s death valley by Sir Ken Robinson

How to escape education’s death valley Link: https://www.ted.com/talks/sir_ken_robinson_how_to_escape_education_s_death_valley Speaker: Sir Ken Robinson Date: April 2013 文章目录 How to escape educations death valleyIntroductionVocabularySummaryTranscri…

redis6.2.7安装

1、下载上传到服务器 从官下载redis&#xff0c;地址 https://redis.io/download/#redis-downloads 然后上传到服务器目录 app/apps目录下 2、安装gcc编译器 使用gcc --version命令测试是否已经安装了gcc编译环境&#xff0c;如果没有安装执行以下命令安装 yum install -y …

2024系统架构师软考考题考点回忆版

2024系统架构师软考试题/考点梳理 选择题 (75道单选题) 软件测试(P205) 静态测试:是被测程序不运行,只依靠分析和检查源程序的语句、结构、过程来检查程序是否有错误。动态测试:运行被测试程序,对得到的结果与预期的结果进行比较分析,同时分析运行效率和健壮性能等。…

人力资源新趋势:RPO项目为何成为企业招聘首选?

随着市场竞争的加剧和人才需求的日益复杂化&#xff0c;企业对于高效、精准的招聘需求越来越迫切。在这样的背景下&#xff0c;人力RPO(招聘流程外包)项目应运而生&#xff0c;其独特的优势为企业带来了全新的招聘体验和效果。 首先&#xff0c;人力RPO项目能够显著降低企业的招…

python-情报加密副本

【问题描述】某情报机构采用公用电话传递数据&#xff0c;数据是5位的整数&#xff0c;在传递过程中是加密的。加密规则如下&#xff1a;每位数字都加上8,然后用和除以7的余数代替该数字&#xff0c;再将第1位和第5位交换&#xff0c;第2位和第4位交换。请编写程序&#xff0c;…

MySQL数据处理增删改

数据处理增删改DML 由于约束&#xff0c;以下操作都有可能执行失败&#xff08;后面讲约束&#xff09; 插入数据 INSERT 基础添加&#xff1a;VALUES 值的顺序必须和表中字段顺序相同 INSERT INTO class VALUES(1,王小,10); 向指定字段添加&#xff1a; 值的顺序和指定…

【QGIS入门实战精品教程】10.7: 基于DEM的地形因子分析(坡度、坡向、粗糙度、山体阴影、耐用指数)

文章目录 一、加载dem二、山体阴影三、坡度四、坡向五、地形耐用指数六、地形位置指数七、地表粗糙度一、加载dem 二、山体阴影 方法一:符号系统 利用符号系统中的山体阴影,渲染出阴影效果。 方法二:山体阴影工具 该算法计算输入中的数字化地形模型的山体阴影。根据太阳的位…

C++第十九弹---string模拟实现(下)

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】 目录 1、修改操作 2、迭代器操作 3、字符串操作 4、非成员函数重载操作 总结 1、修改操作 1、string& operator (const char* s); //尾部插入…

科林Linux6_网络

#include<sys/socket.h> #include<arpa/inet.h> //大小端转换 #include<netdb.h> //DNS一、Socket套接字 为了开发网络应用&#xff0c;系统提供一套API函数接口&#xff0c;用于网络应用开发&#xff0c;这些接口称为套接字函数 struct sockaddr_in…

【STM32】计算定时器的溢出

TIM2、3、4、5、12、13、14在APB1上&#xff0c;最大计数频率84M。 TIM1、8、9、10、11在APB2上&#xff0c;最大计数频率168M。 time(arr1)/(prescale1)/Tclk 算出来的是秒 下图使用TIM14 84MHz 那么time33600*25000/8400000010S&#xff0c;10S进入一次中断 中断方式开…

【脚本篇】---spyglass lint脚本

目录结构 sg_lint.tcl &#xff08;顶层&#xff09; #1.source env #date set WORK_HOME . set REPORT_PATH ${WORK_HOME}/reports puts [clock format [clock second] -format "%Y-%m-%d %H:%M:%S"] #2.generate source filelist #3.set top module puts "##…