Configurer l'intégration continue en utilisant GitHub Actions

:mag: Vue d’ensemble

Pour créer une extension robuste pour Discourse, il est judicieux d’inclure l’intégration continue (CI) dans votre composant de plugin ou de thème. Cela aidera à détecter les erreurs tôt et à réduire les chances de bogues dans votre code.

La mise en place d’un flux de travail d’intégration continue (CI) à l’aide de GitHub Actions pour automatiser les builds et les tests est une approche que l’équipe Discourse utilise sur tous nos composants, et nous vous recommandons de faire de même.

:gear: Mise en place

Pour ajouter des flux de travail automatisés que GitHub Actions pourra détecter, vous devez créer un dossier .github/workflows dans le répertoire racine de votre dépôt.

À l’intérieur du dossier workflows, vous pouvez définir un ensemble d’automatisations que GitHub Actions devra exécuter. Par exemple, il pourrait s’agir de fichiers .yml pour le linting et les tests.

Nous avons créé des flux de travail modèles pour les plugins et les composants de thème que vous pouvez utiliser. Ceux-ci se connectent à nos définitions de « flux de travail réutilisables » ici.

Dans le dépôt squelette du modèle, sur GitHub, vous pouvez cliquer sur le bouton Utiliser ce modèle pour créer un dépôt de plugin/composant de thème basé sur le modèle.

Alternativement, si vous avez déjà un projet auquel vous souhaitez ajouter les flux de travail, copiez simplement le flux de travail pertinent dans le dossier .github/workflows/ de votre dépôt :

:electric_plug: Plugins : discourse-plugin.yml

:jigsaw: Thèmes et Composants de Thème : discourse-theme.yml

:point_up: Ces modèles sont verrouillés sur une version majeure spécifique de nos flux de travail réutilisables. Les petites améliorations que nous apportons aux flux de travail prendront automatiquement effet dans votre thème/plugin. Pour les changements majeurs (par exemple, l’introduction d’un nouveau linter), nous augmenterons la version majeure des flux de travail réutilisables, et vous devrez mettre à jour votre flux de travail pour qu’il pointe vers la nouvelle version.

:tada: Voilà ! Vous êtes prêt ! Créez simplement un commit ou une demande de tirage (PR) vers votre dépôt et GitHub Actions détectera automatiquement les flux de travail et commencera à exécuter les tâches.

GitHub Actions affichera une ventilation de chaque test et, après l’exécution, indiquera soit :white_check_mark: soit :x: selon que le test a réussi ou échoué.

Si un test a échoué, cliquer sur les détails vous donnera des informations sur ce qui a échoué, ce qui peut vous donner des indices sur ce qui ne va pas dans votre code et ce qui doit être corrigé.

Voir l'exemple

:white_check_mark: Ajoutez vos propres tests

Pour que les tests de plugins et de composants fonctionnent efficacement, il est important que vous écriviez des tests pour votre plugin ou composant de thème.

Pour plus de détails sur la façon d’écrire des tests front-end avec EmberJS, consultez :

Pour plus de détails sur la façon d’écrire des tests RSpec avec Rails, consultez :

:bulb: Exemples

Pour votre bénéfice, nous avons sélectionné quelques exemples de plugins et de composants de thème qui intègrent des tests robustes :


Ce document est contrôlé par version - suggérez des modifications sur github.

15 « J'aime »