Visão Geral
Para construir uma extensão robusta para o Discourse, pode ser aconselhável incluir Integração Contínua (CI) em seu plugin ou componente de tema. Isso ajudará a detectar erros precocemente e a diminuir as chances de bugs em seu código.
Configurar um fluxo de trabalho de Integração Contínua (CI) usando GitHub Actions para automatizar compilações e testes é uma abordagem que a equipe do Discourse usa em todos os nossos componentes, e recomendamos que você faça o mesmo.
Configurando
Para adicionar fluxos de trabalho automatizados para o GitHub Actions detectar, você precisa criar uma pasta .github/workflows no diretório raiz do seu repositório.
Dentro da pasta workflows, você pode definir um conjunto de automações que o GitHub Actions precisará executar. Por exemplo, estes podem ser arquivos .yml para linting e testes.
Criamos fluxos de trabalho de modelo para plugins e componentes de tema que você pode utilizar. Estes se conectam às nossas definições de ‘fluxo de trabalho reutilizável’ aqui.
No repositório de esqueleto do modelo, no GitHub, você pode clicar no botão Usar este modelo para criar um repositório de plugin/componente de tema baseado no modelo.
Alternativamente, se você já tem um projeto ao qual deseja adicionar os fluxos de trabalho, basta copiar o fluxo de trabalho relevante para a pasta .github/workflows/ do seu repositório:
Plugins: discourse-plugin.yml
Temas e Componentes de Tema: discourse-theme.yml
Esses modelos estão bloqueados para uma versão principal específica de nossos fluxos de trabalho reutilizáveis. Pequenas melhorias que fazemos nos fluxos de trabalho entrarão automaticamente em vigor em seu tema/plugin. Para alterações que quebram a compatibilidade (por exemplo, introduzindo um novo linter), aumentaremos a versão principal dos fluxos de trabalho reutilizáveis, e você precisará atualizar seu fluxo de trabalho para apontar para a nova versão.
Pronto! Você está configurado! Simplesmente, crie um commit ou um Pull Request (PR) para o seu repositório e o GitHub Actions detectará automaticamente os fluxos de trabalho e começará a executar os jobs.
O GitHub Actions mostrará uma análise de cada teste e, após a execução, indicará um
ou
dependendo se o teste passou ou falhou.
Se um teste falhou, clicar nos detalhes fornecerá algumas informações sobre o que falhou, o que pode dar pistas sobre o que está errado com seu código e o que precisa ser corrigido.
Adicione seus próprios testes
Para que os testes de plugins e componentes funcionem de forma eficaz, é importante que você escreva testes para seu plugin ou componente de tema.
Para detalhes sobre como escrever testes de front-end com EmberJS, consulte:
- Write acceptance tests and component tests for Ember code in Discourse
- Introduction - Testing - Ember Guides
Para mais detalhes sobre como escrever testes RSpec com Rails, consulte:
Exemplos
Para seu benefício, selecionamos alguns exemplos de plugins e componentes de tema que possuem testes robustos integrados:
| Plugin / Component | Testes do Lado do Cliente | Testes do Lado do Servidor |
|---|---|---|
| Assign | ||
| Calendar | ||
| Reactions | ||
| Right Sidebar Blocks | ||
| Tag Icons | ||
| Table Builder |
Este documento é controlado por versão - sugira alterações no github.
