Tengo un servicio angular llamado 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
};
});
Estoy tratando de probar este servicio con jazmín:
"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();
});
});
Leí sobre el soporte asíncrono en Jasmine, pero como soy bastante nuevo en las pruebas unitarias con javascript no pude hacerlo funcionar.
Estoy recibiendo un error:
Async callback was not invoked within timeout specified by jasmine.DEFAULT_TIMEOUT_INTERVAL
y mi prueba está tardando demasiado en ejecutarse (aproximadamente 5 segundos).
¿Alguien puede ayudarme a proporcionar un ejemplo funcional de mi código con alguna explicación?
Jest
esperado , muy común al depurar y tomar algo de tiempo para inspeccionar las variables.
afterEach
paso que estaba limpiando la base de datos (usando el deleteMany
método). Agregar jest.setTimeout(30000);
el beforeAll
método parece haber solucionado esto para mí: supongo que dado que la eliminación de la base de datos es una llamada de red (dentro de la condición), a veces tomaba más de 3 segundos y se lanzaba.