<?php
+/**
+ * @copyright Copyright (C) 2010-2021, the Friendica project
+ *
+ * @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/>.
+ *
+ */
namespace Friendica\Test\src\Console;
use Friendica\Console\ServerBlock;
+use Friendica\Core\Config\Capability\IManageConfigValues;
+use Mockery;
-/**
- * @runTestsInSeparateProcesses
- * @preserveGlobalState disabled
- */
class ServerBlockConsoleTest extends ConsoleTest
{
protected $defaultBlockList = [
'reason' => 'Illegal content',
]
];
+ /**
+ * @var IManageConfigValues|Mockery\LegacyMockInterface|Mockery\MockInterface
+ */
+ private $configMock;
- protected function setUp()
+ protected function setUp() : void
{
parent::setUp();
- $this->mockApp($this->root);
+ $this->configMock = Mockery::mock(IManageConfigValues::class);
}
/**
{
$this->configMock
->shouldReceive('get')
- ->with('system', 'blocklist')
+ ->with('system', 'blocklist', [])
->andReturn($this->defaultBlockList)
->once();
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$txt = $this->dumpExecute($console);
$output = <<<CONS
CONS;
- $this->assertEquals($output, $txt);
+ self::assertEquals($output, $txt);
}
/**
{
$this->configMock
->shouldReceive('get')
- ->with('system', 'blocklist')
+ ->with('system', 'blocklist', [])
->andReturn($this->defaultBlockList)
->once();
->andReturn(true)
->once();
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$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);
+ self::assertEquals('The domain \'testme.now\' is now blocked. (Reason: \'I like it!\')' . PHP_EOL, $txt);
}
/**
{
$this->configMock
->shouldReceive('get')
- ->with('system', 'blocklist')
+ ->with('system', 'blocklist', [])
->andReturn($this->defaultBlockList)
->once();
->andReturn(true)
->once();
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$console->setArgument(0, 'add');
$console->setArgument(1, 'testme.now');
$txt = $this->dumpExecute($console);
- $this->assertEquals('The domain \'testme.now\' is now blocked. (Reason: \'' . ServerBlock::DEFAULT_REASON . '\')' . PHP_EOL, $txt);
+ self::assertEquals('The domain \'testme.now\' is now blocked. (Reason: \'' . ServerBlock::DEFAULT_REASON . '\')' . PHP_EOL, $txt);
}
/**
{
$this->configMock
->shouldReceive('get')
- ->with('system', 'blocklist')
+ ->with('system', 'blocklist', [])
->andReturn($this->defaultBlockList)
->once();
->andReturn(true)
->once();
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$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);
+ self::assertEquals('The domain \'pod.ordoevangelistarum.com\' is now updated. (Reason: \'Other reason\')' . PHP_EOL, $txt);
}
/**
{
$this->configMock
->shouldReceive('get')
- ->with('system', 'blocklist')
+ ->with('system', 'blocklist', [])
->andReturn($this->defaultBlockList)
->once();
->andReturn(true)
->once();
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$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);
+ self::assertEquals('The domain \'pod.ordoevangelistarum.com\' is not more blocked' . PHP_EOL, $txt);
}
/**
*/
public function testBlockedServersWrongCommand()
{
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$console->setArgument(0, 'wrongcommand');
$txt = $this->dumpExecute($console);
- $this->assertStringStartsWith('[Warning] Unknown command', $txt);
+ self::assertStringStartsWith('[Warning] Unknown command', $txt);
}
/**
{
$this->configMock
->shouldReceive('get')
- ->with('system', 'blocklist')
+ ->with('system', 'blocklist', [])
->andReturn($this->defaultBlockList)
->once();
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$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);
+ self::assertEquals('The domain \'not.exiting\' is not blocked.' . PHP_EOL, $txt);
}
/**
*/
public function testAddBlockedServerMissingArgument()
{
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$console->setArgument(0, 'add');
$txt = $this->dumpExecute($console);
- $this->assertStringStartsWith('[Warning] Add needs a domain and optional a reason.', $txt);
+ self::assertStringStartsWith('[Warning] Add needs a domain and optional a reason.', $txt);
}
/**
{
$this->configMock
->shouldReceive('get')
- ->with('system', 'blocklist')
+ ->with('system', 'blocklist', [])
->andReturn($this->defaultBlockList)
->once();
->andReturn(false)
->once();
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$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);
+ self::assertEquals('Couldn\'t save \'testme.now\' as blocked server' . PHP_EOL, $txt);
}
/**
{
$this->configMock
->shouldReceive('get')
- ->with('system', 'blocklist')
+ ->with('system', 'blocklist', [])
->andReturn($this->defaultBlockList)
->once();
->andReturn(false)
->once();
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$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);
+ self::assertEquals('Couldn\'t remove \'pod.ordoevangelistarum.com\' from blocked servers' . PHP_EOL, $txt);
}
/**
*/
public function testRemoveBlockedServerMissingArgument()
{
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$console->setArgument(0, 'remove');
$txt = $this->dumpExecute($console);
- $this->assertStringStartsWith('[Warning] Remove needs a second parameter.', $txt);
+ self::assertStringStartsWith('[Warning] Remove needs a second parameter.', $txt);
}
/**
*/
public function testBlockedServersHelp()
{
- $console = new ServerBlock($this->consoleArgv);
+ $console = new ServerBlock($this->configMock, $this->consoleArgv);
$console->setOption('help', true);
$txt = $this->dumpExecute($console);
$help = <<<HELP
-console serverblock - Manage blocked servers
+console serverblock - Manage blocked server domain patterns
Usage
- bin/console serverblock [-h|--help|-?] [-v]
- bin/console serverblock add <server> <reason> [-h|--help|-?] [-v]
- bin/console serverblock remove <server> [-h|--help|-?] [-v]
+ bin/console serverblock [-h|--help|-?] [-v]
+ bin/console serverblock add <pattern> <reason> [-h|--help|-?] [-v]
+ bin/console serverblock remove <pattern> [-h|--help|-?] [-v]
+ bin/console serverblock export <filename>
+ bin/console serverblock import <filename>
Description
- With this tool, you can list the current blocked servers
- or you can add / remove a blocked server from the list
+ With this tool, you can list the current blocked server domain patterns
+ or you can add / remove a blocked server domain pattern from the list.
+ Using the export and import options you can share your server blocklist
+ with other node admins by CSV files.
+
+ Patterns are case-insensitive shell wildcard comprising the following special characters:
+ - * : Any number of characters
+ - ? : Any single character
+ - [<char1><char2>...] : char1 or char2 or...
Options
-h|--help|-? Show help information
HELP;
- $this->assertEquals($help, $txt);
+ self::assertEquals($help, $txt);
}
}