Maison > développement back-end > C++ > Tester c&#est tricher, compiler c&#est douter

Tester c&#est tricher, compiler c&#est douter

DDD
Libérer: 2025-01-10 22:07:43
original
752 Les gens l'ont consulté

Tester c

Cet article explore le concept, les avantages, les inconvénients et un exemple de démonstration de l'intégration continue (CI).

Revue historique

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é.

Pourquoi utiliser CI ?

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.

Avantages

  • Détectez les erreurs le plus tôt possible : Les problèmes sont identifiés rapidement, ce qui permet d'apporter des réponses rapides.
  • Amélioration de la qualité : Des tests systématiques garantissent un code plus robuste.
  • Gain de temps : Les pipelines automatisés réduisent le besoin de tests manuels répétitifs.

Inconvénients

  • Coût initial : La mise en place de CI peut nécessiter un investissement initial et une expertise importants.
  • Temps d'exécution : Les pipelines complexes peuvent prolonger le temps nécessaire aux développeurs pour vérifier leur code.

Comment ça marche

Avant de comprendre comment cela fonctionne, comprenons quelques termes :

  • Jobs : Une instance d'un conteneur (généralement Docker) utilisée pour exécuter des scripts. Cela peut inclure des commandes, des tests ou des opérations simples telles que l'écho.
  • Pipeline : Une série de jobs organisés en séquence ou en parallèle. Chaque commit déclenche cette série d'actions pour valider les modifications.

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.

Perceuse pratique

Nous utiliserons des exemples basés sur GitLab CI. Peut être configuré via des fichiers .gitlab-ci.yml.

Exemple de base

<code>image: alpine:latest

myjobname:
  script:
    - make</code>
Copier après la connexion
Copier après la connexion

Compiler les drapeaux

Ajouter des drapeaux de compilation, il existe deux méthodes :

  1. Passez les règles dans Makefile.
  2. Passez les indicateurs directement dans les commandes CI.
<code>myjobname_hard:
  script:
    - CFLAGS="-Wall -Werror" make
    # 或者
    - make compile_flags</code>
Copier après la connexion
Copier après la connexion

Utilisation de Criterion pour les tests et le signalement

Criterion est une bibliothèque de tests unitaires en langage C.

Installation des critères

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>
Copier après la connexion
Copier après la connexion

Construction en plusieurs étapes

Divisez les tests unitaires et les tests fonctionnels en plusieurs phases, vous pouvez :

  • Mieux organisé
  • Meilleure vue des résultats
<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>
Copier après la connexion
Copier après la connexion

Utilisez Clang pour formater le code

Le formatage du code est crucial pour maintenir une base de code propre.

<code>image: alpine:latest

myjobname:
  script:
    - make</code>
Copier après la connexion
Copier après la connexion

Cache

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>
Copier après la connexion
Copier après la connexion

Bien entendu, vous pouvez utiliser des options supplémentaires dans la configuration du pipeline pour vider le cache si nécessaire.

Artefact

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>
Copier après la connexion
Copier après la connexion

Couverture des tests

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>
Copier après la connexion
Copier après la connexion

Rapport

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>
Copier après la connexion

Environnement personnalisé

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>
Copier après la connexion

En combinant le contenu ci-dessus, vous pouvez obtenir l'exemple suivant :

<code>artifacts:
  paths:
    - build/
    - reports/</code>
Copier après la connexion

Notez que le fichier .h est manquant et before_script est manquant.

Suppléments supplémentaires

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>
Copier après la connexion

Résumé

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal