从测试角度看待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,进行快速回滚

相关推荐
黄毛火烧雪下4 小时前
【Ruby 】脚本和自动化语言 常用的内容
运维·自动化·ruby
发光小北8 小时前
4路can转4g功能介绍
自动化
神秘人X70710 小时前
Jenkins 持续集成与部署指南
运维·ci/cd·jenkins
广商 小轩11 小时前
自动化实战 Playwright破解滑块验证码的完整实战指南
运维·自动化
你想考研啊11 小时前
自动化部署脚本
linux·服务器·自动化
富唯智能13 小时前
开箱即用,15分钟极速部署:富唯智能精密仪器搬运机器人重塑工业自动化
自动化·工业机器人·复合机器人
博图光电15 小时前
博图机械臂:以智能精度,重塑多行业自动化新生态
运维·自动化
小安运维日记15 小时前
RHCA - DO374 | Day01:使用红帽Ansible自动化平台开发剧本
运维·服务器·云原生·自动化·云计算·ansible
Source.Liu19 小时前
【CMakeLists.txt】 Qt 自动化构建配置详解
qt·自动化·librecad
da_vinci_x1 天前
Substance Designer的通道合并(Channel Packing)自动化工作流
3d·自动化·贴图·技术美术·游戏策划·游戏美术·substance designer