Claude Code pour GitLab CI/CD est actuellement en bêta. Les fonctionnalités et les capacités peuvent évoluer au fur et à mesure que nous affinons l’expérience.Cette intégration est maintenue par GitLab. Pour obtenir de l’aide, consultez le problème GitLab suivant.
Cette intégration est construite sur la base de la CLI et du SDK Claude Code, permettant l’utilisation programmatique de Claude dans vos tâches CI/CD et vos flux de travail d’automatisation personnalisés.
Pourquoi utiliser Claude Code avec GitLab ?
- Création instantanée de MR : Décrivez ce dont vous avez besoin, et Claude propose une MR complète avec les modifications et une explication
- Implémentation automatisée : Transformez les problèmes en code fonctionnel avec une seule commande ou mention
- Conscient du projet : Claude suit vos directives
CLAUDE.mdet les modèles de code existants - Configuration simple : Ajoutez un travail à
.gitlab-ci.ymlet une variable CI/CD masquée - Prêt pour l’entreprise : Choisissez Claude API, AWS Bedrock ou Google Vertex AI pour répondre aux besoins de résidence des données et d’approvisionnement
- Sécurisé par défaut : S’exécute dans vos exécuteurs GitLab avec votre protection de branche et vos approbations
Comment ça marche
Claude Code utilise GitLab CI/CD pour exécuter des tâches d’IA dans des travaux isolés et valider les résultats via des MR :-
Orchestration pilotée par les événements : GitLab écoute les déclencheurs que vous choisissez (par exemple, un commentaire qui mentionne
@claudedans un problème, une MR ou un fil de discussion). Le travail collecte le contexte du fil et du référentiel, construit des invites à partir de cette entrée et exécute Claude Code. -
Abstraction du fournisseur : Utilisez le fournisseur qui correspond à votre environnement :
- Claude API (SaaS)
- AWS Bedrock (accès basé sur IAM, options multi-régions)
- Google Vertex AI (natif GCP, Workload Identity Federation)
- Exécution en bac à sable : Chaque interaction s’exécute dans un conteneur avec des règles strictes de réseau et de système de fichiers. Claude Code applique des autorisations limitées à l’espace de travail pour limiter les écritures. Chaque modification passe par une MR afin que les examinateurs voient le diff et que les approbations s’appliquent toujours.
Que peut faire Claude ?
Claude Code permet des flux de travail CI/CD puissants qui transforment votre façon de travailler avec le code :- Créer et mettre à jour des MR à partir de descriptions ou de commentaires de problèmes
- Analyser les régressions de performance et proposer des optimisations
- Implémenter des fonctionnalités directement dans une branche, puis ouvrir une MR
- Corriger les bogues et les régressions identifiés par les tests ou les commentaires
- Répondre aux commentaires de suivi pour itérer sur les modifications demandées
Configuration
Configuration rapide
Le moyen le plus rapide de commencer est d’ajouter un travail minimal à votre.gitlab-ci.yml et de définir votre clé API en tant que variable masquée.
-
Ajouter une variable CI/CD masquée
- Allez à Paramètres → CI/CD → Variables
- Ajoutez
ANTHROPIC_API_KEY(masquée, protégée selon les besoins)
-
Ajouter un travail Claude à
.gitlab-ci.yml
ANTHROPIC_API_KEY, testez en exécutant le travail manuellement à partir de CI/CD → Pipelines, ou déclenchez-le à partir d’une MR pour laisser Claude proposer des mises à jour dans une branche et ouvrir une MR si nécessaire.
Pour exécuter sur AWS Bedrock ou Google Vertex AI au lieu de l’API Claude, consultez la section Utilisation avec AWS Bedrock et Google Vertex AI ci-dessous pour la configuration de l’authentification et de l’environnement.
Configuration manuelle (recommandée pour la production)
Si vous préférez une configuration plus contrôlée ou si vous avez besoin de fournisseurs d’entreprise :-
Configurer l’accès au fournisseur :
- Claude API : Créez et stockez
ANTHROPIC_API_KEYen tant que variable CI/CD masquée - AWS Bedrock : Configurer GitLab → AWS OIDC et créer un rôle IAM pour Bedrock
- Google Vertex AI : Configurer Workload Identity Federation pour GitLab → GCP
- Claude API : Créez et stockez
-
Ajouter les identifiants du projet pour les opérations de l’API GitLab :
- Utilisez
CI_JOB_TOKENpar défaut, ou créez un jeton d’accès au projet avec la portéeapi - Stockez en tant que
GITLAB_ACCESS_TOKEN(masqué) si vous utilisez un PAT
- Utilisez
-
Ajouter le travail Claude à
.gitlab-ci.yml(voir les exemples ci-dessous) -
(Optionnel) Activer les déclencheurs pilotés par mention :
- Ajouter un webhook de projet pour « Commentaires (notes) » à votre écouteur d’événements (si vous en utilisez un)
- Faire en sorte que l’écouteur appelle l’API de déclenchement de pipeline avec des variables comme
AI_FLOW_INPUTetAI_FLOW_CONTEXTlorsqu’un commentaire contient@claude
Exemples de cas d’usage
Transformer les problèmes en MR
Dans un commentaire de problème :Obtenir de l’aide à l’implémentation
Dans une discussion MR :Corriger les bogues rapidement
Dans un commentaire de problème ou de MR :Utilisation avec AWS Bedrock et Google Vertex AI
Pour les environnements d’entreprise, vous pouvez exécuter Claude Code entièrement sur votre infrastructure cloud avec la même expérience développeur.Conditions préalables
Avant de configurer Claude Code avec AWS Bedrock, vous avez besoin de :- Un compte AWS avec accès à Amazon Bedrock pour les modèles Claude souhaités
- GitLab configuré en tant que fournisseur d’identité OIDC dans AWS IAM
- Un rôle IAM avec des autorisations Bedrock et une politique de confiance limitée à votre projet/références GitLab
- Variables CI/CD GitLab pour l’assomption de rôle :
AWS_ROLE_TO_ASSUME(ARN du rôle)AWS_REGION(région Bedrock)
Instructions de configuration
Configurez AWS pour permettre aux travaux CI GitLab d’assumer un rôle IAM via OIDC (pas de clés statiques).Configuration requise :- Activez Amazon Bedrock et demandez l’accès à vos modèles Claude cibles
- Créez un fournisseur OIDC IAM pour GitLab s’il n’existe pas déjà
- Créez un rôle IAM approuvé par le fournisseur OIDC GitLab, limité à votre projet et références protégées
- Attachez les autorisations de moindre privilège pour les API d’invocation Bedrock
AWS_ROLE_TO_ASSUMEAWS_REGION
Exemples de configuration
Voici des extraits prêts à l’emploi que vous pouvez adapter à votre pipeline..gitlab-ci.yml basique (Claude API)
Exemple de travail AWS Bedrock (OIDC)
Conditions préalables :- Amazon Bedrock activé avec accès à votre modèle Claude choisi
- GitLab OIDC configuré dans AWS avec un rôle qui fait confiance à votre projet et références GitLab
- Rôle IAM avec autorisations Bedrock (moindre privilège recommandé)
AWS_ROLE_TO_ASSUME: ARN du rôle IAM pour l’accès BedrockAWS_REGION: Région Bedrock (par exemple,us-west-2)
Les ID de modèle pour Bedrock incluent des préfixes spécifiques à la région et des suffixes de version (par exemple,
us.anthropic.claude-sonnet-4-5-20250929-v1:0). Transmettez le modèle souhaité via votre configuration de travail ou votre invite si votre flux de travail le prend en charge.Exemple de travail Google Vertex AI (Workload Identity Federation)
Conditions préalables :- API Vertex AI activée dans votre projet GCP
- Workload Identity Federation configurée pour faire confiance à GitLab OIDC
- Un compte de service avec des autorisations Vertex AI
GCP_WORKLOAD_IDENTITY_PROVIDER: Nom complet de la ressource du fournisseurGCP_SERVICE_ACCOUNT: E-mail du compte de serviceCLOUD_ML_REGION: Région Vertex (par exemple,us-east5)
Avec Workload Identity Federation, vous n’avez pas besoin de stocker les clés du compte de service. Utilisez des conditions de confiance spécifiques au référentiel et des comptes de service avec le moindre privilège.
Meilleures pratiques
Configuration CLAUDE.md
Créez un fichierCLAUDE.md à la racine du référentiel pour définir les normes de codage, les critères d’examen et les règles spécifiques au projet. Claude lit ce fichier lors des exécutions et suit vos conventions lors de la proposition de modifications.
Considérations de sécurité
Ne validez jamais les clés API ou les identifiants cloud dans votre référentiel ! Utilisez toujours les variables CI/CD GitLab :- Ajoutez
ANTHROPIC_API_KEYen tant que variable masquée (et protégez-la si nécessaire) - Utilisez OIDC spécifique au fournisseur si possible (pas de clés de longue durée)
- Limitez les autorisations des travaux et la sortie réseau
- Examinez les MR de Claude comme tout autre contributeur
Optimisation des performances
- Gardez
CLAUDE.mdconcentré et concis - Fournissez des descriptions claires de problèmes/MR pour réduire les itérations
- Configurez des délais d’expiration de travail raisonnables pour éviter les exécutions incontrôlées
- Mettez en cache les installations npm et de paquets dans les exécuteurs si possible
Coûts CI
Lorsque vous utilisez Claude Code avec GitLab CI/CD, soyez conscient des coûts associés :-
Temps d’exécuteur GitLab :
- Claude s’exécute sur vos exécuteurs GitLab et consomme des minutes de calcul
- Consultez la facturation des exécuteurs de votre plan GitLab pour plus de détails
-
Coûts API :
- Chaque interaction Claude consomme des jetons en fonction de la taille de l’invite et de la réponse
- L’utilisation des jetons varie selon la complexité de la tâche et la taille de la base de code
- Consultez la tarification Anthropic pour plus de détails
-
Conseils d’optimisation des coûts :
- Utilisez des commandes
@claudespécifiques pour réduire les tours inutiles - Définissez les valeurs
max_turnset les délais d’expiration des travaux appropriés - Limitez la concurrence pour contrôler les exécutions parallèles
- Utilisez des commandes
Sécurité et gouvernance
- Chaque travail s’exécute dans un conteneur isolé avec un accès réseau restreint
- Les modifications de Claude passent par des MR afin que les examinateurs voient chaque diff
- Les règles de protection de branche et d’approbation s’appliquent au code généré par l’IA
- Claude Code utilise des autorisations limitées à l’espace de travail pour limiter les écritures
- Les coûts restent sous votre contrôle car vous apportez vos propres identifiants de fournisseur
Dépannage
Claude ne répond pas aux commandes @claude
- Vérifiez que votre pipeline est déclenché (manuellement, événement MR ou via un écouteur d’événements/webhook de note)
- Assurez-vous que les variables CI/CD (
ANTHROPIC_API_KEYou paramètres du fournisseur cloud) sont présentes et non masquées - Vérifiez que le commentaire contient
@claude(pas/claude) et que votre déclencheur de mention est configuré
Le travail ne peut pas écrire de commentaires ou ouvrir des MR
- Assurez-vous que
CI_JOB_TOKENdispose des autorisations suffisantes pour le projet, ou utilisez un jeton d’accès au projet avec la portéeapi - Vérifiez que l’outil
mcp__gitlabest activé dans--allowedTools - Confirmez que le travail s’exécute dans le contexte de la MR ou dispose de suffisamment de contexte via les variables
AI_FLOW_*
Erreurs d’authentification
- Pour Claude API : Confirmez que
ANTHROPIC_API_KEYest valide et non expiré - Pour Bedrock/Vertex : Vérifiez la configuration OIDC/WIF, l’emprunt d’identité de rôle et les noms secrets ; confirmez la disponibilité de la région et du modèle
Configuration avancée
Paramètres et variables courants
Claude Code prend en charge ces entrées couramment utilisées :prompt/prompt_file: Fournissez les instructions en ligne (-p) ou via un fichiermax_turns: Limitez le nombre d’itérations aller-retourtimeout_minutes: Limitez le temps d’exécution totalANTHROPIC_API_KEY: Requis pour l’API Claude (non utilisé pour Bedrock/Vertex)- Environnement spécifique au fournisseur :
AWS_REGION, variables de projet/région pour Vertex
Les drapeaux et paramètres exacts peuvent varier selon la version de
@anthropic-ai/claude-code. Exécutez claude --help dans votre travail pour voir les options prises en charge.Personnalisation du comportement de Claude
Vous pouvez guider Claude de deux manières principales :- CLAUDE.md : Définissez les normes de codage, les exigences de sécurité et les conventions du projet. Claude lit ceci lors des exécutions et suit vos règles.
- Invites personnalisées : Transmettez les instructions spécifiques à la tâche via
prompt/prompt_filedans le travail. Utilisez différentes invites pour différents travaux (par exemple, examen, implémentation, refactorisation).