O tutorial anterior: Developing Discourse Plugins - Part 5 - Add an admin interface
Você sabia que o Discourse tem dois grandes conjuntos de testes para sua base de código? No lado do servidor, nosso código Ruby tem um conjunto de testes que usa o rspec. Para o aplicativo do navegador, temos um conjunto de testes qunit que inclui o ember-testing.
Assumindo que você tenha um ambiente de desenvolvimento configurado, se você visitar o URL http://localhost:4200/tests, começará a executar o conjunto de testes JavaScript em seu navegador. Um aspecto interessante é que você pode vê-lo testando o aplicativo em uma janela miniatura no canto inferior direito:
O aplicativo Discourse é construído com muitos testes que começarão a ser executados quando você visitar o URL /tests. Portanto, pode ser útil filtrar seus testes pelo plugin no qual você está trabalhando. Você pode fazer isso na interface clicando no menu suspenso Plugin e selecionando seu plugin:
Adicionando um Teste de Aceitação em seu Plugin
Primeiro, certifique-se de ter a versão mais recente do Discourse extraída. Ser capaz de executar testes de Aceitação de plugins é um recurso relativamente novo e, se você não extrair a versão mais recente, seus testes não aparecerão.
Para este artigo, vou escrever um teste de aceitação para o plugin purple-tentacle que criamos na parte 5 desta série.
Adicionar um teste de aceitação é tão fácil quanto adicionar um arquivo ao seu plugin. Crie o seguinte:
test/javascripts/acceptance/purple-tentacle-test.js
import { acceptance, exists } from "discourse/tests/helpers/qunit-helpers";
import { click, visit } from "@ember/test-helpers";
import { test } from "qunit";
acceptance("Purple Tentacle", function (needs) {
needs.settings({ purple_tentacle_enabled: true });
needs.user();
test("Purple tentacle button works", async function (assert) {
await visit("/admin/plugins/purple-tentacle");
assert.ok(exists("#show-tentacle"), "it shows the purple tentacle button");
assert.ok(!exists(".tentacle"), "the tentacle is not shown yet");
await click("#show-tentacle");
assert.ok(exists(".tentacle"), "the tentacle wants to rule the world!");
});
});
Eu tentei escrever o teste de uma forma clara, mas pode ser um pouco confuso se você nunca escreveu um teste de aceitação antes. Eu altamente recomendo que você leia a documentação do Ember sobre testes de aceitação, pois eles têm muitas ótimas informações.
Em cada teste que escrevemos, precisamos assert (afirmar) algo. Em nosso teste, queremos fazer algumas afirmações para verificar se o tentáculo está oculto inicialmente e só é mostrado depois de clicar no botão.
Queremos definir um conjunto de ações a serem tomadas antes que uma afirmação seja feita. Para fazer isso, usamos a palavra-chave await. Ao usar essa palavra-chave, esperamos que a execução de cada helper assíncrono termine primeiro.
Nossa primeira ação de importância é: await visit("/admin/plugins/purple-tentacle");. Isso diz ao nosso teste para navegar para aquele URL em nosso aplicativo. Aquele URL era o que exibia o tentáculo.
Depois de visitar a página onde o botão do tentáculo roxo aparece, queremos verificar se conseguimos ver que o botão na página existe e que a imagem do tentáculo ainda não existe.
Isso é feito pelas seguintes afirmações:
assert.ok(exists("#show-tentacle"), "it shows the purple tentacle button");
assert.ok(!exists(".tentacle"), "the tentacle is not shown yet");
P.S. a versão anterior do plugin purple-tentacle não tinha o ID do elemento #show-tentacle no template handlebars. Verifique a versão mais recente para acompanhar!
Assim que esses testes passarem, é hora de testar a interação.
O próximo comando é await click('#show-tentacle');, que diz ao nosso framework de teste que queremos clicar no botão e mostrar o tentáculo.
Depois de simular um clique no botão, podemos verificar se o tentáculo aparece afirmando:
assert.ok(exists(".tentacle"), "the tentacle wants to rule the world!");
Não é tão ruim, é? Você pode tentar o teste você mesmo visitando http://localhost:4200/tests?qunit_single_plugin=purple-tentacle&qunit_skip_core=1 em sua máquina de desenvolvimento. Você deverá ver muito rapidamente o tentáculo roxo aparecer e todos os testes passarão.
Se você quiser executar os testes qunit do plugin na linha de comando usando PhantomJS, você pode executar
rake plugin:qunit['purple-tentacle']
(onde purple-tentacle é o nome da pasta do seu plugin)
Depurando seus testes
Ao escrever seus plugins, seus testes podem ajudá-lo a identificar problemas em seu plugin. Ao desenvolver seus testes ou ao fazer alterações no código do seu plugin, os testes podem falhar. Para ajudar a entender o porquê, o Ember tem alguns helpers úteis: pauseTest() e resumeTest().
Para usá-los, adicione await pauseTest() dentro do código do seu teste onde você gostaria que o teste pausasse. Agora, quando você executa seu teste no navegador, o teste pausará automaticamente no ponto em que você adicionou pauseTest(). Isso lhe dará uma chance de inspecionar a página ou visualizar quaisquer erros para ajudar na depuração de problemas.
Para onde ir a partir daqui
Eu odeio soar como um disco riscado, mas a documentação do Ember sobre testes é excelente. Você também pode querer ver como o Discourse testa várias funcionalidades navegando pelos testes em nosso diretório de testes javascript. Temos muitos exemplos lá que você pode aprender.
Feliz testando!
Mais na série
Parte 1: Noções Básicas de Plugin
Parte 2: Plugin Outlets
Parte 3: Configurações do Site
Parte 4: Configuração do git
Parte 5: Interfaces de Administrador
Parte 6: Este tópico
Parte 7: Publique seu plugin
Este documento é controlado por versão - sugira alterações no github.



)