0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何快速向RT-Thread提一个PR:以CI为例

RTThread物联网操作系统 ? 来源:未知 ? 2023-06-08 12:00 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

PR方法(Git操作) 01Fork

首先将官方仓库 fork 到我们自己的账号下,点击一下 fork 按钮,按照提示操作即可。

edfcf5f6-05b0-11ee-8a94-dac502259ad0.jpg

回到自己的仓库中,将仓库clone到本地。

git clone https://github.com/yourusername/rt-thread.git

如果是较早之前fork的仓库,可以先和上游的仓库同步一下:

1. 先在仓库页面Update branch

2. 在本地仓库git fetch & git merge

ee1c83a8-05b0-11ee-8a94-dac502259ad0.jpg

02Commit & Push

一般来说,一个issue或者PR对应一个新的分支,所以需要创建一个分支

git checkout -b

更改相应的代码,然后提交代码

git add .

git commit -m "message"

git push origin test-branch

03Pull Request

在仓库首页按操作提起一个PR

ee45b5fc-05b0-11ee-8a94-dac502259ad0.jpg

ee6bd912-05b0-11ee-8a94-dac502259ad0.jpg

04Rollback

如果提交有误或者需要修改,可以进行回滚,然后重新push

git reset HEAD^(回退到上一个版本)

05CI

查看CI结果,根据结果对代码进行修改

ee82fd4a-05b0-11ee-8a94-dac502259ad0.jpg

功能的修改和增加:以CI(issue 7458)为例 01理解issue
[CI][cppcheck] 需要根据ignore_format 过滤掉不需要扫描的文件夹 · Issue #7458 · RT-Thread/rt-thread (github.com)https://github.com/RT-Thread/rt-thread/issues/7458

对问题本身的理解十分重要,issue里可能会有其他人对这个需求的或者问题详细讨论和思路的提供,所以仔细查看issue非常重要。

根据这个issue的描述,主要是添加忽略一些文件和目录进行静态检查的功能。

具体需求是:

1. 添加对.ignore_format.yml配置文件检查

2. 如果新更新的文件在dir_path属性的目录下或者在file_path属性中

3. 对这个文件就不启用静态检查

并且这个issue中也提供了一种思路:

1. 遍历一下ignore_format.yml文件找到所有需要忽略的文件夹,搞个大数组,然后过滤

2. 参考一下

https://github.com/RT-Thread/rt-thread/blob/master/tools/file_check.py

02代码定位

代码定位是对功能的修改和增加的第一步,对于Bug fix来说,代码定位可能比较困难,但是对于功能的修改和增加来说,是比较简单的。

首先可以看出来这个issue的工作主要是CI这块,那么我们需要先了解github的CI工具:Github Action。最好的文档肯定就是GitHub Actions文档 - GitHub 文档。我们不需要全部了解之后再动手,只要了解一些基本概念之后就可以先动手。

根据文档的描述,我们可以了解到github workflow使用yml来描述,并且放在了.github/workflow目录下,所以第一步可以定位到.github/workflow下的static_code_analysis.yml。

在这个目录我们可以看到static_code_analysis.yml是直接在yaml中用shell编写工作流程,而还有其它文件如file_check.yml使用调用其它Python脚本来完成工作流程。所以基本可以确定我们需要修改或者增加的地方就在.github/workflow和tools/ci下。

03代码阅读

在这里,我们参考file_check.yml的实现。所以需要先理解file_check.yml的整体实现。

file_check.yml主要先使用shell按照了Pyhon脚本中必须使用的库然后直接调用Python脚本,我们直接跳入这个被调用的脚本查看。

代码阅读个人比较喜欢也觉得比较快速的方式是:先了解代码的某一部分(需要控制精度)的大致结构和功能,不关注其具体实现,之后再深入理解具体实现。在这个过程中有需要去猜测别人是如何写的代码,并且在一步步阅读代码的过程当中验证和纠正自己的想法。

我们来看file_check.py。

我们可以先忽略使用的click命令行库,或者也可以从命名和使用方式猜测出它们的功能。

因为这个文件比较简单,所以我们可以猜测函数的入口就是check()。主函数里的逻辑是十分简单的,可以看到通过checkout.get_new_file()获得了一个文件列表,然后传递给了FormatCheckLicenseCheck,它们又分别调用了自身的check函数,最后根据它们返回值判断是否检查出错误。

所以我们可以猜测checkout.get_new_file()获得的文件列表是需要检查的文件列表,而FormatCheckLicenseCheck执行各自的检查逻辑,我们可以不用关注。

get_new_file的就需要深入代码看具体实现,具体的逻辑也比较简单。

1. 通过git命令获得新增和修改的文件列表

2. 然后遍历这个文件列表

3. 遍历这个文件列表中的文件路径的每一层目录,看是否存在.ignore_format.yml文件

4. 然后根据.ignore_format.yml的属性来判断当前文件是否需要被检查

所以我们实现的重点就是对需要检查的代码进行静态代码检查。

04功能增加

首先,因为获得需要检查的文件列表这个功能是可能会被多次利用,可以先提取出来作为一个独立功能,并且可以做一些优化(在获得新增和修改的文件列表时的写法可以优化)。

其次,最重要的就是利用cppcheck完成静态代码检查的功能:

1. 从文件列表中再一次过滤出C/C++相关文件

2. 然后使用cppcheck逐个检查文件列表,并且捕获标准错误流

 1classCPPCheck:
 2def__init__(self,file_list):
 3self.file_list=file_list
 4defcheck(self):
 5file_list_filtered=[fileforfileinself.file_listiffile.endswith(('.c','.cpp','.cc','.cxx'))]
 6logging.info("Starttostaticcodeanalysis.")
 7check_result=True
 8forfileinfile_list_filtered:
 9result=subprocess.run(['cppcheck','--enable=warning','performance','portability','--inline-suppr','--error-exitcode=1','--force',file],stdout=subprocess.PIPE,stderr=subprocess.PIPE)
10logging.info(result.stdout.decode())
11logging.info(result.stderr.decode())
12ifresult.stderr:
13check_result=False
14returncheck_result
15@click.group()
16@click.pass_context
17defcli(ctx):
18pass
19@cli.command()
20defcheck():
21"""
22staticcodeanalysis(cppcheck).
23"""
24format_ignore.init_logger()
25#getmodifiedfileslist
26checkout=format_ignore.CheckOut()
27file_list=checkout.get_new_file()
28iffile_listisNone:
29logging.error("checkoutfilesfail")
30sys.exit(1)
31#usecppcheck
32cpp_check=CPPCheck(file_list)
33cpp_check_result=cpp_check.check()
34ifnotcpp_check_result:
35logging.error("staticcodeanalysis(cppcheck)fail.")
36sys.exit(1)
37logging.info("checksuccess.")
38sys.exit(0)
39if__name__=='__main__':
40cli()

05功能测试

完成代码的修改之后最重要的就是通过测试,最基本也是最简单的测试就是功能测试。所以我们可以给这次的修改安排三个测试:

修改cppcheck会出现错误的文件:

case 1:不将文件加入.ignore_format.yml,CI报错

case 2:将文件加入.ignore_format.yml的file_path,CI不报错

case 3:将文件加入.ignore_format.yml的dir_path,CI不报错

PR心得

这次PR的提交有以下两个小心得。

01仔细沟通

第一点,也是最重要的一点就是和主动社区的前辈进行交流,对issue的问题和需求进行讨论。在这个PR被merge之前我就完成了其余两版,但是因为缺乏沟通,不是很适合当前的RT-Thread。

02Github Action 本地测试

在修改CI部分时,每次都需要推送到远端才能执行相关的action,这样比较麻烦。可以使用nektos/act: Run your GitHub Actions locally 工具在本地跑Github action。

原文:https://club.rt-thread.org/ask/article/0b4c0d3b999554d0.html

———————End———————

RT-Thread线下入门培训

6月 - 深圳

1.免费2.动手实验+理论3.主办方免费提供开发板4.自行携带电脑,及插线板用于笔记本电脑充电5.参与者需要有C语言单片机ARM Cortex-M核)基础,请提前安装好RT-Thread Studio 开发环境

eea228c8-05b0-11ee-8a94-dac502259ad0.png

立即扫码报名

报名链接

https://jinshuju.net/f/UYxS2k

巡回城市:青岛、北京、西安、成都、武汉、郑州、杭州、深圳、上海、南京

你可以添加微信:rtthread2020 为好友,注明:公司+姓名,拉进RT-Thread官方微信交流群!

点击阅读原文,进入RT-Thread 官网


原文标题:如何快速向RT-Thread提一个PR:以CI为例

文章出处:【微信公众号:RTThread物联网操作系统】欢迎添加关注!文章转载请注明出处。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • RT-Thread
    +关注

    关注

    32

    文章

    1427

    浏览量

    42169

原文标题:如何快速向RT-Thread提一个PR:以CI为例

文章出处:【微信号:RTThread,微信公众号:RTThread物联网操作系统】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    RT-Thread 遇上 Rust:安全内核 RusT-Thread 的诞生

    大家好,我们是中国科学技术大学操作系统原理与设计(H)课oooooS小组。这个项目是我们的课程大作业:参考RT-Thread架构,使用Rust搭建原生的嵌入式操作系统内核。初识Rust是因为xk
    的头像 发表于 08-02 11:03 ?554次阅读
    <b class='flag-5'>RT-Thread</b> 遇上 Rust:安全内核 RusT-<b class='flag-5'>Thread</b> 的诞生

    RT-Thread荣获2025优秀开源项目 | 新闻速递

    6月底,RT-Thread睿赛德受邀参与由上海开源信息技术协会主办的2025上海开源创新精英荟。上海市商委副主任张杰出席会议并致辞。RT-Thread嵌入式操作系统项目凭借其卓越的技术创新与开源生态
    的头像 发表于 07-04 09:04 ?1843次阅读
    <b class='flag-5'>RT-Thread</b>荣获2025优秀开源项目 | 新闻速递

    揭秘RT-Thread上的AUTOSAR CP系统

    标准,同时保留RT-Thread的POSIX支持与可裁剪性,实现了通信隔离、诊断模块集成等关键技术突破,车载系统提供高安全、可扩展的解决方案。车载电子系统与传统
    的头像 发表于 06-23 20:22 ?2380次阅读
    揭秘<b class='flag-5'>RT-Thread</b>上的AUTOSAR CP系统

    人形机器人敏捷开发新路径:RT-Thread软件底座破解复杂系统难题 | 新闻速递

    5月29日,2025机器人开发者大会在上海张江科学城拉开帷幕,RT-Thread睿赛德受邀参会,与宇树、智元、傅利叶等企业共话机器人行业解决方案。在人形机器人本体专题论坛上,RT-Thread睿赛德
    的头像 发表于 06-04 14:03 ?688次阅读
    人形机器人敏捷开发新路径:<b class='flag-5'>RT-Thread</b><b class='flag-5'>以</b>软件底座破解复杂系统难题 | 新闻速递

    RT-Thread审核团招募: 深度参与开源RTOS社区治理与演进

    全球开发者招募:RT-Thread审核团(ReviewTeam)正式开放申请!在开源的世界里,代码审查(CodeReview)是保证软件质量、促进技术交流的关键环节。RT-Thread作为全球领先
    的头像 发表于 05-21 18:02 ?722次阅读
    <b class='flag-5'>RT-Thread</b>审核团招募: 深度参与开源RTOS社区治理与演进

    如何将RT-Thread移植到NXP MCUXPressoIDE上

    RT-Thread默认支持的IDE只有IAR 和 Keil, 那如何将RT-Thread移植到NXP MCUXPressoIDE上呢?本文内容比较简单但稍有琐碎,希望对有需要的小伙伴有所帮助。
    的头像 发表于 02-13 10:37 ?1991次阅读
    如何将<b class='flag-5'>RT-Thread</b>移植到NXP MCUXPressoIDE上

    RT-Thread应用开发寒假师资培训——西安站

    随着物联网和智能系统的快速发展,嵌入式成为当前最热门最有发展前途的IT应用领域之步提升全国大学生在嵌入式芯片及系统设计领域的创新能力,特别是针对物联网应用开发中
    的头像 发表于 12-11 01:06 ?739次阅读
    <b class='flag-5'>RT-Thread</b>应用开发寒假师资培训——西安站

    RT-Thread操作系统应用开发寒假师资培训

    随着物联网和智能系统的快速发展,嵌入式成为当前最热门最有发展前途的IT应用领域之步提升全国大学生在嵌入式芯片及系统设计领域的创新能力,特别是针对物联网应用开发中
    的头像 发表于 12-06 01:06 ?601次阅读
    <b class='flag-5'>RT-Thread</b>操作系统应用开发寒假师资培训

    RT-Thread上CAN实践

    开箱测试RT-Thread官方已完成了对英飞凌XMC7200EVK的移植,通过shell可以看到做好了uart3的console。本文将介绍如何进行RT-ThreadCan移植。接下来我们要完成CAN_FD的驱动移植,并正常启动RT-T
    的头像 发表于 11-13 01:03 ?2220次阅读
    <b class='flag-5'>RT-Thread</b>上CAN实践

    混合部署 | 在迅RK3568上同时部署RT-Thread和Linux系统

    RT-Thread介绍 RT-Thread高安全性、实时性的操作系统,广泛应用于任务关键领域,例如电力、轨道交通、车载系统、工业控制和新能源等。它的加入让 RK3568 能够在
    发表于 11-01 10:31

    开源共生 商业共赢 | RT-Thread 2024开发者大会报名启动!

    亲爱的RT-Thread开发者我们很高兴地宣布,一年一度的RDC(RT-ThreadDeveloperConference,RT-Thread开发者大会)正式启动报名!2024
    的头像 发表于 10-29 08:06 ?1004次阅读
    开源共生 商业共赢 | <b class='flag-5'>RT-Thread</b> 2024开发者大会报名启动!

    混合部署 | 在迅RK3568上同时部署RT-Thread和Linux系统

    RT-Thread介绍 RT-Thread高安全性、实时性的操作系统,广泛应用于任务关键领域,例如电力、轨道交通、车载系统、工业控制和新能源等。它的加入让 RK3568 能够在
    发表于 09-18 10:54

    【成都】9月21日RT-Thread巡回线下培训-OpenMV机器视觉

    亲爱的RT-Thread社区成员们:RT-Thread24年全球巡回培训将覆盖超10座城市及国家,开发者提供深入学习
    的头像 发表于 09-13 08:09 ?1811次阅读
    【成都】9月21日<b class='flag-5'>RT-Thread</b>巡回线下培训-OpenMV机器视觉

    【大连】9月7日RT-Thread巡回线下培训-OpenMV机器视觉

    亲爱的RT-Thread社区成员们:2024年RT-Thread全球开发者线下培训拉开帷幕啦!24年全球巡回培训将覆盖超10座城市及国家,开发者提供
    的头像 发表于 09-01 08:02 ?4005次阅读
    【大连】9月7日<b class='flag-5'>RT-Thread</b>巡回线下培训-OpenMV机器视觉

    2024 RT-Thread全球巡回 线下培训火热来袭!

    亲爱的RT-Thread社区成员们:我们非常高兴地宣布,2024年RT-Thread全球开发者线下培训即将拉开帷幕!24年全球巡回培训将覆盖超10座城市及国家,开发者提供
    的头像 发表于 08-07 08:35 ?3008次阅读
    2024 <b class='flag-5'>RT-Thread</b>全球巡回 线下培训火热来袭!