Au lieu d’écrire des scripts shell pour installer des outils, vous pouvez faire directement référence à des GitHub Actions dans les sectionsDocumentation Index
Fetch the complete documentation index at: https://docs.devin.ai/llms.txt
Use this file to discover all available pages before exploring further.
initialize ou maintenance de votre blueprint. Devin télécharge et exécute l’action pendant le build du snapshot, de la même manière que les runners CI de GitHub exécutent les étapes d’une action.
C’est particulièrement utile pour les actions de configuration de langages comme setup-python, setup-node et setup-go, qui gèrent automatiquement les versions et la configuration du PATH.
Syntaxe
uses à n’importe quelle section de votre blueprint :
| Champ | Type | Description |
|---|---|---|
name | string (facultatif) | Libellé compréhensible par un humain affiché dans les logs du build |
uses | string | Référence de GitHub Action (voir le format ci-dessous) |
with | map (facultatif) | Paramètres d’entrée transmis à l’action |
env | map (facultatif) | Variables d’environnement supplémentaires pour l’étape |
Une étape doit spécifier soit
run (une commande shell), soit uses (une action), mais pas les deux.Format de référence d’action
github.com/ et le suffixe @<ref> sont tous deux obligatoires. La ref est généralement un tag de version comme v5.
Exemples :
| Référence | Ce à quoi elle correspond |
|---|---|
github.com/actions/setup-python@v5 | actions/setup-python au tag v5 |
github.com/actions/setup-node@v4 | actions/setup-node au tag v4 |
github.com/gradle/actions/setup-gradle@v4 | repo gradle/actions, sous-répertoire setup-gradle, tag v4 |
Transmission des paramètres d’entrée
with pour transmettre des paramètres d’entrée à l’action. Toutes les valeurs sont traitées comme des chaînes de caractères, conformément au comportement de GitHub Actions :
Définir des variables d’environnement
env pour définir des variables d’environnement dont le périmètre est limité à une seule étape d’action :
GITHUB_ENV ou GITHUB_PATH) sont automatiquement transmises aux étapes suivantes du blueprint.
Exemples
Projet Python avec une version spécifique
Projet multilingue
Mélanger des actions et des commandes shell
Projet Java avec Gradle
Actions ou scripts shell
- Avec GitHub Actions
- Script shell équivalent
Fonctionnement
uses lors d’un build du snapshot :
- Télécharge le dépôt de l’action (clone superficiel de la référence épinglée)
- Lit les métadonnées
action.ymlde l’action afin de déterminer l’environnement d’exécution et les points d’entrée - Construit l’environnement d’exécution avec les variables
INPUT_*,GITHUB_*etRUNNER_* - Exécute l’étape
prede l’action (si elle est définie), puis le point d’entréemain - Propage les effets de bord — toutes les entrées écrites dans
GITHUB_PATHouGITHUB_ENVpar l’action sont appliquées aux étapes de blueprint suivantes
Les actions s’exécutent en dehors d’un véritable workflow GitHub. Les variables de contexte comme
github.repository sont renseignées avec des valeurs factices. Les actions qui nécessitent un accès direct à l’API GitHub (p. ex., commenter des pull requests, créer des releases) ne fonctionneront pas dans les blueprints.Limitations
- Actions Node.js uniquement — Seules les GitHub Actions qui utilisent un environnement d’exécution Node.js (
node16,node20,node24) sont prises en charge. Les actions basées sur Docker et les actions composites ne sont pas prises en charge. - Pas de phase
post— Devin exécute les étapespreetmain, mais ignore les étapes de nettoyagepost, car les builds s’exécutent dans des VM temporaires. - Contexte GitHub simulé — Les actions qui s’appuient sur des appels d’API GitHub, des données d’événement de workflow ou le contexte du dépôt peuvent ne pas fonctionner correctement, car ces valeurs sont factices dans l’environnement de build.
- Figez vos versions — Utilisez toujours un tag de version spécifique (p. ex.,
@v5) plutôt qu’un nom de branche afin d’obtenir des builds reproductibles.
