Maison >développement back-end >C++ >Tester cest tricher, compiler cest douter
Cet article explore le concept, les avantages, les inconvénients et un exemple de démonstration de l'intégration continue (CI).
Tout d’abord, jetons un bref coup d’œil à l’histoire.
En 1999, Kent Beck a exploré ce sujet en profondeur dans son premier livre sur l'Extreme Programming. En 2001, CruiseControl, l'un des premiers outils CI open source, est né.
L'objectif de CI est d'exécuter des tests automatisés après chaque validation de code. Cela garantit que le code reste toujours fonctionnel. Nous appelons cela intégration continue car chaque fois que le code est modifié, il est vérifié pour garantir qu'aucun problème de régression ne se produit.
Avant de comprendre comment cela fonctionne, comprenons quelques termes :
Le principe est simple : chaque job renvoie un code de statut (succès ou échec). Si une tâche échoue, le pipeline s'arrêtera ou ignorera les étapes suivantes en fonction de la configuration.
Nous utiliserons des exemples basés sur GitLab CI. Peut être configuré via des fichiers .gitlab-ci.yml
.
<code>image: alpine:latest myjobname: script: - make</code>
Ajouter des drapeaux de compilation, il existe deux méthodes :
<code>myjobname_hard: script: - CFLAGS="-Wall -Werror" make # 或者 - make compile_flags</code>
Criterion est une bibliothèque de tests unitaires en langage C.
Avant d'utiliser Criterion pour les tests, vous devez installer Criterion.
<code>before_script: - apt-get update && apt-get install -y libcriterion-dev script: - ./configure - make test</code>
Divisez les tests unitaires et les tests fonctionnels en plusieurs phases, vous pouvez :
<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>
Le formatage du code est crucial pour maintenir une base de code propre.
<code>image: alpine:latest myjobname: script: - make</code>
Dans certains cas, il est utile de mettre en cache des fichiers ou des dossiers pour éviter de les recharger à chaque fois que le pipeline est exécuté.
Un exemple courant est le dossier node_modules/
en JavaScript.
<code>myjobname_hard: script: - CFLAGS="-Wall -Werror" make # 或者 - make compile_flags</code>
Bien entendu, vous pouvez utiliser des options supplémentaires dans la configuration du pipeline pour vider le cache si nécessaire.
Les artefacts sont des fichiers générés par CI qui peuvent être partagés ou téléchargés entre les tâches.
Par exemple, des rapports de tests ou de couverture.
<code>before_script: - apt-get update && apt-get install -y libcriterion-dev script: - ./configure - make test</code>
La couverture des tests peut être mesurée en intégrant des outils comme gcovr ou Cobertura dans votre pipeline CI.
<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>
Ce bloc de code vous permet d'intégrer le reporting de couverture dans vos demandes de fusion afin que vous puissiez voir le code qui n'est pas couvert ainsi que le pourcentage de couverture.
<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>
Vous pouvez spécifier l'environnement de base pour CI en sélectionnant une image Docker spécifique.
<code>cache: paths: - node_modules/ install: script: - npm install</code>
En combinant le contenu ci-dessus, vous pouvez obtenir l'exemple suivant :
<code>artifacts: paths: - build/ - reports/</code>
Notez que le fichier
.h
est manquant etbefore_script
est manquant.
Vous pouvez également rechercher les fichiers indésirables pour vous assurer que make clean
fonctionne correctement.
<code>test-coverage: stage: test script: - gcovr --html --html-details -o coverage.html artifacts: paths: - coverage.html</code>
L'intégration continue est un outil extrêmement puissant. Même si sa mise en place peut être difficile, les avantages sont énormes.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!