Estoy probando unitariamente una de mis directivas (angularjs) usando grunt / karma / phantomjs / jasmine. Mis pruebas funcionan bien
describe('bar foo', function () {
beforeEach(inject(function ($rootScope, $compile) {
elm = angular.element('<img bar-foo src="img1.png"/>');
scope = $rootScope.$new();
$compile(elm)();
scope.$digest();
}));
....
});
pero consigo estos 404
WARN [web-server]: 404: /img1.png
WARN [web-server]: 404: /img2.png
...
Aunque no hacen nada, agregan ruido a la salida del registro. ¿Hay alguna forma de solucionar este problema? (sin cambiar el nivel de registro de karma, por supuesto, porque quiero verlos)
javascript
unit-testing
angularjs
http-status-code-404
karma-runner
Jeanluca Scaljeri
fuente
fuente
Respuestas:
Eso se debe a que necesita configurar karma para cargar y luego servirlos cuando se le solicite;)
En su archivo karma.conf.js ya debería tener archivos y / o patrones definidos como:
// list of files / patterns to load in the browser files : [ {pattern: 'app/lib/angular.js', watched: true, included: true, served: true}, {pattern: 'app/lib/angular-*.js', watched: true, included: true, served: true}, {pattern: 'app/lib/**/*.js', watched: true, included: true, served: true}, {pattern: 'app/js/**/*.js', watched: true, included: true, served: true}, // add the line below with the correct path pattern for your case {pattern: 'path/to/**/*.png', watched: false, included: false, served: true}, // important: notice that "included" must be false to avoid errors // otherwise Karma will include them as scripts {pattern: 'test/lib/**/*.js', watched: true, included: true, served: true}, {pattern: 'test/unit/**/*.js', watched: true, included: true, served: true}, ], // list of files to exclude exclude: [ ], // ...
Puedes echar un vistazo aquí para más información :)
EDITAR: Si usa un servidor web nodejs para ejecutar su aplicación, puede agregar esto a karma.conf.js:
proxies: { '/path/to/img/': 'http://localhost:8000/path/to/img/' },
EDIT2: Si no usa o no desea usar otro servidor, puede definir un proxy local, pero como Karma no proporciona acceso al puerto en uso, dinámicamente, si karma comienza en otro puerto que no sea 9876 (predeterminado), aún lo hará conseguir esos molestos 404 ...
proxies = { '/images/': '/base/images/' };
Problema relacionado: https://github.com/karma-runner/karma/issues/872
fuente
port: 9999
)proxies = { '/images/': 'http://localhost:9999/base/images/' };
La pieza confusa del rompecabezas para mí fue la carpeta virtual "base". Si no sabe que debe incluirse en las rutas de activos de sus dispositivos, le resultará difícil depurarlo.
Según la documentación de configuración
Nota: esto puede no ser cierto para otras versiones: estoy en 0.12.14 y funcionó para mí, pero los documentos 0.10 no lo mencionan.
Después de especificar el patrón de archivos:
{ pattern: 'Test/images/*.gif', watched: false, included: false, served: true, nocache: false },
Podría usar esto en mi accesorio:
<img src="base/Test/images/myimage.gif" />
Y no necesitaba el proxy en ese momento.
fuente
Puede crear middleware genérico dentro de su karma.conf.js, un poco exagerado, pero hizo el trabajo por mí
Primero defina imágenes ficticias de 1px (he usado base64):
const DUMMIES = { png: { base64: '', type: 'image/png' }, jpg: { base64: '', type: 'image/jpeg' }, gif: { base64: '', type: 'image/gif' } };
Luego defina la función de middleware:
function surpassImage404sMiddleware(req, res, next) { const imageExt = req.url.split('.').pop(); const dummy = DUMMIES[imageExt]; if (dummy) { // Table of files to ignore const imgPaths = ['/another-cat-image.png']; const isFakeImage = imgPaths.indexOf(req.url) !== -1; // URL to ignore const isCMSImage = req.url.indexOf('/cms/images/') !== -1; if (isFakeImage || isCMSImage) { const img = Buffer.from(dummy.base64, 'base64'); res.writeHead(200, { 'Content-Type': dummy.type, 'Content-Length': img.length }); return res.end(img); } } next(); }
Aplicar middleware en su configuración de karma
{ basePath: '', frameworks: ['jasmine', '@angular/cli'], middleware: ['surpassImage404sMiddleware'], plugins: [ ... {'middleware:surpassImage404sMiddleware': ['value', surpassImage404sMiddleware]} ], ... }
fuente
req.headers.accept
si contieneimage
y devuelva 204 si lo hace.Según la respuesta de @ glepretre, creé un archivo .png vacío y lo agregué a la configuración para ocultar las advertencias 404:
proxies: { '/img/generic.png': 'test/assets/img/generic.png' }
fuente
Para solucionarlo,
karma.conf.js
asegúrese de señalar el archivo servido con sus proxies:files: [ { pattern: './src/img/fake.jpg', watched: false, included: false, served: true }, ], proxies: { '/image.jpg': '/base/src/img/fake.jpg', '/fake-avatar': '/base/src/img/fake.jpg', '/folder/0x500.jpg': '/base/src/img/fake.jpg', '/undefined': '/base/src/img/fake.jpg' }
fuente
A pesar de que es un hilo antiguo, me tomó un par de horas lograr que mi imagen fuera realmente servida por el karma para eliminar el 404. Los comentarios no fueron lo suficientemente completos. Creo que puedo aclarar la solución con esta captura de pantalla. Básicamente, lo único que faltaba en muchos comentarios es el hecho de que el valor del proxy debe comenzar con "/ base" , aunque la base no está en ninguna de las rutas de mi carpeta, ni en mis solicitudes.
("base" sin la barra inclinada hacia adelante resultó en que el karma devolviera un 400 MALA PETICIÓN)
Ahora, después de ejecutar la prueba ng , puedo servir correctamente "./src/assets/favicon.png" desde la URL: http: // localhost: 9876 / test / dummy.png
En mi proyecto, estoy usando las siguientes versiones del paquete npm:
fuente
Si tiene una ruta raíz en algún lugar de su archivo de configuración, también puede usar algo como esto:
proxies: { '/bower_components/': config.root + '/client/bower_components/' }
fuente