Projek ini ialah projek contoh pantas yang menunjukkan automasi proses binaan, ujian dan penggunaan aplikasi kepada persekitaran pementasan semasa menolak ke cawangan utama.
Untuk menunjukkan saluran paip CI/CD dengan secukupnya, kami akan mencipta projek Python mudah dengan kod minimum dan kemudian menyepadukannya ke dalam Tindakan GitHub.
Seperti yang saya nyatakan sebelum ini, kami akan membuat projek mudah yang akan kami gunakan dalam perancangan kami. Saya memilih untuk melakukan ini dalam python tanpa sebab tertentu, anda boleh menggunakan mana-mana bahasa pengaturcaraan lain yang anda pilih, utama projek ini adalah untuk menunjukkan saluran paip.
Jadi, teruskan dan buat folder projek dan navigasi ke dalam folder itu:
mkdir automated-testing cd automated-testing
Sekarang kita akan menulis aplikasi python mudah. Cipta fail app.py baharu dalam folder projek.
touch app.py
Tambahkan blok kod di bawah pada fail:
def hello(): return "Hello, World!" if __name__ == "__main__": print(hello())
Ini ialah fungsi "Hello world" ular sawa yang sangat mudah yang berfungsi sebagai contoh fungsi asas yang boleh diuji dalam saluran paip CI.
def hello() mentakrifkan fungsi bernama hello yang tidak memerlukan hujah. Apabila fungsi ini dipanggil, ia mengembalikan rentetan "Hello, World!".
if __name__ == "__main__" ialah binaan Python standard yang digunakan untuk memastikan bahawa kod tertentu hanya berjalan apabila fail dilaksanakan secara langsung (bukan apabila diimport sebagai modul). Ia bertindak sebagai titik masuk untuk skrip.
Apabila app.py dijalankan secara langsung (cth., dengan menjalankan python app.py), skrip akan memanggil fungsi hello() dan mencetak hasilnya, iaitu "Hello, World!".
Projek biasa akan mempunyai kebergantungan dan dalam projek ular sawa mereka biasanya ditakrifkan dalam fail requirements.txt.
Buat keperluan fail baharu.txt
touch requirements.txt
Tambahkan ini pada fail:
pytest
Kini kami akan menambah fail ujian asas, test_app.py, untuk menguji fungsi dalam app.py. Tambahkan di bawah pada fail:
from app import hello def test_hello(): assert hello() == "Hello, World!"
Kini kami bersedia untuk mencipta saluran paip kami.
Untuk mengkonfigurasi tindakan GitHub, kami perlu mencipta folder .github/workflows di dalam repo kami, ini adalah cara kami memberitahu GitHub tentang saluran paip CI/CD dalam repo kami.
Buat fail baharu:
mkdir -p .github/workflows
Anda boleh mempunyai berbilang saluran paip dalam satu repo, jadi buat fail proj.yml dalam folder .github/workflows. Di sinilah kami akan menentukan langkah untuk membina, menguji dan menggunakan projek Python kami.
Tambahkan kod di bawah pada fail anda:
name: Build, Test and Deploy # Trigger the workflow on pushes to the main branch on: push: branches: - main jobs: build-and-test: runs-on: ubuntu-latest steps: # Checkout the code from the repository - name: Checkout repo uses: actions/checkout@v4 # Set up Python environment - name: Setup Python uses: actions/setup-python@v5 with: python-version: '3.x' # Install dependencies - name: Install Dependecies run: | python -m pip install --upgrade pip pip install -r requirements.txt # Build (this project deosn't require a build but we will simulate a build by creating a file) - name: Build Project run: | mkdir -p build # Simulate build output by creating a file touch build/output_file.txt # Run tests using pytest - name: Run tests run: pytest # Upload the build output as an artifact (we created a file in the build step to simulate an artifact) - name: Upload build artifact uses: actions/upload-artifact@v4 with: name: build-artifact path: build/ deploy: runs-on: ubuntu-latest needs: build-and-test if: success() steps: # Download the artifact from the build stage - name: Download build artifact uses: actions/download-artifact@v4 with: name: build-artifact path: build/ - name: Simulate Deployment run: | echo "Deploying to staging..." ls build/
If you haven't already, you need to initialize a git repository using the commands below:
git init git add . git commit -m "Create project as well as CI/CD pipeline"
Now we push to GitHub. Create a GitHub repository and push your code using the below commands:
git remote add origin <your-repo-url> git push -u origin main
After pushing the code, you can visit the Actions tab in your GitHub repository. You should see the pipeline triggered, running the steps defined in your proj.yml file.
If everything is set up correctly, the pipeline will build, test, and simulate deployment. You can changes things around in your project and make new pushes to see the the pipeline works, create errors intentional so you can see how the pipeline works when the tests fail.
On a successful run this is how your Actions tab should look.
And that's it, this setup provides a working example of a CI/CD pipeline for a very basic Python project. If you found this helpful, please share with your connection and if you have any questions, do not hesitate to drop the question in the comments.
Atas ialah kandungan terperinci Automatikkan Proses Bina, Uji & Pasang dengan Tindakan GitHub. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!