2019-10-23 00:40:14 +02:00
|
|
|
<?php
|
2020-02-09 15:45:36 +01:00
|
|
|
/**
|
|
|
|
* @copyright Copyright (C) 2020, Friendica
|
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
2019-10-23 00:40:14 +02:00
|
|
|
|
|
|
|
namespace Friendica\Test\src\Util;
|
|
|
|
|
2019-10-28 18:16:10 +01:00
|
|
|
use Error;
|
2019-10-23 00:40:14 +02:00
|
|
|
use Friendica\Model\Group;
|
|
|
|
use Friendica\Util\ACLFormatter;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
|
|
|
/**
|
2020-01-19 07:05:23 +01:00
|
|
|
* ACLFormater utility testing class
|
2019-10-23 00:40:14 +02:00
|
|
|
*/
|
|
|
|
class ACLFormaterTest extends TestCase
|
|
|
|
{
|
2019-11-01 15:43:16 +01:00
|
|
|
public function assertAcl($text, array $assert = [])
|
2019-10-23 00:40:14 +02:00
|
|
|
{
|
|
|
|
$aclFormatter = new ACLFormatter();
|
|
|
|
|
2019-11-01 15:43:16 +01:00
|
|
|
$acl = $aclFormatter->expand($text);
|
2019-10-23 00:40:14 +02:00
|
|
|
|
2019-11-01 15:43:16 +01:00
|
|
|
$this->assertEquals($assert, $acl);
|
2019-10-23 00:40:14 +02:00
|
|
|
|
2019-11-01 15:43:16 +01:00
|
|
|
$this->assertMergable($acl);
|
2019-10-23 00:40:14 +02:00
|
|
|
}
|
|
|
|
|
2019-11-01 15:43:16 +01:00
|
|
|
public function assertMergable(array $aclOne, array $aclTwo = [])
|
2019-10-23 00:40:14 +02:00
|
|
|
{
|
2019-11-01 15:43:16 +01:00
|
|
|
$this->assertTrue(is_array($aclOne));
|
|
|
|
$this->assertTrue(is_array($aclTwo));
|
2019-10-23 00:40:14 +02:00
|
|
|
|
2019-11-01 15:43:16 +01:00
|
|
|
$aclMerged = array_unique(array_merge($aclOne, $aclTwo));
|
|
|
|
$this->assertTrue(is_array($aclMerged));
|
2019-10-23 00:40:14 +02:00
|
|
|
|
2019-11-01 15:43:16 +01:00
|
|
|
return $aclMerged;
|
2019-10-23 00:40:14 +02:00
|
|
|
}
|
|
|
|
|
2019-11-01 15:43:16 +01:00
|
|
|
public function dataExpand()
|
2019-10-23 00:40:14 +02:00
|
|
|
{
|
2019-11-01 15:43:16 +01:00
|
|
|
return [
|
|
|
|
'normal' => [
|
|
|
|
'input' => '<1><2><3><' . Group::FOLLOWERS . '><' . Group::MUTUALS . '>',
|
|
|
|
'assert' => ['1', '2', '3', Group::FOLLOWERS, Group::MUTUALS],
|
|
|
|
],
|
|
|
|
'nigNumber' => [
|
|
|
|
'input' => '<1><' . PHP_INT_MAX . '><15>',
|
|
|
|
'assert' => ['1', (string)PHP_INT_MAX, '15'],
|
|
|
|
],
|
|
|
|
'string' => [
|
|
|
|
'input' => '<1><279012><tt>',
|
|
|
|
'assert' => ['1', '279012'],
|
|
|
|
],
|
|
|
|
'space' => [
|
|
|
|
'input' => '<1><279 012><32>',
|
|
|
|
'assert' => ['1', '32'],
|
|
|
|
],
|
|
|
|
'empty' => [
|
|
|
|
'input' => '',
|
|
|
|
'assert' => [],
|
|
|
|
],
|
|
|
|
/// @todo should there be an exception?
|
|
|
|
'noBrackets' => [
|
|
|
|
'input' => 'According to documentation, that\'s invalid. ', //should be invalid
|
|
|
|
'assert' => [],
|
|
|
|
],
|
|
|
|
/// @todo should there be an exception?
|
|
|
|
'justOneBracket' => [
|
|
|
|
'input' => '<Another invalid string', //should be invalid
|
|
|
|
'assert' => [],
|
|
|
|
],
|
|
|
|
/// @todo should there be an exception?
|
|
|
|
'justOneBracket2' => [
|
|
|
|
'input' => 'Another invalid> string', //should be invalid
|
|
|
|
'assert' => [],
|
|
|
|
],
|
|
|
|
/// @todo should there be an exception?
|
|
|
|
'closeOnly' => [
|
|
|
|
'input' => 'Another> invalid> string>', //should be invalid
|
|
|
|
'assert' => [],
|
|
|
|
],
|
|
|
|
/// @todo should there be an exception?
|
|
|
|
'openOnly' => [
|
|
|
|
'input' => '<Another< invalid string<', //should be invalid
|
|
|
|
'assert' => [],
|
|
|
|
],
|
|
|
|
/// @todo should there be an exception?
|
|
|
|
'noMatching1' => [
|
|
|
|
'input' => '<Another<> invalid <string>', //should be invalid
|
|
|
|
'assert' => [],
|
|
|
|
],
|
|
|
|
'emptyMatch' => [
|
2019-11-01 15:49:18 +01:00
|
|
|
'input' => '<1><><3>',
|
2019-11-01 15:43:16 +01:00
|
|
|
'assert' => ['1', '3'],
|
|
|
|
],
|
|
|
|
];
|
2019-10-23 00:40:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-11-01 15:43:16 +01:00
|
|
|
* @dataProvider dataExpand
|
2019-10-23 00:40:14 +02:00
|
|
|
*/
|
2019-11-01 15:43:16 +01:00
|
|
|
public function testExpand($input, array $assert)
|
2019-10-23 00:40:14 +02:00
|
|
|
{
|
2019-11-01 15:43:16 +01:00
|
|
|
$this->assertAcl($input, $assert);
|
2019-10-23 00:40:14 +02:00
|
|
|
}
|
2019-10-23 00:54:34 +02:00
|
|
|
|
2019-10-28 18:16:10 +01:00
|
|
|
/**
|
2019-11-01 14:13:29 +01:00
|
|
|
* Test nullable expand (=> no ACL set)
|
2019-10-28 18:16:10 +01:00
|
|
|
*/
|
|
|
|
public function testExpandNull()
|
|
|
|
{
|
|
|
|
$aclFormatter = new ACLFormatter();
|
|
|
|
|
2019-11-01 15:43:16 +01:00
|
|
|
$allow_people = $aclFormatter->expand();
|
|
|
|
$allow_groups = $aclFormatter->expand();
|
|
|
|
|
|
|
|
$this->assertEmpty($aclFormatter->expand(null));
|
|
|
|
$this->assertEmpty($aclFormatter->expand());
|
|
|
|
|
|
|
|
$recipients = array_unique(array_merge($allow_people, $allow_groups));
|
|
|
|
$this->assertEmpty($recipients);
|
2019-10-28 18:16:10 +01:00
|
|
|
}
|
|
|
|
|
2019-10-23 00:54:34 +02:00
|
|
|
public function dataAclToString()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'empty' => [
|
|
|
|
'input' => '',
|
|
|
|
'assert' => '',
|
|
|
|
],
|
|
|
|
'string' => [
|
|
|
|
'input' => '1,2,3,4',
|
|
|
|
'assert' => '<1><2><3><4>',
|
|
|
|
],
|
|
|
|
'array' => [
|
|
|
|
'input' => [1, 2, 3, 4],
|
|
|
|
'assert' => '<1><2><3><4>',
|
|
|
|
],
|
|
|
|
'invalid' => [
|
|
|
|
'input' => [1, 'a', 3, 4],
|
|
|
|
'assert' => '<1><3><4>',
|
|
|
|
],
|
|
|
|
'invalidString' => [
|
|
|
|
'input' => 'a,bsd23,4',
|
|
|
|
'assert' => '<4>',
|
|
|
|
],
|
2019-11-01 14:13:29 +01:00
|
|
|
/** @see https://github.com/friendica/friendica/pull/7787 */
|
|
|
|
'bug-7778-angle-brackets' => [
|
|
|
|
'input' => ["<40195>"],
|
|
|
|
'assert' => "<40195>",
|
|
|
|
],
|
|
|
|
Group::FOLLOWERS => [
|
|
|
|
'input' => [Group::FOLLOWERS, 1],
|
|
|
|
'assert' => '<' . Group::FOLLOWERS . '><1>',
|
|
|
|
],
|
|
|
|
Group::MUTUALS => [
|
|
|
|
'input' => [Group::MUTUALS, 1],
|
|
|
|
'assert' => '<' . Group::MUTUALS . '><1>',
|
|
|
|
],
|
|
|
|
'wrong-angle-brackets' => [
|
|
|
|
'input' => ["<asd>","<123>"],
|
|
|
|
'assert' => "<123>",
|
|
|
|
],
|
2019-10-23 00:54:34 +02:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dataProvider dataAclToString
|
|
|
|
*/
|
|
|
|
public function testAclToString($input, string $assert)
|
|
|
|
{
|
|
|
|
$aclFormatter = new ACLFormatter();
|
|
|
|
|
2019-10-23 21:38:51 +02:00
|
|
|
$this->assertEquals($assert, $aclFormatter->toString($input));
|
2019-10-23 00:54:34 +02:00
|
|
|
}
|
2019-10-23 00:40:14 +02:00
|
|
|
}
|