Rumah >pembangunan bahagian belakang >C++ >Menguji adalah menipu, menyusun adalah meragukan

Menguji adalah menipu, menyusun adalah meragukan

DDD
DDDasal
2025-01-10 22:07:43790semak imbas

Tester c

Artikel ini meneroka konsep, kelebihan, keburukan dan contoh demonstrasi Integrasi Berterusan (CI).

Semakan Sejarah

Pertama, mari kita lihat sejarah secara ringkas.

Pada tahun 1999, Kent Beck meneroka topik ini secara mendalam dalam buku pertamanya mengenai Pengaturcaraan Extreme. Pada tahun 2001, CruiseControl, salah satu alat CI sumber terbuka pertama, telah dilahirkan.

Kenapa guna CI?

Matlamat CI adalah untuk melaksanakan ujian automatik selepas setiap kod komit. Ini memastikan bahawa kod sentiasa kekal berfungsi. Kami memanggil penyepaduan berterusan ini kerana setiap kali kod diubah suai ia disahkan untuk memastikan tiada isu regresi berlaku.

Kelebihan

  • Tangkap ralat lebih awal: Masalah dikenal pasti dengan cepat, membolehkan respons tepat pada masanya.
  • Meningkatkan kualiti: Ujian sistematik memastikan kod yang lebih mantap.
  • Penjimatan Masa: Saluran paip automatik mengurangkan keperluan untuk ujian manual berulang.

Kelemahan

  • Kos Permulaan: Menyediakan CI boleh memerlukan pelaburan dan kepakaran permulaan yang ketara.
  • Masa pelaksanaan: Saluran paip yang kompleks mungkin memanjangkan masa yang diambil untuk pembangun mengesahkan kod mereka.

Cara ia berfungsi

Sebelum kita memahami cara ia berfungsi, mari kita fahami beberapa istilah:

  • Kerja: Contoh bekas (biasanya Docker) yang digunakan untuk melaksanakan skrip. Ini mungkin termasuk arahan, ujian atau operasi mudah seperti gema.
  • Saluran Paip: Satu siri kerja yang disusun mengikut urutan atau selari. Setiap komit mencetuskan siri tindakan ini untuk mengesahkan perubahan.

Prinsipnya mudah: setiap kerja mengembalikan kod status (berjaya atau gagal). Jika kerja gagal, saluran paip akan berhenti atau melangkau langkah seterusnya bergantung pada konfigurasi.

Latih tubi praktikal

Kami akan menggunakan contoh berasaskan GitLab CI. Boleh dikonfigurasikan melalui .gitlab-ci.yml fail.

Contoh Asas

<code>image: alpine:latest

myjobname:
  script:
    - make</code>

Kompilasi bendera

Tambah bendera kompilasi, terdapat dua kaedah:

  1. Luluskan peraturan dalam Makefile.
  2. Hantar bendera terus dalam arahan CI.
<code>myjobname_hard:
  script:
    - CFLAGS="-Wall -Werror" make
    # 或者
    - make compile_flags</code>

Menggunakan Kriteria untuk menguji dan membenderakan

Kriteria ialah perpustakaan ujian unit bahasa C.

Pemasangan kriteria

Sebelum menggunakan Kriteria untuk ujian, anda perlu memasang Kriteria.

<code>before_script:
  - apt-get update && apt-get install -y libcriterion-dev
script:
  - ./configure
  - make test</code>

Pembinaan berbilang peringkat

Pisah ujian unit dan ujian fungsi kepada berbilang fasa, anda boleh:

  • Lebih Tersusun
  • Pandangan hasil yang lebih baik
<code>stages:
  - build
  - test

build:
  stage: build
  script:
    - make all

test-unit:
  stage: test
  script:
    - make unit-test

test-functional:
  stage: test
  script:
    - make functional-test</code>

Gunakan Clang untuk memformat kod

Pemformatan kod adalah penting untuk mengekalkan asas kod yang bersih.

<code>image: alpine:latest

myjobname:
  script:
    - make</code>

Cache

Dalam sesetengah kes adalah berguna untuk cache fail atau folder untuk mengelakkan memuatkan semula fail setiap kali saluran paip dijalankan.

Contoh biasa ialah folder node_modules/ dalam JavaScript.

<code>myjobname_hard:
  script:
    - CFLAGS="-Wall -Werror" make
    # 或者
    - make compile_flags</code>

Sudah tentu, anda boleh menggunakan pilihan tambahan dalam konfigurasi saluran paip untuk mengosongkan cache jika perlu.

Artifak

Artifak ialah fail janaan CI yang boleh dikongsi atau dimuat turun merentas kerja.

Contohnya, laporan ujian atau liputan.

<code>before_script:
  - apt-get update && apt-get install -y libcriterion-dev
script:
  - ./configure
  - make test</code>

Liputan Ujian

Liputan ujian boleh diukur dengan menyepadukan alatan seperti gcovr atau Cobertura dalam saluran paip CI anda.

<code>stages:
  - build
  - test

build:
  stage: build
  script:
    - make all

test-unit:
  stage: test
  script:
    - make unit-test

test-functional:
  stage: test
  script:
    - make functional-test</code>

Laporkan

Blok kod ini membolehkan anda menyepadukan pelaporan liputan ke dalam permintaan gabungan anda supaya anda boleh melihat kod yang tidak dilindungi serta peratusan liputan.

<code>clang_format:
  stage: format
  before_script:
    - apt-get -qq update && apt-get -qq install -y clang-format autotools-dev autoconf-archive gcovr libcriterion-dev
  script:
    - clang-format -i $(find src/ -type f -name "*.c") --dry-run --Werror</code>

Persekitaran tersuai

Anda boleh menentukan persekitaran asas untuk CI dengan memilih imej Docker tertentu.

<code>cache:
  paths:
    - node_modules/

install:
  script:
    - npm install</code>

Menggabungkan kandungan di atas, anda boleh mendapatkan contoh berikut:

<code>artifacts:
  paths:
    - build/
    - reports/</code>

Perhatikan bahawa fail .h tiada dan before_script tiada.

Supplemen tambahan

Anda juga boleh menyemak fail sampah untuk memastikan make clean berfungsi dengan betul.

<code>test-coverage:
  stage: test
  script:
    - gcovr --html --html-details -o coverage.html
  artifacts:
    paths:
      - coverage.html</code>

Ringkasan

Penyepaduan berterusan ialah alat yang sangat berkuasa. Walaupun ia boleh menjadi sukar untuk disediakan, faedahnya sangat besar.

Atas ialah kandungan terperinci Menguji adalah menipu, menyusun adalah meragukan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn