写点什么

持续集成的关键:产品反馈驱动实践

  • 2023-07-20
    北京
  • 本文字数:1454 字

    阅读完需:约 5 分钟

持续集成的关键:产品反馈驱动实践

缩短持续集成(CI)系统的反馈时间并优化测试方法和类,可为开发团队带来更为有效的反馈。据 Tobias Geyer 所说,CI 系统是开发过程中的重要一部分,且应被重视起来。


Tobias Geyer 在2023年罗马尼亚测试大会上以测试人员的身份谈到了集成系统的改进问题。

在 Geyer 刚入职时,公司的持续集成系统是一台堆在桌子底下的老旧开发电脑,没人负责也没人有时间做维护。他说,这台电脑的速度太慢导致反馈周期非常长,开发人员完全忽视了 CI 系统的反馈。


Geyer 称,优化反馈时间的一个捷径是在工作时间跳过不必要的构建步骤,并将构建限制为每晚一次。

一个更难处理的瓶颈问题则是磁盘的 I/O。构建读取和写入的数据量太大,磁盘没办法跟得上。Geyer 说他最后找到 IT 部门的人把 CI 系统从开发电脑挪到了数据中心的虚拟机上,解决了磁盘的 I/O 问题,并将系统扩展到了两台机器上,使其能够并行运行更多的构建。


他们将测试按执行快慢分为几类,在快反馈 CI 构建中只运行测试的一个子集,速度慢的测试则被放到了执行频率更低的专用构建中。Geyer 解释道,这么做让他们得到的反馈依旧完整,且大部分反馈要比之前快上许多。


Geyer 描述了他们是如何优化测试的方法和类:


在找出运行缓慢的测试后,我们将其当作技术债务来处理。为改进测试,我们给开发者们提出了“测试债务预算”,开发者们对这些问题的处理方式各不相同:

  1. 将测试数据精简,只保留有关数据,从而缩短测试的设置时间

  2. 引入模拟测试,不再需要预加载任何测试数据

  3. 让产品代码更具可测试性,使原本需要集成测试的部分可被单元测试替代完成


Geyer 总结,不一定要深刻理解技术领域才能带来影响:


我可以利用我测量、实验和协作的测试技巧让事情变得更好,即使这也意味着别人必须去完成实际的实施工作。


InfoQ 就 CI 系统的改进话题采访了 Tobias Geyer。


InfoQ:可以给出一个跳过构建步骤的例子吗?


Tobias Geyer:效果最明显的例子是我们的产品混淆。每个产品构建在交付给客户之前都会被混淆,而这些被混淆的产品很明显是需要经过测试的。但产品混淆过程至少需要三十分钟,因此我们在白天跳过这一步骤,并在晚上将产品混淆并进行测试。


InfoQ:你们对构建过程和平台有什么重要的变动吗?


Geyer:我们将我们的构建系统从 Ant 和 Windows 的批处理迁移到了 Gradle。主要工作是由我们的团队中的开发者们完成,我负责处理所有与测试执行相关的工作。


引入测试 CI 系统这一改变虽然明显但仍然重要,我们得以在不中断正常开发流程的前提下,准备并测试 CI 系统中的变更(如插件更新、新增构建节点等等)。


InfoQ:你们是如何鼓励在不同团队间的持续集成知识共享?


Geyer:我是在公司的其他部门中寻找有过在 CI 系统上工作经历且具备类似技术栈的人。我们定期开会讨论(CI 系统)最近更新和大家所面临的问题。很多时候某个团队对问题的解决方案是可以被复用的。


能看到其他人的进展和他们的结果是很好的。有时候一些团队想要引入的变更会在他们的团队内部遇到阻力,“其他团队有过这方面的正向经验”,这句话有助于说服他人。


InfoQ:对于不满自己 CI 解决方案的团队,你有什么建议吗?


Geyer:像是对待其他软件开发项目一样看待(CI 系统)。把困扰自己的问题列出来,用对待 bug 的方式处理它们。也就是说,对这些问题进行优先级排序、分析,并合作修复。我想强调“合作”这点,和 IT 部门的探讨对我们修复部分问题而言至关重要。


原文链接

Treat Your CI System as a Product for Faster and Better Feedback


相关阅读:

Terraform引入新的CI/CD工具,增加对Azure Linux的支持

中国企业研发高效能白皮书-CI/CD篇

2023-07-20 08:002174

评论

发布
暂无评论
发现更多内容

软件测试 | 人工智能的广泛应用领域有哪些?

测吧(北京)科技有限公司

测试

langchain中的LLM模型使用介绍

程序那些事

人工智能 AIGC langchain

文心一言 VS 讯飞星火 VS chatgpt (83)-- 算法导论8.1 4题

福大大架构师每日一题

福大大架构师每日一题

创新医疗:人工智能引领健康未来

测吧(北京)科技有限公司

测试

软件测试 | 人工智能的背景与发展历程

测吧(北京)科技有限公司

测试

小灯塔系列-中小企业数字化转型系列研究——表单管理测评报告

向量智库

印刷行业MES系统解决方案

万界星空科技

MES系统 印刷

一文让你简单知道银行建设堡垒机的意义

行云管家

网络安全 银行 堡垒机

为什么 Higress 是 Knative 入口网关的最佳实践?

阿里巴巴云原生

阿里云 云原生 Higress

NFT沙盒游戏开发搭建

V\TG【ch3nguang】

NFT数字藏品系统

【收藏】制作艺术二维码,用 Stable Diffusion 就行!

阿里巴巴云原生

阿里云 云原生 Stable Diffusion Stable

OpenHarmony设备截屏的5种方式

OpenHarmony开发者

OpenHarmony

来文心中国行!专家面对面解读大模型产业实践及AI场景突围

飞桨PaddlePaddle

人工智能 百度飞桨 百度AI 文心一言 文心大模型

Databend 开源周报第 108 期

Databend

软件测试 | 人工智能的引领,医疗的未来

测吧(北京)科技有限公司

测试

性能专家深度解读:常见的压测模型

优测云服务平台

性能测试 压力测试 云平台 性能瓶颈 云平台技术

延时摄影视频制作软件LRTimelapse mac中文激活版v6.5.0

mac

苹果mac Windows软件下载 lrTimelapse 延时摄影视频制作软件

区块链交易所系统开发

V\TG【ch3nguang】

数字货币交易所系统搭建

大数据平台数据安全解决方案就看行云管家!

行云管家

大数据 数据安全 大数据平台

直播预约丨《实时湖仓实践五讲》第一讲:企业为什么需要实时湖仓?

袋鼠云数栈

直播 实时湖仓

Karmada 结合 coreDNS 插件实现跨集群统一域名访问

华为云开发者联盟

云原生 后端 华为云 华为云开发者联盟 企业号 8 月 PK 榜

JavaScript原型链污染

互联网工科生

JavaScript 前端 js

通过AOP拦截Spring Boot日志并将其存入数据库

华为云开发者联盟

数据库 开发 华为云 华为云开发者联盟 企业号 8 月 PK 榜

简单好用的防火墙 Radio Silence最新激活码

mac大玩家j

Mac软件 防火墙工具 防火墙软件 阻止网络连接软件

基于飞桨图学习框架的空间异配性感知图神经网络

飞桨PaddlePaddle

人工智能 百度飞桨

软件测试/测试开发丨Selenium 高级定位 CSS

测试人

CSS Python 程序员 软件测试 selenium

一文讲透 JavaScript 应用的演进历程

高端章鱼哥

JavaScript 软件开发 #web

OpenHarmony组件复用示例

OpenHarmony开发者

OpenHarmony

华为云新生代开发者招募

华为云PaaS服务小智

开发者 有奖活动 华为云

持续集成的关键:产品反馈驱动实践_研发效能_Ben Linders_InfoQ精选文章