From: Daniel Imms Date: Sat, 11 Jun 2016 01:53:32 +0000 (-0700) Subject: Add a bunch of tests X-Git-Url: https://git.proxmox.com/?a=commitdiff_plain;h=f2f0f460c4ecf5dd61097937bf4292cf77d516c7;p=mirror_xterm.js.git Add a bunch of tests --- diff --git a/addons/linkify/linkify.js b/addons/linkify/linkify.js index 344bc71..f02c202 100644 --- a/addons/linkify/linkify.js +++ b/addons/linkify/linkify.js @@ -91,22 +91,13 @@ continue; } + var url = exports.findLinkMatch(node.data, lenient); - if (lenient) { - match = node.data.match(lenientUrlRegex); - } else { - match = node.data.match(strictUrlRegex); - } - - /** - * If no URL was found in the current text, return. - */ - if (!match) { + if (!url) { continue; } - var url = match[1], - startsWithProtocol = new RegExp('^' + protocolClause), + var startsWithProtocol = new RegExp('^' + protocolClause), urlHasProtocol = url.match(startsWithProtocol), href = (urlHasProtocol) ? url : 'http://' + url, link = '' + url + '', @@ -125,6 +116,20 @@ terminal.emit('linkify:line', line); }; + /** + * Finds a link within a block of text. + * + * @param {string} text - The text to search . + * @param {boolean} lenient - Whether to use the lenient search. + * @return {string} A URL. + */ + exports.findLinkMatch = function (text, lenient) { + var match = text.match(lenient ? lenientUrlRegex : strictUrlRegex); + if (!match || match.length === 0) { + return null; + } + return match[1]; + } /** * Converts all valid URLs found in the terminal view into hyperlinks. diff --git a/package.json b/package.json index 73fde3c..f1d3e57 100644 --- a/package.json +++ b/package.json @@ -14,6 +14,6 @@ }, "scripts": { "start": "bash bin/server", - "test": "bash bin/test" + "test": "bash bin/test --recursive" } } diff --git a/test/addons/linkify-test.js b/test/addons/linkify-test.js new file mode 100644 index 0000000..7cb2318 --- /dev/null +++ b/test/addons/linkify-test.js @@ -0,0 +1,48 @@ +var assert = require('chai').assert; +var Terminal = require('../../src/xterm'); +var linkify = require('../../addons/linkify/linkify'); + +describe('linkify addon', function () { + var xterm; + + describe('API', function () { + it('should define Terminal.prototype.linkify', function () { + assert.isDefined(Terminal.prototype.linkify); + }); + it('should define Terminal.prototype.linkifyTerminalLine', function () { + assert.isDefined(Terminal.prototype.linkifyTerminalLine); + }); + }); + + describe('findUrlMatchOnLine', function () { + describe('strict regex', function () { + it('should match when the entire text is a match', function () { + assert.equal(linkify.findLinkMatch('http://github.com', false), 'http://github.com'); + assert.equal(linkify.findLinkMatch('http://127.0.0.1', false), 'http://127.0.0.1'); + }); + it('should match simple domains', function () { + assert.equal(linkify.findLinkMatch('foo http://github.com bar', false), 'http://github.com'); + assert.equal(linkify.findLinkMatch('foo http://www.github.com bar', false), 'http://www.github.com'); + assert.equal(linkify.findLinkMatch('foo https://github.com bar', false), 'https://github.com'); + assert.equal(linkify.findLinkMatch('foo https://www.github.com bar', false), 'https://www.github.com'); + }); + it('should match web addresses with alpha paths', function () { + assert.equal(linkify.findLinkMatch('foo http://github.com/a/b/c bar', false), 'http://github.com/a/b/c'); + assert.equal(linkify.findLinkMatch('foo http://www.github.com/a/b/c bar', false), 'http://www.github.com/a/b/c'); + }); + it('should not include whitespace surrounding a match', function () { + assert.equal(linkify.findLinkMatch(' http://github.com', false), 'http://github.com'); + assert.equal(linkify.findLinkMatch('http://github.com ', false), 'http://github.com'); + assert.equal(linkify.findLinkMatch(' http://github.com ', false), 'http://github.com'); + }); + it('should match IP addresses', function () { + assert.equal(linkify.findLinkMatch('foo http://127.0.0.1 bar', false), 'http://127.0.0.1'); + assert.equal(linkify.findLinkMatch('foo https://127.0.0.1 bar', false), 'https://127.0.0.1'); + }); + it('should match ports on both domains and IP addresses', function () { + assert.equal(linkify.findLinkMatch('foo http://127.0.0.1:8080 bar', false), 'http://127.0.0.1:8080'); + assert.equal(linkify.findLinkMatch('foo http://www.github.com:8080 bar', false), 'http://www.github.com:8080'); + }); + }); + }); +});