2019-04-20 12:53:17 +02:00
|
|
|
<?php
|
|
|
|
|
2019-05-02 23:17:35 +02:00
|
|
|
namespace Friendica\Test\src\Console;
|
2019-04-20 12:53:17 +02:00
|
|
|
|
2019-05-02 23:17:35 +02:00
|
|
|
use Friendica\Console\ServerBlock;
|
2019-04-20 12:53:17 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @runTestsInSeparateProcesses
|
|
|
|
* @preserveGlobalState disabled
|
|
|
|
*/
|
2019-04-20 16:40:27 +02:00
|
|
|
class ServerBlockConsoleTest extends ConsoleTest
|
2019-04-20 12:53:17 +02:00
|
|
|
{
|
|
|
|
protected $defaultBlockList = [
|
|
|
|
[
|
|
|
|
'domain' => 'social.nobodyhasthe.biz',
|
|
|
|
'reason' => 'Illegal content',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'domain' => 'pod.ordoevangelistarum.com',
|
|
|
|
'reason' => 'Illegal content',
|
|
|
|
]
|
|
|
|
];
|
|
|
|
|
|
|
|
protected function setUp()
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
$this->mockApp($this->root);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test to list the default blocked servers
|
|
|
|
*/
|
|
|
|
public function testBlockedServersList()
|
|
|
|
{
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('get')
|
|
|
|
->with('system', 'blocklist')
|
|
|
|
->andReturn($this->defaultBlockList)
|
|
|
|
->once();
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$output = <<<CONS
|
|
|
|
+----------------------------+-----------------+
|
|
|
|
| Domain | Reason |
|
|
|
|
+----------------------------+-----------------+
|
|
|
|
| social.nobodyhasthe.biz | Illegal content |
|
|
|
|
| pod.ordoevangelistarum.com | Illegal content |
|
|
|
|
+----------------------------+-----------------+
|
|
|
|
|
|
|
|
|
|
|
|
CONS;
|
|
|
|
|
|
|
|
$this->assertEquals($output, $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test blockedservers add command
|
|
|
|
*/
|
|
|
|
public function testAddBlockedServer()
|
|
|
|
{
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('get')
|
|
|
|
->with('system', 'blocklist')
|
|
|
|
->andReturn($this->defaultBlockList)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$newBlockList = $this->defaultBlockList;
|
|
|
|
$newBlockList[] = [
|
|
|
|
'domain' => 'testme.now',
|
|
|
|
'reason' => 'I like it!',
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('set')
|
|
|
|
->with('system', 'blocklist', $newBlockList)
|
|
|
|
->andReturn(true)
|
|
|
|
->once();
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setArgument(0, 'add');
|
|
|
|
$console->setArgument(1, 'testme.now');
|
|
|
|
$console->setArgument(2, 'I like it!');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertEquals('The domain \'testme.now\' is now blocked. (Reason: \'I like it!\')' . PHP_EOL, $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test blockedservers add command with the default reason
|
|
|
|
*/
|
|
|
|
public function testAddBlockedServerWithDefaultReason()
|
|
|
|
{
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('get')
|
|
|
|
->with('system', 'blocklist')
|
|
|
|
->andReturn($this->defaultBlockList)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$newBlockList = $this->defaultBlockList;
|
|
|
|
$newBlockList[] = [
|
|
|
|
'domain' => 'testme.now',
|
2019-04-20 16:40:27 +02:00
|
|
|
'reason' => ServerBlock::DEFAULT_REASON,
|
2019-04-20 12:53:17 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('set')
|
|
|
|
->with('system', 'blocklist', $newBlockList)
|
|
|
|
->andReturn(true)
|
|
|
|
->once();
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setArgument(0, 'add');
|
|
|
|
$console->setArgument(1, 'testme.now');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$this->assertEquals('The domain \'testme.now\' is now blocked. (Reason: \'' . ServerBlock::DEFAULT_REASON . '\')' . PHP_EOL, $txt);
|
2019-04-20 13:24:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test blockedservers add command on existed domain
|
|
|
|
*/
|
|
|
|
public function testUpdateBlockedServer()
|
|
|
|
{
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('get')
|
|
|
|
->with('system', 'blocklist')
|
|
|
|
->andReturn($this->defaultBlockList)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$newBlockList = [
|
|
|
|
[
|
|
|
|
'domain' => 'social.nobodyhasthe.biz',
|
|
|
|
'reason' => 'Illegal content',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'domain' => 'pod.ordoevangelistarum.com',
|
|
|
|
'reason' => 'Other reason',
|
|
|
|
]
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('set')
|
|
|
|
->with('system', 'blocklist', $newBlockList)
|
|
|
|
->andReturn(true)
|
|
|
|
->once();
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 13:24:33 +02:00
|
|
|
$console->setArgument(0, 'add');
|
|
|
|
$console->setArgument(1, 'pod.ordoevangelistarum.com');
|
|
|
|
$console->setArgument(2, 'Other reason');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertEquals('The domain \'pod.ordoevangelistarum.com\' is now updated. (Reason: \'Other reason\')' . PHP_EOL, $txt);
|
2019-04-20 12:53:17 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test blockedservers remove command
|
|
|
|
*/
|
|
|
|
public function testRemoveBlockedServer()
|
|
|
|
{
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('get')
|
|
|
|
->with('system', 'blocklist')
|
|
|
|
->andReturn($this->defaultBlockList)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$newBlockList = [
|
|
|
|
[
|
|
|
|
'domain' => 'social.nobodyhasthe.biz',
|
|
|
|
'reason' => 'Illegal content',
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('set')
|
|
|
|
->with('system', 'blocklist', $newBlockList)
|
|
|
|
->andReturn(true)
|
|
|
|
->once();
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setArgument(0, 'remove');
|
|
|
|
$console->setArgument(1, 'pod.ordoevangelistarum.com');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertEquals('The domain \'pod.ordoevangelistarum.com\' is not more blocked' . PHP_EOL, $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test blockedservers with a wrong command
|
|
|
|
*/
|
|
|
|
public function testBlockedServersWrongCommand()
|
|
|
|
{
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setArgument(0, 'wrongcommand');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertStringStartsWith('[Warning] Unknown command', $txt);
|
|
|
|
}
|
|
|
|
|
2019-04-20 13:24:33 +02:00
|
|
|
/**
|
|
|
|
* Test blockedservers remove with not existing domain
|
|
|
|
*/
|
|
|
|
public function testRemoveBlockedServerNotExist()
|
|
|
|
{
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('get')
|
|
|
|
->with('system', 'blocklist')
|
|
|
|
->andReturn($this->defaultBlockList)
|
|
|
|
->once();
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 13:24:33 +02:00
|
|
|
$console->setArgument(0, 'remove');
|
|
|
|
$console->setArgument(1, 'not.exiting');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertEquals('The domain \'not.exiting\' is not blocked.' . PHP_EOL, $txt);
|
|
|
|
}
|
|
|
|
|
2019-04-20 12:53:17 +02:00
|
|
|
/**
|
|
|
|
* Test blockedservers add command without argument
|
|
|
|
*/
|
|
|
|
public function testAddBlockedServerMissingArgument()
|
|
|
|
{
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setArgument(0, 'add');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertStringStartsWith('[Warning] Add needs a domain and optional a reason.', $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test blockedservers add command without save
|
|
|
|
*/
|
|
|
|
public function testAddBlockedServerNoSave()
|
|
|
|
{
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('get')
|
|
|
|
->with('system', 'blocklist')
|
|
|
|
->andReturn($this->defaultBlockList)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$newBlockList = $this->defaultBlockList;
|
|
|
|
$newBlockList[] = [
|
|
|
|
'domain' => 'testme.now',
|
2019-04-20 16:40:27 +02:00
|
|
|
'reason' => ServerBlock::DEFAULT_REASON,
|
2019-04-20 12:53:17 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('set')
|
|
|
|
->with('system', 'blocklist', $newBlockList)
|
|
|
|
->andReturn(false)
|
|
|
|
->once();
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setArgument(0, 'add');
|
|
|
|
$console->setArgument(1, 'testme.now');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertEquals('Couldn\'t save \'testme.now\' as blocked server' . PHP_EOL, $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test blockedservers remove command without save
|
|
|
|
*/
|
|
|
|
public function testRemoveBlockedServerNoSave()
|
|
|
|
{
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('get')
|
|
|
|
->with('system', 'blocklist')
|
|
|
|
->andReturn($this->defaultBlockList)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$newBlockList = [
|
|
|
|
[
|
|
|
|
'domain' => 'social.nobodyhasthe.biz',
|
|
|
|
'reason' => 'Illegal content',
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->configMock
|
|
|
|
->shouldReceive('set')
|
|
|
|
->with('system', 'blocklist', $newBlockList)
|
|
|
|
->andReturn(false)
|
|
|
|
->once();
|
|
|
|
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setArgument(0, 'remove');
|
|
|
|
$console->setArgument(1, 'pod.ordoevangelistarum.com');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertEquals('Couldn\'t remove \'pod.ordoevangelistarum.com\' from blocked servers' . PHP_EOL, $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test blockedservers remove command without argument
|
|
|
|
*/
|
|
|
|
public function testRemoveBlockedServerMissingArgument()
|
|
|
|
{
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setArgument(0, 'remove');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertStringStartsWith('[Warning] Remove needs a second parameter.', $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test the blockedservers help
|
|
|
|
*/
|
|
|
|
public function testBlockedServersHelp()
|
|
|
|
{
|
2019-04-20 16:40:27 +02:00
|
|
|
$console = new ServerBlock($this->consoleArgv);
|
2019-04-20 12:53:17 +02:00
|
|
|
$console->setOption('help', true);
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$help = <<<HELP
|
2019-04-20 16:40:27 +02:00
|
|
|
console serverblock - Manage blocked servers
|
2019-04-20 12:53:17 +02:00
|
|
|
Usage
|
2019-04-20 16:40:27 +02:00
|
|
|
bin/console serverblock [-h|--help|-?] [-v]
|
|
|
|
bin/console serverblock add <server> <reason> [-h|--help|-?] [-v]
|
|
|
|
bin/console serverblock remove <server> [-h|--help|-?] [-v]
|
2019-04-20 12:53:17 +02:00
|
|
|
|
|
|
|
Description
|
|
|
|
With this tool, you can list the current blocked servers
|
|
|
|
or you can add / remove a blocked server from the list
|
|
|
|
|
|
|
|
Options
|
|
|
|
-h|--help|-? Show help information
|
|
|
|
-v Show more debug information.
|
|
|
|
|
|
|
|
HELP;
|
|
|
|
|
|
|
|
$this->assertEquals($help, $txt);
|
|
|
|
}
|
|
|
|
}
|