2019-08-15 08:22:29 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Friendica\Test\src\Console;
|
|
|
|
|
|
|
|
use Friendica\App;
|
|
|
|
use Friendica\App\Mode;
|
|
|
|
use Friendica\Console\Lock;
|
|
|
|
use Friendica\Core\Lock\ILock;
|
|
|
|
use Mockery\MockInterface;
|
|
|
|
|
|
|
|
class LockConsoleTest extends ConsoleTest
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var App\Mode|MockInterface $appMode
|
|
|
|
*/
|
|
|
|
private $appMode;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var ILock|MockInterface
|
|
|
|
*/
|
|
|
|
private $lockMock;
|
|
|
|
|
|
|
|
protected function setUp()
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
\Mockery::getConfiguration()->setConstantsMap([
|
|
|
|
Mode::class => [
|
|
|
|
'DBCONFIGAVAILABLE' => 0
|
|
|
|
]
|
|
|
|
]);
|
|
|
|
|
|
|
|
$this->appMode = \Mockery::mock(App\Mode::class);
|
|
|
|
$this->appMode->shouldReceive('has')
|
|
|
|
->andReturn(true);
|
|
|
|
|
|
|
|
$this->lockMock = \Mockery::mock(ILock::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testList()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
|
|
|
->shouldReceive('getLocks')
|
|
|
|
->andReturn(['test', 'test2'])
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'list');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("Listing all Locks:\ntest\ntest2\n2 locks found\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testListPrefix()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
|
|
|
->shouldReceive('getLocks')
|
|
|
|
->with('test')
|
|
|
|
->andReturn(['test', 'test2'])
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'list');
|
|
|
|
$console->setArgument(1, 'test');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("Listing all Locks starting with \"test\":\ntest\ntest2\n2 locks found\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDelLock()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
2020-01-06 18:57:30 -05:00
|
|
|
->shouldReceive('release')
|
2019-08-15 08:22:29 -04:00
|
|
|
->with('test', true)
|
|
|
|
->andReturn(true)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'del');
|
|
|
|
$console->setArgument(1, 'test');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("Lock 'test' released.\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDelUnknownLock()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
2020-01-06 18:57:30 -05:00
|
|
|
->shouldReceive('release')
|
2019-08-15 08:22:29 -04:00
|
|
|
->with('test', true)
|
|
|
|
->andReturn(false)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'del');
|
|
|
|
$console->setArgument(1, 'test');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("Couldn't release Lock 'test'\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetLock()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
|
|
|
->shouldReceive('isLocked')
|
|
|
|
->with('test')
|
|
|
|
->andReturn(false)
|
|
|
|
->once();
|
|
|
|
$this->lockMock
|
2020-01-06 18:57:30 -05:00
|
|
|
->shouldReceive('acquire')
|
2019-08-15 08:22:29 -04:00
|
|
|
->with('test')
|
|
|
|
->andReturn(true)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'set');
|
|
|
|
$console->setArgument(1, 'test');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("Lock 'test' acquired.\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetLockIsLocked()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
|
|
|
->shouldReceive('isLocked')
|
|
|
|
->with('test')
|
|
|
|
->andReturn(true)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'set');
|
|
|
|
$console->setArgument(1, 'test');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("[Error] 'test' is already set.\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetLockNotWorking()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
|
|
|
->shouldReceive('isLocked')
|
|
|
|
->with('test')
|
|
|
|
->andReturn(false)
|
|
|
|
->once();
|
|
|
|
$this->lockMock
|
2020-01-06 18:57:30 -05:00
|
|
|
->shouldReceive('acquire')
|
2019-08-15 08:22:29 -04:00
|
|
|
->with('test')
|
|
|
|
->andReturn(false)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'set');
|
|
|
|
$console->setArgument(1, 'test');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("[Error] Unable to lock 'test'.\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testReleaseAll()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
|
|
|
->shouldReceive('releaseAll')
|
|
|
|
->andReturn(true)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'clear');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("Locks successfully cleared.\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testReleaseAllFailed()
|
|
|
|
{
|
|
|
|
$this->lockMock
|
|
|
|
->shouldReceive('releaseAll')
|
|
|
|
->andReturn(false)
|
|
|
|
->once();
|
|
|
|
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, $this->consoleArgv);
|
|
|
|
$console->setArgument(0, 'clear');
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
$this->assertEquals("[Error] Unable to clear the locks.\n", $txt);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetHelp()
|
|
|
|
{
|
|
|
|
// Usable to purposely fail if new commands are added without taking tests into account
|
|
|
|
$theHelp = <<<HELP
|
|
|
|
console lock - Manage node locks
|
|
|
|
Synopsis
|
|
|
|
bin/console lock list [<prefix>] [-h|--help|-?] [-v]
|
|
|
|
bin/console lock set <lock> [<timeout> [<ttl>]] [-h|--help|-?] [-v]
|
|
|
|
bin/console lock del <lock> [-h|--help|-?] [-v]
|
|
|
|
bin/console lock clear [-h|--help|-?] [-v]
|
|
|
|
|
|
|
|
Description
|
|
|
|
bin/console lock list [<prefix>]
|
|
|
|
List all locks, optionally filtered by a prefix
|
|
|
|
|
|
|
|
bin/console lock set <lock> [<timeout> [<ttl>]]
|
|
|
|
Sets manually a lock, optionally with the provided TTL (time to live) with a default of five minutes.
|
|
|
|
|
|
|
|
bin/console lock del <lock>
|
|
|
|
Deletes a lock.
|
|
|
|
|
|
|
|
bin/console lock clear
|
|
|
|
Clears all locks
|
|
|
|
|
|
|
|
Options
|
|
|
|
-h|--help|-? Show help information
|
|
|
|
-v Show more debug information.
|
|
|
|
|
|
|
|
HELP;
|
|
|
|
$console = new Lock($this->appMode, $this->lockMock, [$this->consoleArgv]);
|
|
|
|
$console->setOption('help', true);
|
|
|
|
|
|
|
|
$txt = $this->dumpExecute($console);
|
|
|
|
|
|
|
|
$this->assertEquals($txt, $theHelp);
|
|
|
|
}
|
|
|
|
}
|