Add tests for autolinker in BBCde::convert
This commit is contained in:
parent
792a0f11c0
commit
eec04b1864
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