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

相关推荐
程序员的世界你不懂9 天前
Appium+python自动化(三十)yaml配置数据隔离
运维·appium·自动化
东窗西篱梦10 天前
LNMP一键自动化部署
运维·自动化
Deepoch10 天前
Deepoc大模型重构核工业智能基座:混合增强架构与安全增强决策技术
人工智能·科技·学习·自动化·创业创新
忘记安全带10 天前
AWS EC2使用SSM会话管理器连接
服务器·网络·自动化·云计算·aws
你的秋裤穿反了10 天前
网络/信号/电位跟踪
自动化
小猴崽10 天前
腾讯云事件总线:构建毫秒级响应的下一代事件驱动架构
架构·自动化·腾讯云
mit6.82410 天前
[project-based-learning] 开源贡献指南 | 自动化链接验证 | Issue模板规范
开源·自动化·issue
疯狂的维修10 天前
七层网络模型与电脑通信比喻
自动化
饺子大魔王的男人10 天前
Windows环境Browser-Use平台部署与AI自动化远程访问实现过程
人工智能·windows·自动化
云云32110 天前
亚矩云手机赋能Vinted矩阵运营:破解二手电商多账号与本地化困局
网络·人工智能·智能手机·矩阵·自动化