Eu tenho um serviço angular chamado requestNotificationChannel
:
app.factory("requestNotificationChannel", function($rootScope) {
var _DELETE_MESSAGE_ = "_DELETE_MESSAGE_";
function deleteMessage(id, index) {
$rootScope.$broadcast(_DELETE_MESSAGE_, { id: id, index: index });
};
return {
deleteMessage: deleteMessage
};
});
Eu estou tentando testar este serviço usando o jasmim:
"use strict";
describe("Request Notification Channel", function() {
var requestNotificationChannel, rootScope, scope;
beforeEach(function(_requestNotificationChannel_) {
module("messageAppModule");
inject(function($injector, _requestNotificationChannel_) {
rootScope = $injector.get("$rootScope");
scope = rootScope.$new();
requestNotificationChannel = _requestNotificationChannel_;
})
spyOn(rootScope, '$broadcast');
});
it("should broadcast delete message notification", function(done) {
requestNotificationChannel.deleteMessage(1, 4);
expect(rootScope.$broadcast).toHaveBeenCalledWith("_DELETE_MESSAGE_", { id: 1, index: 4 });
done();
});
});
Eu li sobre o Suporte assíncrono no Jasmine, mas como eu sou novo no teste de unidade com javascript, não poderia fazê-lo funcionar.
Estou recebendo um erro:
Async callback was not invoked within timeout specified by jasmine.DEFAULT_TIMEOUT_INTERVAL
e meu teste está demorando muito para ser executado (cerca de 5s).
Alguém pode me ajudar a fornecer um exemplo prático do meu código com alguma explicação?
Jest
esperado - muito comum durante a depuração e o tempo necessário para inspecionar variáveis.
afterEach
etapa que estava limpando o banco de dados (usando o deleteMany
método). A adição jest.setTimeout(30000);
do beforeAll
método parece ter corrigido isso para mim - acho que, como a exclusão do banco de dados é uma chamada de rede (dentro da condição), às vezes levava mais de 3 segundos e o lançamento.