Tests: Stub image request for dimensions (#8973)

no issue
- test cases were trying to fetch image sizes for `localhost:port/favicon.ico` but no server is running so they time out
- stub the `getImageSizeFromUrl` method so it resolves instantly
This commit is contained in:
Katharina Irrgang 2017-09-05 17:24:04 +02:00 committed by Kevin Ansfield
parent 5c2e1161f6
commit 1fe87a6110
3 changed files with 14 additions and 8 deletions

View File

@ -1,8 +1,7 @@
var Promise = require('bluebird'), var Promise = require('bluebird'),
sizeOf = require('./image-size'), imageSize = require('./image-size'),
logging = require('../logging'), logging = require('../logging'),
errors = require('../errors'), errors = require('../errors'),
getImageSizeFromUrl = sizeOf.getImageSizeFromUrl,
imageSizeCache = {}; imageSizeCache = {};
/** /**
@ -20,7 +19,7 @@ function getCachedImageSizeFromUrl(url) {
// image size is not in cache // image size is not in cache
if (!imageSizeCache[url]) { if (!imageSizeCache[url]) {
return getImageSizeFromUrl(url).then(function (res) { return imageSize.getImageSizeFromUrl(url).then(function (res) {
imageSizeCache[url] = res; imageSizeCache[url] = res;
return Promise.resolve(imageSizeCache[url]); return Promise.resolve(imageSizeCache[url]);

View File

@ -5,6 +5,7 @@ var should = require('should'), // jshint ignore:line
moment = require('moment'), moment = require('moment'),
configUtils = require('../../utils/configUtils'), configUtils = require('../../utils/configUtils'),
helpers = require('../../../server/helpers'), helpers = require('../../../server/helpers'),
imageSize = require('../../../server/utils/image-size'),
proxy = require('../../../server/helpers/proxy'), proxy = require('../../../server/helpers/proxy'),
settingsCache = proxy.settingsCache, settingsCache = proxy.settingsCache,
api = proxy.api, api = proxy.api,
@ -18,9 +19,15 @@ describe('{{ghost_head}} helper', function () {
configUtils.restore(); configUtils.restore();
}); });
// TODO: stub `getImageDimensions` to make things faster
beforeEach(function () { beforeEach(function () {
sandbox.stub(api.clients, 'read').returns(new Promise.resolve({ /**
* Each test case here requests the image dimensions.
* The image path is e.g. localhost:port/favicon.ico, but no server is running.
* If we don't mock the image size utility, we run into lot's of timeouts.
*/
sandbox.stub(imageSize, 'getImageSizeFromUrl').returns(Promise.resolve());
sandbox.stub(api.clients, 'read').returns(Promise.resolve({
clients: [ clients: [
{slug: 'ghost-frontend', secret: 'a1bcde23cfe5', status: 'enabled'} {slug: 'ghost-frontend', secret: 'a1bcde23cfe5', status: 'enabled'}
] ]

View File

@ -3,7 +3,7 @@ var should = require('should'),
Promise = require('bluebird'), Promise = require('bluebird'),
rewire = require('rewire'), rewire = require('rewire'),
// Stuff we are testing // Stuff we are testing
getCachedImageSizeFromUrl = rewire('../../../server/utils/cached-image-size-from-url'), getCachedImageSizeFromUrl = rewire('../../../server/utils/cached-image-size-from-url'),
sandbox = sinon.sandbox.create(); sandbox = sinon.sandbox.create();
@ -30,7 +30,7 @@ describe('getCachedImageSizeFromUrl', function () {
type: 'jpg' type: 'jpg'
})); }));
getCachedImageSizeFromUrl.__set__('getImageSizeFromUrl', sizeOfStub); getCachedImageSizeFromUrl.__set__('imageSize.getImageSizeFromUrl', sizeOfStub);
getCachedImageSizeFromUrl(url).then(function () { getCachedImageSizeFromUrl(url).then(function () {
// first call to get result from `getImageSizeFromUrl` // first call to get result from `getImageSizeFromUrl`
@ -61,7 +61,7 @@ describe('getCachedImageSizeFromUrl', function () {
sizeOfStub.returns(new Promise.reject('error')); sizeOfStub.returns(new Promise.reject('error'));
getCachedImageSizeFromUrl.__set__('getImageSizeFromUrl', sizeOfStub); getCachedImageSizeFromUrl.__set__('imageSize.getImageSizeFromUrl', sizeOfStub);
getCachedImageSizeFromUrl(url) getCachedImageSizeFromUrl(url)
.then(function () { .then(function () {