diff --git a/ghost/oembed-service/lib/OEmbedService.js b/ghost/oembed-service/lib/OEmbedService.js index 7715cb1facb3..977a67edd629 100644 --- a/ghost/oembed-service/lib/OEmbedService.js +++ b/ghost/oembed-service/lib/OEmbedService.js @@ -238,11 +238,11 @@ class OEmbedService { scraperResponse = await metascraper({ html, url, - // In development, allow non-standard tlds + // In development, allow non-standard TLDs validateUrl: this.config.get('env') !== 'development' }); } catch (err) { - // Log to avoid being blind to errors happenning in metascraper + // Log to avoid being blind to errors happening in metascraper logging.error(err); return this.unknownProvider(url); } @@ -334,7 +334,7 @@ class OEmbedService { if (oembed.type === 'photo' && !oembed.url) { return; } - if ((oembed.type === 'video' || oembed.type === 'rich') && (!oembed.html || !oembed.width || !oembed.height)) { + if ((oembed.type === 'video' || oembed.type === 'rich') && (!oembed.html || !oembed.width)) { return; } diff --git a/ghost/oembed-service/test/oembed-service.test.js b/ghost/oembed-service/test/oembed-service.test.js index 1ada49a6fa75..d87d5fcdb9c7 100644 --- a/ghost/oembed-service/test/oembed-service.test.js +++ b/ghost/oembed-service/test/oembed-service.test.js @@ -1,5 +1,6 @@ const assert = require('assert/strict'); const nock = require('nock'); +const got = require('got'); const OembedService = require('../'); @@ -8,7 +9,12 @@ describe('oembed-service', function () { let oembedService; before(function () { - oembedService = new OembedService({}); + oembedService = new OembedService({ + config: {get() { + return true; + }}, + externalRequest: got + }); nock.disableNetConnect(); }); @@ -96,4 +102,34 @@ describe('oembed-service', function () { } }); }); + + describe('fetchOembedDataFromUrl', function () { + it('allows rich embeds to skip height field', async function () { + nock('https://www.example.com') + .get('/') + .query(true) + .reply(200, ``); + + nock('https://www.example.com') + .get('/oembed') + .query(true) + .reply(200, { + type: 'rich', + version: '1.0', + title: 'Test Title', + author_name: 'Test Author', + author_url: 'https://example.com/user/testauthor', + html: '', + width: 640, + height: null + }); + + const response = await oembedService.fetchOembedDataFromUrl('https://www.example.com'); + + assert.equal(response.title, 'Test Title'); + assert.equal(response.author_name, 'Test Author'); + assert.equal(response.author_url, 'https://example.com/user/testauthor'); + assert.equal(response.html, ''); + }); + }); });