报名参加CloudWeGo黑客松,奖金直推双丰收! 了解详情
写点什么

Intel 图形库 Mesa 的持续集成

  • 2018-10-23
  • 本文字数:1288 字

    阅读完需:约 4 分钟

Mesa CI 是 Intel 的一个持续集成系统,用于运行 Mesa 图形库的构建和一致性测试套件。它运行在 200 多个系统中,每天运行数千万次测试。

Mesa 项目 OpenGL Vulkan 等图形标准的 OSS 实现。Intel 和 AMD 将其作为图形驱动程序的基础。它充当图形 API 和硬件驱动程序之间的转换层。Mesa 开发人员使用一个名为 Mesa CI 的框架进行持续集成,特别是在他们的测试套件中。Mesa 需要支持各种供应商图形驱动程序以及不同版本的API 标准。这就需要一个全面的测试套件,它需要与每个提交一起运行,以确保功能和性能。 Piglit dEQP VK-GL-CTS Crucibleare 是一些在 Mesa CI 上运行的测试套件。在最近的 X Org 开发者大会上, Mark Janes 和 Clayton Craft 分享了一些关于 Mesa CI 的细节

Mesa CI 包括一组配置文件和一个可以在 Jenkins 上运行的作业调度器及作业实现。它主要是用 Python 编写的,其原则是“把最小化 Jenkins 中的配置作为 Mesa CI 最重要的设计考虑”。根据文档,Mesa CI 理论上可以运行在任何 CI 基础设施之上,而不仅仅是 Jenkins。目前,它被用于开发测试、发布验证、Intel 驱动程序模拟器的投产前(硬件)测试、性能测试和一致性测试套件的验证。典型的开发测试周转时间是 30 分钟,即使向主分支的一次提交触发了数百万个测试。自定义数据库提供对测试历史的即时访问,系统还为公共基准测试生成性能趋势线。

Mesa CI 创建于 2014 年,但人们认识到 Mesa 自动化测试的好处比这要早。从那时起,发布过程就正规化了,并且一直在发展(PDF)。在之前的一篇文章(PDF)中,Janes 分享了为 Mesa 建立持续集成的理念。将测试作为一等工件,其中包括对测试可靠性和运行时间进行优先级排序。

 

图片来源: https://xdc2018.x.org/slides/Mesa_Continuous_Integration_at_Intel.pdf

每个平台都有一个单独的 CI 配置文件,一些测试套件需要一个单独的配置用于 32 位构建。由提交引起的测试失败会触发一系列步骤,其中一些是手动的。失败的测试被添加到 CI 配置的跳过列表中。不过,这并不是由开发人员完成的,也不知道这是否是因为测试框架没有注解测试用例而导致它们被忽略了。 JUnit NUnit 等常见测试套件都提供了这个特性。跳过列表中的测试仍然运行,但失败时不会报告。这可以避免在 Bug 修复之前损失测试覆盖率。

当在包含未修复的 Bug 的分支上开发特性时,由于 CI 配置会跟踪主分支,所以会导致构建失败。对于每个测试状态更改,Mesa CI 都会记录导致这种情况的提交。在这种情况下,由于 Bug 修复会被推送到主分支,所以当测试开始通过时,它会记录提交 id。Mesa CI 会检查特性分支是否已经修复。如果没有,它就认为测试状态是错误的,即预计测试会失败。最终,旧的稳定分支会在 Mesa CI 上运行,因为它们具有与该分支上的源代码一致的测试状态 CI 配置。但是,对于旧的分支,测试仍然会失败,测试机器上有硬件更新,而这些更新会影响所有分支。

Mesa CI 的未来计划包括在构建执行期间显示日志和组件的状态,并允许开发人员对构建进行 A/B 比较。他们还可以使用公共仪表板

查看英文原文: Continuous Integration at Intel for the Mesa Graphics Library

2018-10-23 14:341715
用户头像

发布了 1008 篇内容, 共 407.9 次阅读, 收获喜欢 346 次。

关注

评论 1 条评论

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

一个创业者的途中思考

非著名程序员

创业 读书笔记 程序员 重新理解创业 思考

2020了,各家小程序发展的怎么样?

崔红保

小程序 uni-app

走出舒适区最好办法别走了,扩大它

乐少

Flink初体验

数据社

大数据 flink 流计算

写一个开源的 macOS 程序可以赚多少钱?

子骅 luin

node.js redis GitHub 开源 赚钱

为什么你的创业公司应该运行在Kubernetes上

云原生

云原生 k8s

uni-app黑魔法:小程序自定义组件运行到H5平台

崔红保

小程序 uni-app

【Vue3.0 Beta】尝鲜

德育处主任

CSS Java html5 Vue 大前端

【gRPC】Python调用Java的gRPC服务

遇见

Java Python gRPC

电子书:《Linux Perf Master》

RiboseYim

Linux 性能优化

近两年影响我的两个重要原则

Selina

从流程、认知上做稳定的系统演进

Skysper

系统设计 质量管理

寻找伴侣最重要的是什么?

二爷

对话 CTO〡和 PingCAP CTO 黄东旭聊开源数据库新蓝海

ONES 王颖奇

数据库 分布式 开发者

浅谈汽车行业嵌入式软件发布的流程有多复杂

WB

程序员 软件

初入响应式编程(上)

CD826

spring 微服务 Spring Cloud 响应式编程 reactor

翻译: Effective Go (1)

申屠鹏会

翻译 Go 语言

业务系统开发程序员常用linux知识

程序员劝退师

Linux

用声音在一起,听荔枝CTO丁宁聊UGC声音互动平台的技术世界

ONES 王颖奇

内容 企业架构 互联网

测试

Chonge

人们喜欢彼此制造困难让大家难过

Fenng

WebSphere Application Server运维实践 --从入门到监控

rafe

Java WAS perfservlet visualVM JMX

分享多年积累的 macOS 效率工具

张晓辉

macos

业务代码必须要做的事情

程序员劝退师

芋道 Spring Cloud Alibaba 介绍

艿艿

阿里巴巴 分布式 微服务 Spring Cloud Spring Boot

一文讲清楚 MySQL 事务隔离级别和实现原理,开发人员必备知识点

古时的风筝

MySQL 数据库 事务隔离级别 mysql事务 数据库事务

Linux 性能诊断:负载评估入门

RiboseYim

Linux 性能优化

【数据结构】双向链表插入操作的时间复杂度分析

遇见

数据结构 算法 时间复杂度

此为开卷

X.F

毕竟,一生很短,少有圆满

霍太稳@极客邦科技

创业 身心健康 个人成长

OKR实践中的痛点(1):老板的KR我的O,怎么办?

大叔杨

OKR Scrum 敏捷

Intel图形库Mesa的持续集成_DevOps & 平台工程_Hrishikesh Barua_InfoQ精选文章