Merge pull request #6841 from MrPetovan/bug/2487-fix-autolinker
Add tests to autolinker + regex fix
This commit is contained in:
commit
d67ae7cbdd
|
@ -1275,20 +1275,15 @@ class BBCode extends BaseObject
|
||||||
( # Capture 1: entire matched URL
|
( # Capture 1: entire matched URL
|
||||||
https?:// # http or https protocol
|
https?:// # http or https protocol
|
||||||
(?:
|
(?:
|
||||||
www\d{0,3}[.] # "www.", "www1.", "www2." … "www999."
|
[^/.][^/]+[.][^/]+/? # looks like domain name followed by a slash
|
||||||
| # or
|
|
||||||
[a-z0-9.\-]+[.][a-z]{2,4}/ # looks like domain name followed by a slash
|
|
||||||
)
|
)
|
||||||
(?: # One or more:
|
(?: # One or more:
|
||||||
[^\s()<>]+ # Run of non-space, non-()<>
|
[^\s()<>]+ # Run of non-space, non-()<>
|
||||||
| # or
|
| # or
|
||||||
\(([^\s()<>]+|(\([^\s()<>]+\)))*\) # balanced parens, up to 2 levels
|
\(([^\s()<>]+|(\([^\s()<>]+\)))*\) # balanced parens, up to 2 levels
|
||||||
)+
|
|
||||||
(?: # End with:
|
|
||||||
\(([^\s()<>]+|(\([^\s()<>]+\)))*\) # balanced parens, up to 2 levels
|
|
||||||
| # or
|
| # or
|
||||||
[^\s`!()\[\]{};:\'".,<>?«»“”‘’] # not a space or one of these punct chars
|
[^\s`!()\[\]{};:\'".,<>?«»“”‘’] # not a space or one of these punct chars
|
||||||
)
|
)*
|
||||||
)@';
|
)@';
|
||||||
$text = preg_replace($autolink_regex, '[url]$1[/url]', $text);
|
$text = preg_replace($autolink_regex, '[url]$1[/url]', $text);
|
||||||
if ($simple_html == 7) {
|
if ($simple_html == 7) {
|
||||||
|
|
111
tests/src/Content/Text/BBCodeTest.php
Normal file
111
tests/src/Content/Text/BBCodeTest.php
Normal file
|
@ -0,0 +1,111 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Friendica\Test\src\Content\Text;
|
||||||
|
|
||||||
|
use Friendica\Content\Text\BBCode;
|
||||||
|
use Friendica\Test\MockedTest;
|
||||||
|
use Friendica\Test\Util\AppMockTrait;
|
||||||
|
use Friendica\Test\Util\L10nMockTrait;
|
||||||
|
use Friendica\Test\Util\VFSTrait;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @runTestsInSeparateProcesses
|
||||||
|
* @preserveGlobalState disabled
|
||||||
|
*/
|
||||||
|
class BBCodeTest extends MockedTest
|
||||||
|
{
|
||||||
|
use VFSTrait;
|
||||||
|
use AppMockTrait;
|
||||||
|
use L10nMockTrait;
|
||||||
|
|
||||||
|
protected function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
$this->setUpVfsDir();
|
||||||
|
$this->mockApp($this->root);
|
||||||
|
$this->app->videowidth = 425;
|
||||||
|
$this->app->videoheight = 350;
|
||||||
|
$this->configMock->shouldReceive('get')
|
||||||
|
->with('system', 'remove_multiplicated_lines')
|
||||||
|
->andReturn(false);
|
||||||
|
$this->configMock->shouldReceive('get')
|
||||||
|
->with('system', 'no_oembed')
|
||||||
|
->andReturn(false);
|
||||||
|
$this->configMock->shouldReceive('get')
|
||||||
|
->with('system', 'allowed_link_protocols')
|
||||||
|
->andReturn(null);
|
||||||
|
$this->configMock->shouldReceive('get')
|
||||||
|
->with('system', 'itemcache_duration')
|
||||||
|
->andReturn(-1);
|
||||||
|
$this->mockL10nT();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function dataLinks()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
/** @see https://github.com/friendica/friendica/issues/2487 */
|
||||||
|
'bug-2487-1' => [
|
||||||
|
'data' => 'https://de.wikipedia.org/wiki/Juha_Sipilä',
|
||||||
|
'assertHTML' => true,
|
||||||
|
],
|
||||||
|
'bug-2487-2' => [
|
||||||
|
'data' => 'https://de.wikipedia.org/wiki/Dnepr_(Motorradmarke)',
|
||||||
|
'assertHTML' => true,
|
||||||
|
],
|
||||||
|
'bug-2487-3' => [
|
||||||
|
'data' => 'https://friendica.wäckerlin.ch/friendica',
|
||||||
|
'assertHTML' => true,
|
||||||
|
],
|
||||||
|
'bug-2487-4' => [
|
||||||
|
'data' => 'https://mastodon.social/@morevnaproject',
|
||||||
|
'assertHTML' => true,
|
||||||
|
],
|
||||||
|
/** @see https://github.com/friendica/friendica/issues/5795 */
|
||||||
|
'bug-5795' => [
|
||||||
|
'data' => 'https://social.nasqueron.org/@liw/100798039015010628',
|
||||||
|
'assertHTML' => true,
|
||||||
|
],
|
||||||
|
/** @see https://github.com/friendica/friendica/issues/6095 */
|
||||||
|
'bug-6095' => [
|
||||||
|
'data' => 'https://en.wikipedia.org/wiki/Solid_(web_decentralization_project)',
|
||||||
|
'assertHTML' => true,
|
||||||
|
],
|
||||||
|
'no-protocol' => [
|
||||||
|
'data' => 'example.com/path',
|
||||||
|
'assertHTML' => false
|
||||||
|
],
|
||||||
|
'wrong-protocol' => [
|
||||||
|
'data' => 'ftp://example.com',
|
||||||
|
'assertHTML' => false
|
||||||
|
],
|
||||||
|
'wrong-domain-without-path' => [
|
||||||
|
'data' => 'http://example',
|
||||||
|
'assertHTML' => false
|
||||||
|
],
|
||||||
|
'wrong-domain-with-path' => [
|
||||||
|
'data' => 'http://example/path',
|
||||||
|
'assertHTML' => false
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test convert different links inside a text
|
||||||
|
* @dataProvider dataLinks
|
||||||
|
*
|
||||||
|
* @param string $data The data to text
|
||||||
|
* @param bool $assertHTML True, if the link is a HTML link (<a href...>...</a>)
|
||||||
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
|
*/
|
||||||
|
public function testAutoLinking($data, $assertHTML)
|
||||||
|
{
|
||||||
|
$output = BBCode::convert($data);
|
||||||
|
if ($assertHTML) {
|
||||||
|
$assert = '<a href="' . $data . '" target="_blank">' . $data . '</a>';
|
||||||
|
} else {
|
||||||
|
$assert = $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->assertEquals($assert, $output);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue