mirror of
https://github.com/showdownjs/showdown.git
synced 2024-03-22 13:30:55 +08:00
fix(helpers): update octocat emoji image location; add tests
This commit is contained in:
parent
f9d9705d3c
commit
5544e4d995
|
@ -1710,6 +1710,6 @@ showdown.helper.emojis = {
|
||||||
'zzz':'\ud83d\udca4',
|
'zzz':'\ud83d\udca4',
|
||||||
|
|
||||||
/* special emojis :P */
|
/* special emojis :P */
|
||||||
'octocat': '<img width="20" height="20" align="absmiddle" src="https://assets-cdn.github.com/images/icons/emoji/octocat.png">',
|
'octocat': '<img width="20" height="20" align="absmiddle" src="https://github.githubassets.com/images/icons/emoji/octocat.png">',
|
||||||
'showdown': '<img width="20" height="20" align="absmiddle" src="">'
|
'showdown': '<img width="20" height="20" align="absmiddle" src="">'
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,2 +1,2 @@
|
||||||
<p>this is showdown's emoji <img width="20" height="20" align="absmiddle" src=""></p>
|
<p>this is showdown's emoji <img width="20" height="20" align="absmiddle" src=""></p>
|
||||||
<p>and this is github's emoji <img width="20" height="20" align="absmiddle" src="https://assets-cdn.github.com/images/icons/emoji/octocat.png"></p>
|
<p>and this is github's emoji <img width="20" height="20" align="absmiddle" src="https://github.githubassets.com/images/icons/emoji/octocat.png"></p>
|
||||||
|
|
|
@ -18,7 +18,10 @@ var bootstrap = require('./makehtml.bootstrap.js'),
|
||||||
//literalMidWordAsterisksSuite = bootstrap.getTestSuite('test/functional/makehtml/cases/features/literalMidWordAsterisks/'),
|
//literalMidWordAsterisksSuite = bootstrap.getTestSuite('test/functional/makehtml/cases/features/literalMidWordAsterisks/'),
|
||||||
completeHTMLOutputSuite = bootstrap.getTestSuite('test/functional/makehtml/cases/features/completeHTMLOutput/'),
|
completeHTMLOutputSuite = bootstrap.getTestSuite('test/functional/makehtml/cases/features/completeHTMLOutput/'),
|
||||||
metadataSuite = bootstrap.getTestSuite('test/functional/makehtml/cases/features/metadata/'),
|
metadataSuite = bootstrap.getTestSuite('test/functional/makehtml/cases/features/metadata/'),
|
||||||
splitAdjacentBlockquotesSuite = bootstrap.getTestSuite('test/functional/makehtml/cases/features/splitAdjacentBlockquotes/');
|
splitAdjacentBlockquotesSuite = bootstrap.getTestSuite('test/functional/makehtml/cases/features/splitAdjacentBlockquotes/'),
|
||||||
|
http = require('http'),
|
||||||
|
https = require('https'),
|
||||||
|
expect = require('chai').expect;
|
||||||
|
|
||||||
describe('makeHtml() features testsuite', function () {
|
describe('makeHtml() features testsuite', function () {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
@ -190,7 +193,31 @@ describe('makeHtml() features testsuite', function () {
|
||||||
/** test emojis support **/
|
/** test emojis support **/
|
||||||
describe('emojis support', function () {
|
describe('emojis support', function () {
|
||||||
var converter,
|
var converter,
|
||||||
suite = emojisSuite;
|
suite = emojisSuite,
|
||||||
|
imgSrcRegexp = /<img[^>]+src=("https?:\/\/[^"]+"|'https?:\/\/[^']+')/g;
|
||||||
|
|
||||||
|
function testImageUrlExists (imgUrl) {
|
||||||
|
// Strip the quotes
|
||||||
|
imgUrl = imgUrl.substr(0, imgUrl.length - 1).substr(1);
|
||||||
|
return function (done) {
|
||||||
|
(imgUrl.startsWith('http://') ? http : https).get(imgUrl, function (res) {
|
||||||
|
expect(res.statusCode).to.equal(200);
|
||||||
|
// Make sure we get some data and that it's a png
|
||||||
|
expect(parseInt(res.headers['content-length'], 10)).to.be.above(0);
|
||||||
|
expect(res.headers['content-type']).to.equal('image/png');
|
||||||
|
|
||||||
|
// Discard the data (but fetch it)
|
||||||
|
res.on('data', function () {});
|
||||||
|
|
||||||
|
res.on('end', function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
}).on('error', function (e) {
|
||||||
|
throw e;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
for (var i = 0; i < suite.length; ++i) {
|
for (var i = 0; i < suite.length; ++i) {
|
||||||
if (suite[i].name === 'simplifiedautolinks') {
|
if (suite[i].name === 'simplifiedautolinks') {
|
||||||
converter = new showdown.Converter({emoji: true, simplifiedAutoLink: true});
|
converter = new showdown.Converter({emoji: true, simplifiedAutoLink: true});
|
||||||
|
@ -199,6 +226,11 @@ describe('makeHtml() features testsuite', function () {
|
||||||
}
|
}
|
||||||
|
|
||||||
it(suite[i].name.replace(/-/g, ' '), assertion(suite[i], converter));
|
it(suite[i].name.replace(/-/g, ' '), assertion(suite[i], converter));
|
||||||
|
|
||||||
|
var imgUrl = imgSrcRegexp.exec(suite[i].expected);
|
||||||
|
if (imgUrl) {
|
||||||
|
it('should use a working emoji URL', testImageUrlExists(imgUrl[1]));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user