首頁 後端開發 Python教學 為 ReadmeGenie 實作 CI/CD

為 ReadmeGenie 實作 CI/CD

Nov 22, 2024 am 05:28 AM

Implementing CI/CD for ReadmeGenie

為什麼是持續整合/持續交付?

在我們深入了解設定之前,讓我們先簡單介紹一下為什麼 CI/CD 如此重要:

  1. 自動化測試:自動執行測試可確保代碼在每次變更時保持穩定。
  2. 一致性:CI/CD 在整個程式碼庫中強制執行標準(linting、格式化)。
  3. 可靠性:自動檢查和測試最大限度地減少人為錯誤並提高程式碼可靠性。
  4. 快速回饋:開發人員會收到有關程式碼品質的即時回饋,以便及早發現問題。

ReadmeGenie 中,我們利用 GitHub Actions 作為我們的 CI/CD 工具。它與 GitHub 儲存庫順利集成,並透過 YAML 設定檔提供靈活性和自動化。

ReadmeGenie 的 CI/CD 管道

我們的 CI/CD 管道包括以下自動化步驟:

  1. Linting 和格式檢查:我們運行 RuffBlack 以確保程式碼風格和一致性。
  2. 單元測試:我們使用單元測試來驗證程式碼變更不會破壞現有功能。
  3. 覆蓋率分析:我們使用Coverage.py來確保程式碼在允許提交之前滿足我們的覆蓋率閾值。
  4. 預先提交掛鉤:我們添加了掛鉤以在推送更改之前強制執行本地品質檢查。

GitHub Actions 工作流程概述

CI 工作流程在 .github/workflows/python-app.yml 中定義。以下是工作流程每個部分的詳細說明:

1. 觸發工作流程

工作流程在主分支的每個推送和拉取請求上執行。這可確保所有程式碼變更在合併到生產環境之前都經過驗證。

name: Python application

on:
  push:
    branches: ["main"]
  pull_request:
    branches: ["main"]
登入後複製
登入後複製

2. 設定Python環境

我們將 GitHub Actions 設定為使用 Python 3.12.x,確保與本機開發環境的一致性。此步驟安裝特定的Python版本並準備依賴安裝的環境。

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v4
      - name: Set up Python 3.12.x
        uses: actions/setup-python@v3
        with:
          python-version: "3.12.x"
登入後複製
登入後複製

3. 安裝依賴項

下一步是安裝專案相依性。在這裡,我們升級pip並安裝requirements.txt文件,它將安裝其中指定的附加依賴項。

      - name: Install dependencies
        run: |
          python -m pip install --upgrade pip
          pip install flake8 pytest
          if [ -f requirements.txt ]; then pip install -r requirements.txt; fi
登入後複製
登入後複製

4. 運行 Linting 和程式碼品質檢查

Linting 是我們工作流程的重要組成部分,確保程式碼符合指定的品質標準。我們運行 flake8,並帶有標記語法錯誤、未定義名稱和複雜性問題的選項。

name: Python application

on:
  push:
    branches: ["main"]
  pull_request:
    branches: ["main"]
登入後複製
登入後複製

5. 透過覆蓋率分析運行測試

對於單元測試,我們使用 pytest 來運行所有測試案例。此外,我們使用覆蓋率來追蹤測試了哪些程式碼行,確保我們的測試套件符合定義的 75% 覆蓋率閾值。

以下命令執行測試並產生覆蓋率報告,突出顯示測試覆蓋率中的任何差距。這對於品質保證至關重要,因為未經測試的程式碼是未來錯誤的潛在來源。

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v4
      - name: Set up Python 3.12.x
        uses: actions/setup-python@v3
        with:
          python-version: "3.12.x"
登入後複製
登入後複製

此覆蓋率檢查透過強制測試覆蓋至少 75% 的程式碼庫來確保高標準的程式碼品質。如果覆蓋率低於此閾值,則不允許提交。

整合預提交掛鉤

除了 CI/CD 之外,我們還設定了預提交掛鉤,以在將任何變更推送到儲存庫之前在本地強制執行程式碼品質。這些鉤子:

  • 執行 Ruff 進行 linting,執行 Black 進行格式化。
  • 透過在本地運行覆蓋率測試來強制執行最低覆蓋率閾值。

以下是我們如何將覆蓋率檢查新增為 .pre-commit-config.yaml 中的預先提交掛鉤:

      - name: Install dependencies
        run: |
          python -m pip install --upgrade pip
          pip install flake8 pytest
          if [ -f requirements.txt ]; then pip install -r requirements.txt; fi
登入後複製
登入後複製

挑戰和經驗教訓

設定 CI/CD 需要深入了解不同工具(flake8、pytest、coverage)如何在 GitHub Actions 中互動。以下是我們面臨的一些挑戰以及我們實施的解決方案:

處理不同的本地和遠端配置

我們遇到了環境變數衝突的問題,特別是在測試 API 整合和組態處理時。在單元測試中使用 @patch.dict 和其他模擬技術使我們能夠有效地模擬環境。

測試覆蓋率和閾值

最大的挑戰是確保足夠的測試覆蓋率。在 GitHub Actions 和預提交掛鉤中使用帶有 --fail-under=75 的coverage.py 有助於執行此標準。

未來的改進

為了讓 CI/CD 管道更強大,我們計畫:

  1. 新增部署階段:測試通過後自動部署到暫存或生產環境。
  2. 自動化程式碼品質徽章:新增動態徽章以在 README 中顯示覆蓋率、linting 狀態和測試結果。
  3. 擴大覆蓋範圍要求:隨著我們改進測試並覆蓋更多邊緣情況,提高覆蓋範圍閾值。

外賣

透過這個項目,我意識到儘早建立強大的測試和 CI/CD 實踐的重要性。如果我重新開始,我會專注於從一開始就編寫全面的測試,並隨著專案的進展逐步擴展和改進它們。這種方法可以防止丟失分支或未經測試的區域,並確保所有新程式碼順利整合到覆蓋良好的程式碼庫中。

以上是為 ReadmeGenie 實作 CI/CD的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1672
14
CakePHP 教程
1428
52
Laravel 教程
1332
25
PHP教程
1277
29
C# 教程
1256
24
Python與C:學習曲線和易用性 Python與C:學習曲線和易用性 Apr 19, 2025 am 12:20 AM

Python更易學且易用,C 則更強大但複雜。 1.Python語法簡潔,適合初學者,動態類型和自動內存管理使其易用,但可能導致運行時錯誤。 2.C 提供低級控制和高級特性,適合高性能應用,但學習門檻高,需手動管理內存和類型安全。

學習Python:2小時的每日學習是否足夠? 學習Python:2小時的每日學習是否足夠? Apr 18, 2025 am 12:22 AM

每天學習Python兩個小時是否足夠?這取決於你的目標和學習方法。 1)制定清晰的學習計劃,2)選擇合適的學習資源和方法,3)動手實踐和復習鞏固,可以在這段時間內逐步掌握Python的基本知識和高級功能。

Python vs.C:探索性能和效率 Python vs.C:探索性能和效率 Apr 18, 2025 am 12:20 AM

Python在開發效率上優於C ,但C 在執行性能上更高。 1.Python的簡潔語法和豐富庫提高開發效率。 2.C 的編譯型特性和硬件控制提升執行性能。選擇時需根據項目需求權衡開發速度與執行效率。

Python vs. C:了解關鍵差異 Python vs. C:了解關鍵差異 Apr 21, 2025 am 12:18 AM

Python和C 各有優勢,選擇應基於項目需求。 1)Python適合快速開發和數據處理,因其簡潔語法和動態類型。 2)C 適用於高性能和系統編程,因其靜態類型和手動內存管理。

Python標準庫的哪一部分是:列表或數組? Python標準庫的哪一部分是:列表或數組? Apr 27, 2025 am 12:03 AM

pythonlistsarepartofthestAndArdLibrary,herilearRaysarenot.listsarebuilt-In,多功能,和Rused ForStoringCollections,而EasaraySaraySaraySaraysaraySaraySaraysaraySaraysarrayModuleandleandleandlesscommonlyusedDduetolimitedFunctionalityFunctionalityFunctionality。

Python:自動化,腳本和任務管理 Python:自動化,腳本和任務管理 Apr 16, 2025 am 12:14 AM

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。

科學計算的Python:詳細的外觀 科學計算的Python:詳細的外觀 Apr 19, 2025 am 12:15 AM

Python在科學計算中的應用包括數據分析、機器學習、數值模擬和可視化。 1.Numpy提供高效的多維數組和數學函數。 2.SciPy擴展Numpy功能,提供優化和線性代數工具。 3.Pandas用於數據處理和分析。 4.Matplotlib用於生成各種圖表和可視化結果。

Web開發的Python:關鍵應用程序 Web開發的Python:關鍵應用程序 Apr 18, 2025 am 12:20 AM

Python在Web開發中的關鍵應用包括使用Django和Flask框架、API開發、數據分析與可視化、機器學習與AI、以及性能優化。 1.Django和Flask框架:Django適合快速開發複雜應用,Flask適用於小型或高度自定義項目。 2.API開發:使用Flask或DjangoRESTFramework構建RESTfulAPI。 3.數據分析與可視化:利用Python處理數據並通過Web界面展示。 4.機器學習與AI:Python用於構建智能Web應用。 5.性能優化:通過異步編程、緩存和代碼優

See all articles