Merge pull request #6841 from MrPetovan/bug/2487-fix-autolinker
Add tests to autolinker + regex fix
This commit is contained in:
commit
d67ae7cbdd
2 changed files with 113 additions and 7 deletions
|
@ -1275,20 +1275,15 @@ class BBCode extends BaseObject
|
|||
( # Capture 1: entire matched URL
|
||||
https?:// # http or https protocol
|
||||
(?:
|
||||
www\d{0,3}[.] # "www.", "www1.", "www2." … "www999."
|
||||
| # or
|
||||
[a-z0-9.\-]+[.][a-z]{2,4}/ # looks like domain name followed by a slash
|
||||
[^/.][^/]+[.][^/]+/? # looks like domain name followed by a slash
|
||||
)
|
||||
(?: # One or more:
|
||||
[^\s()<>]+ # Run of non-space, non-()<>
|
||||
| # or
|
||||
\(([^\s()<>]+|(\([^\s()<>]+\)))*\) # balanced parens, up to 2 levels
|
||||
)+
|
||||
(?: # End with:
|
||||
\(([^\s()<>]+|(\([^\s()<>]+\)))*\) # balanced parens, up to 2 levels
|
||||
| # or
|
||||
[^\s`!()\[\]{};:\'".,<>?«»“”‘’] # not a space or one of these punct chars
|
||||
)
|
||||
)*
|
||||
)@';
|
||||
$text = preg_replace($autolink_regex, '[url]$1[/url]', $text);
|
||||
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