0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何快速向RT-Thread提一個(gè)PR:以CI為例

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來源:未知 ? 2023-06-08 12:00 ? 次閱讀
PR方法(Git操作) 01Fork

首先將官方倉庫 fork 到我們自己的賬號(hào)下,點(diǎn)擊一下 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

一般來說,一個(gè)issue或者PR對(duì)應(yīng)一個(gè)新的分支,所以需要?jiǎng)?chuàng)建一個(gè)分支

git checkout -b

更改相應(yīng)的代碼,然后提交代碼

git add .

git commit -m "message"

git push origin test-branch

03Pull Request

在倉庫首頁按操作提起一個(gè)PR

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

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

04Rollback

如果提交有誤或者需要修改,可以進(jìn)行回滾,然后重新push

git reset HEAD^(回退到上一個(gè)版本)

05CI

查看CI結(jié)果,根據(jù)結(jié)果對(duì)代碼進(jìn)行修改

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

功能的修改和增加:以CI(issue 7458)為例 01理解issue
[CI][cppcheck] 需要根據(jù)ignore_format 過濾掉不需要掃描的文件夾 · Issue #7458 · RT-Thread/rt-thread (github.com)https://github.com/RT-Thread/rt-thread/issues/7458

對(duì)問題本身的理解十分重要,issue里可能會(huì)有其他人對(duì)這個(gè)需求的或者問題詳細(xì)討論和思路的提供,所以仔細(xì)查看issue非常重要。

根據(jù)這個(gè)issue的描述,主要是添加忽略一些文件和目錄進(jìn)行靜態(tài)檢查的功能。

具體需求是:

1. 添加對(duì).ignore_format.yml配置文件檢查

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

3. 對(duì)這個(gè)文件就不啟用靜態(tài)檢查

并且這個(gè)issue中也提供了一種思路:

1. 遍歷一下ignore_format.yml文件找到所有需要忽略的文件夾,搞個(gè)大數(shù)組,然后過濾

2. 參考一下

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

02代碼定位

代碼定位是對(duì)功能的修改和增加的第一步,對(duì)于Bug fix來說,代碼定位可能比較困難,但是對(duì)于功能的修改和增加來說,是比較簡單的。

首先可以看出來這個(gè)issue的工作主要是CI這塊,那么我們需要先了解github的CI工具:Github Action。最好的文檔肯定就是GitHub Actions文檔 - GitHub 文檔。我們不需要全部了解之后再動(dòng)手,只要了解一些基本概念之后就可以先動(dòng)手。

根據(jù)文檔的描述,我們可以了解到github workflow使用yml來描述,并且放在了.github/workflow目錄下,所以第一步可以定位到.github/workflow下的static_code_analysis.yml。

在這個(gè)目錄我們可以看到static_code_analysis.yml是直接在yaml中用shell編寫工作流程,而還有其它文件如file_check.yml使用調(diào)用其它Python腳本來完成工作流程。所以基本可以確定我們需要修改或者增加的地方就在.github/workflow和tools/ci下。

03代碼閱讀

在這里,我們參考file_check.yml的實(shí)現(xiàn)。所以需要先理解file_check.yml的整體實(shí)現(xiàn)。

file_check.yml主要先使用shell按照了Pyhon腳本中必須使用的庫然后直接調(diào)用Python腳本,我們直接跳入這個(gè)被調(diào)用的腳本查看。

代碼閱讀個(gè)人比較喜歡也覺得比較快速的方式是:先了解代碼的某一部分(需要控制精度)的大致結(jié)構(gòu)和功能,不關(guān)注其具體實(shí)現(xiàn),之后再深入理解具體實(shí)現(xiàn)。在這個(gè)過程中有需要去猜測別人是如何寫的代碼,并且在一步步閱讀代碼的過程當(dāng)中驗(yàn)證和糾正自己的想法。

我們來看file_check.py。

我們可以先忽略使用的click命令行庫,或者也可以從命名和使用方式猜測出它們的功能。

因?yàn)檫@個(gè)文件比較簡單,所以我們可以猜測函數(shù)的入口就是check()。主函數(shù)里的邏輯是十分簡單的,可以看到通過checkout.get_new_file()獲得了一個(gè)文件列表,然后傳遞給了FormatCheckLicenseCheck,它們又分別調(diào)用了自身的check函數(shù),最后根據(jù)它們返回值判斷是否檢查出錯(cuò)誤。

所以我們可以猜測checkout.get_new_file()獲得的文件列表是需要檢查的文件列表,而FormatCheckLicenseCheck執(zhí)行各自的檢查邏輯,我們可以不用關(guān)注。

get_new_file的就需要深入代碼看具體實(shí)現(xiàn),具體的邏輯也比較簡單。

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

2. 然后遍歷這個(gè)文件列表

3. 遍歷這個(gè)文件列表中的文件路徑的每一層目錄,看是否存在.ignore_format.yml文件

4. 然后根據(jù).ignore_format.yml的屬性來判斷當(dāng)前文件是否需要被檢查

所以我們實(shí)現(xiàn)的重點(diǎn)就是對(duì)需要檢查的代碼進(jìn)行靜態(tài)代碼檢查。

04功能增加

首先,因?yàn)楂@得需要檢查的文件列表這個(gè)功能是可能會(huì)被多次利用,可以先提取出來作為一個(gè)獨(dú)立功能,并且可以做一些優(yōu)化(在獲得新增和修改的文件列表時(shí)的寫法可以優(yōu)化)。

其次,最重要的就是利用cppcheck完成靜態(tài)代碼檢查的功能:

1. 從文件列表中再一次過濾出C/C++相關(guān)文件

2. 然后使用cppcheck逐個(gè)檢查文件列表,并且捕獲標(biāo)準(zhǔn)錯(cuò)誤流

 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功能測試

完成代碼的修改之后最重要的就是通過測試,最基本也是最簡單的測試就是功能測試。所以我們可以給這次的修改安排三個(gè)測試:

修改cppcheck會(huì)出現(xiàn)錯(cuò)誤的文件:

case 1:不將文件加入.ignore_format.yml,CI報(bào)錯(cuò)

case 2:將文件加入.ignore_format.yml的file_path,CI不報(bào)錯(cuò)

case 3:將文件加入.ignore_format.yml的dir_path,CI不報(bào)錯(cuò)

PR心得

這次PR的提交有以下兩個(gè)小心得。

01仔細(xì)溝通

第一點(diǎn),也是最重要的一點(diǎn)就是和主動(dòng)社區(qū)的前輩進(jìn)行交流,對(duì)issue的問題和需求進(jìn)行討論。在這個(gè)PR被merge之前我就完成了其余兩版,但是因?yàn)槿狈贤?,不是很適合當(dāng)前的RT-Thread。

02Github Action 本地測試

在修改CI部分時(shí),每次都需要推送到遠(yuǎn)端才能執(zhí)行相關(guān)的action,這樣比較麻煩。可以使用nektos/act: Run your GitHub Actions locally 工具在本地跑Github action。

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

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

RT-Thread線下入門培訓(xùn)

6月 - 深圳

1.免費(fèi)2.動(dòng)手實(shí)驗(yàn)+理論3.主辦方免費(fèi)提供開發(fā)板4.自行攜帶電腦,及插線板用于筆記本電腦充電5.參與者需要有C語言、單片機(jī)ARM Cortex-M核)基礎(chǔ),請(qǐng)?zhí)崆鞍惭b好RT-Thread Studio 開發(fā)環(huán)境

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

立即掃碼報(bào)名

報(bào)名鏈接

https://jinshuju.net/f/UYxS2k

巡回城市:青島、北京、西安、成都、武漢、鄭州、杭州、深圳、上海、南京

你可以添加微信:rtthread2020 為好友,注明:公司+姓名,拉進(jìn)RT-Thread官方微信交流群!

點(diǎn)擊閱讀原文,進(jìn)入RT-Thread 官網(wǎng)


原文標(biāo)題:如何快速向RT-Thread提一個(gè)PR:以CI為例

文章出處:【微信公眾號(hào):RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • RT-Thread
    +關(guān)注

    關(guān)注

    31

    文章

    1251

    瀏覽量

    39755

原文標(biāo)題:如何快速向RT-Thread提一個(gè)PR:以CI為例

文章出處:【微信號(hào):RTThread,微信公眾號(hào):RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    【大連】9月7日RT-Thread巡回線下培訓(xùn)-OpenMV機(jī)器視覺

    親愛的RT-Thread社區(qū)成員們:2024年RT-Thread全球開發(fā)者線下培訓(xùn)拉開帷幕啦!24年全球巡回培訓(xùn)將覆蓋超10座城市及國家,開發(fā)者提供
    的頭像 發(fā)表于 09-01 08:02 ?869次閱讀
    【大連】9月7日<b class='flag-5'>RT-Thread</b>巡回線下培訓(xùn)-OpenMV機(jī)器視覺

    2024 RT-Thread全球巡回 線下培訓(xùn)火熱來襲!

    親愛的RT-Thread社區(qū)成員們:我們非常高興地宣布,2024年RT-Thread全球開發(fā)者線下培訓(xùn)即將拉開帷幕!24年全球巡回培訓(xùn)將覆蓋超10座城市及國家,開發(fā)者提供
    的頭像 發(fā)表于 08-07 08:35 ?735次閱讀
    2024 <b class='flag-5'>RT-Thread</b>全球巡回 線下培訓(xùn)火熱來襲!

    【好書推薦】RT-Thread設(shè)備驅(qū)動(dòng)開發(fā)指南

    近年來國內(nèi)芯片產(chǎn)業(yè)和物聯(lián)網(wǎng)產(chǎn)業(yè)的快速崛起,行業(yè)發(fā)展迫切需要更多人才,尤其需要掌握嵌入式操作系統(tǒng)等底層技術(shù)的人才。隨著RT-Thread被更廣泛地應(yīng)用于行業(yè)中,開發(fā)者對(duì)嵌入式驅(qū)動(dòng)開發(fā)的需求越來越
    的頭像 發(fā)表于 08-01 08:35 ?429次閱讀
    【好書推薦】<b class='flag-5'>RT-Thread</b>設(shè)備驅(qū)動(dòng)開發(fā)指南

    RT-Thread 新里程碑達(dá)成——GitHub Star 破萬!

    RT-Thread實(shí)時(shí)操作系統(tǒng)開源項(xiàng)目在GitHub上的star數(shù)量突破一萬!截止發(fā)文,RT-Thread作為實(shí)時(shí)操作系統(tǒng)在業(yè)界Star數(shù)量排名第!倉庫地址:https://github.com
    的頭像 發(fā)表于 07-04 08:35 ?345次閱讀
    <b class='flag-5'>RT-Thread</b> 新里程碑達(dá)成——GitHub Star 破萬!

    6月6日杭州站RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    嵌入式軟件工程師郭占鑫老師您講解有關(guān)技術(shù)知識(shí)和實(shí)踐經(jīng)驗(yàn)。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺(tái)上提升系統(tǒng)實(shí)時(shí)
    的頭像 發(fā)表于 05-28 08:35 ?356次閱讀
    6月6日杭州站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    5月16日南京站RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    嵌入式軟件工程師郭占鑫老師您講解有關(guān)技術(shù)知識(shí)和實(shí)踐經(jīng)驗(yàn)。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺(tái)上提升系統(tǒng)實(shí)
    的頭像 發(fā)表于 05-01 08:35 ?283次閱讀
    5月16日南京站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    RT-Thread混合部署Workshop北京站來啦!

    嵌入式軟件工程師郭占鑫老師您講解有關(guān)技術(shù)知識(shí)和實(shí)踐經(jīng)驗(yàn)。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺(tái)上提升系統(tǒng)
    的頭像 發(fā)表于 04-19 08:34 ?370次閱讀
    <b class='flag-5'>RT-Thread</b>混合部署Workshop北京站來啦!

    4月25日北京站RT-Thread線下workshop,探索RT-Thread混合部署新模式

    嵌入式軟件工程師郭占鑫老師您講解有關(guān)技術(shù)知識(shí)和實(shí)踐經(jīng)驗(yàn)。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺(tái)上提升系統(tǒng)
    的頭像 發(fā)表于 04-16 08:35 ?358次閱讀
    4月25日北京站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式

    4月10日深圳場RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    4月10日我們將在深圳福田舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深嵌入式軟件工程師農(nóng)曉明老師
    的頭像 發(fā)表于 03-27 11:36 ?714次閱讀
    4月10日深圳場<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    4月10日深圳場RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    嵌入式軟件工程師農(nóng)曉明老師您講解有關(guān)技術(shù)知識(shí)和實(shí)踐經(jīng)驗(yàn)。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺(tái)上提升系統(tǒng)實(shí)
    的頭像 發(fā)表于 03-27 08:34 ?440次閱讀
    4月10日深圳場<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    恩智浦半導(dǎo)體正式加入RT-Thread全球合作伙伴計(jì)劃!

    前不久,恩智浦半導(dǎo)體正式加入RT-Thread全球合作伙伴計(jì)劃,成為RT-Thread高級(jí)會(huì)員合作伙伴。同時(shí),RT-Thread現(xiàn)已成為恩智浦注冊(cè)合作伙伴(RT-Thread| 簡介合
    的頭像 發(fā)表于 03-14 10:40 ?528次閱讀
    恩智浦半導(dǎo)體正式加入<b class='flag-5'>RT-Thread</b>全球合作伙伴計(jì)劃!

    RT-Thread設(shè)備驅(qū)動(dòng)開發(fā)指南》基礎(chǔ)篇--先楫bsp的hwtimer設(shè)備

    、概述(RT-Thread設(shè)備驅(qū)動(dòng)《RT-Thread設(shè)備驅(qū)動(dòng)開發(fā)指南》書籍是RT-thread官方出品撰寫,系統(tǒng)講解
    的頭像 發(fā)表于 02-24 08:16 ?1213次閱讀
    《<b class='flag-5'>RT-Thread</b>設(shè)備驅(qū)動(dòng)開發(fā)指南》基礎(chǔ)篇--<b class='flag-5'>以</b>先楫bsp的hwtimer設(shè)備<b class='flag-5'>為</b><b class='flag-5'>例</b>

    RT-Thread設(shè)備驅(qū)動(dòng)開發(fā)指南基礎(chǔ)篇—先楫bsp的hwtimer設(shè)備

    RT-Thread設(shè)備驅(qū)動(dòng)開發(fā)指南》書籍是RT-thread官方出品撰寫,系統(tǒng)講解RT-thread IO設(shè)備驅(qū)動(dòng)開發(fā)方法,從三方面進(jìn)行講解。
    的頭像 發(fā)表于 02-20 16:01 ?1515次閱讀
    <b class='flag-5'>RT-Thread</b>設(shè)備驅(qū)動(dòng)開發(fā)指南基礎(chǔ)篇—<b class='flag-5'>以</b>先楫bsp的hwtimer設(shè)備<b class='flag-5'>為</b><b class='flag-5'>例</b>

    i.MX RT1170:VGLite移植RT-Thread Nano過程講解(下)

    上篇介紹了如何移植 RT-Thread Nano 內(nèi)核與 Finsh 控制臺(tái)到 RT1170。本篇繼續(xù)介紹如何將 NXP 官方的 VGLite API 移植到 RT-Thread Nano 上。
    的頭像 發(fā)表于 11-09 11:22 ?829次閱讀

    上海線下培訓(xùn):RT-Thread×先楫 HPM5300 for RT-Thread ,高性能 RISC-V 平臺(tái)開發(fā)快速上手

    11月23日 RT-Thread 聯(lián)合先楫半導(dǎo)體將在上海舉行場線下培訓(xùn)。 本次培訓(xùn)會(huì)將為參與者提供了解先楫半導(dǎo)體和RT-Thread兩家公司最新技術(shù)和創(chuàng)新解決方案的機(jī)會(huì)。參與者將深入了解先楫半導(dǎo)體
    的頭像 發(fā)表于 11-03 19:10 ?689次閱讀
    上海線下培訓(xùn):<b class='flag-5'>RT-Thread</b>×先楫  HPM5300 for <b class='flag-5'>RT-Thread</b> ,高性能 RISC-V 平臺(tái)開發(fā)<b class='flag-5'>快速</b>上手