从测试角度看待CI/CD,敏捷开发

什么是敏捷开发?

是在高强度反馈的情况下,短周期,不断的迭代产品,满足用户需求,抢占更多的市场

敏捷开发是什么?

是一种产品快速迭代的情况下,降低出错的概率,具体会落实到公司的规章制度上,去确保快速响应,快速迭代

什么是CI/CD

是一种持续交付,持续部署并自动测试的自动化软件系统,是敏捷落地的具体产物,

我以我在前东家了解到的业务实践场景,简述下:

CI

CI是持续提交 ,具体体现在开发同学,可以在github不停的提交分支代码,Jenkins自动拉取最新的分支代码部署,测试同学 在ModHeader 中设置 X-Env-Branch: 分支名称(一个浏览器插件,用于修改HTTP请求头),后端就会自动将请求路由到对应分支环境的镜像实例,实现多分支并行测试的能力,且互不干扰。

这个是我目前见过最好的一个落地实践,在部署完毕之后,还可以自动执行核心测试套件(接口返回200),进行自动化测试,测试不通过,自动@提交者,提供接口测试报告,提交者(开发者)可以查看那些接口有问题,进行修改,提高效率

CD

是随时可以发布,但是具体到实施,都是有固定的时间节点,错过了,需要走紧急发布邮件通知负责人,这样做的好处是:在特定节点上线,有利于集成测试环境的回归,确保所有本次要上线的分支,都合到集成测试环境,所有的改动,都在集成测试环境中回归验证过;

CD发布的环境,可以具体划分为

分支测试环境:对应上述的CI开发提交代码到github,Jenkins自动拉去部署

集成测试环境:分支测试没有问题,便把代码合到master分支,Jenkins自动拉取并部署

stage环境:和线上共用同一个库,区别是没有流量的进入

生产环境:真实用户使用的环境

比较好的CD落地是,测试同学可以手动设置不同的tag进行发布,并关联jira上需求的状态,对需求的状态相互验证,如果当前环境有问题,测试同学可以选择测试不通过,或者发布中止,进入回滚流程,选最近一次生产发布过的tag,进行快速回滚

相关推荐
IT成长日记8 小时前
【自动化运维神器Ansible】Ansible常用模块之hostname模块详解
运维·自动化·ansible·hostname·常用模块
慌ZHANG11 小时前
Python在自动化与运维领域的核心角色:工具化、平台化与智能化
运维·自动化
IT成长日记13 小时前
【自动化运维神器Ansible】Ansible常用模块之cron模块详解
运维·自动化·ansible·cron·cron模块·常用模块
宇钶宇夕14 小时前
图像处理第二篇:初级篇 —— 选择镜头的基础知识及对图像处理的影响
运维·数码相机·程序人生·自动化
zzywxc78715 小时前
随着人工智能技术的飞速发展,大语言模型(Large Language Models, LLMs)已经成为当前AI领域最引人注目的技术突破。
人工智能·深度学习·算法·低代码·机器学习·自动化·排序算法
tzc_fly16 小时前
OriGene:一种可自进化的虚拟疾病生物学家,实现治疗靶点发现自动化
自动化
码界奇点18 小时前
Python深度挖掘:openpyxl与pandas高效数据处理实战指南
开发语言·数据库·python·自动化·pandas·python3.11
狙个栗子21 小时前
Centos 7.9安装部署cobbler-自动化部署服务器完整教程
linux·运维·服务器·centos·自动化
qq_526099131 天前
如何选择工业电脑?
嵌入式硬件·自动化·电脑
厦门辰迈智慧科技有限公司1 天前
山洪灾害监测预警系统主要涵盖
物联网·安全·自动化·监测