<?php
/**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2021, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
namespace Friendica\Test\src\App;
use Friendica\App\Router;
-use Friendica\Core\Cache\ICache;
+use Friendica\Core\Cache\Capability\ICanCache;
use Friendica\Core\L10n;
+use Friendica\Core\Lock\Capability\ICanLock;
use Friendica\Module;
use Friendica\Network\HTTPException\MethodNotAllowedException;
use Friendica\Network\HTTPException\NotFoundException;
+use Mockery;
use Mockery\MockInterface;
use PHPUnit\Framework\TestCase;
/** @var L10n|MockInterface */
private $l10n;
/**
- * @var ICache
+ * @var ICanCache
*/
private $cache;
+ /**
+ * @var ICanLock
+ */
+ private $lock;
- protected function setUp()
+ protected function setUp() : void
{
parent::setUp();
- $this->l10n = \Mockery::mock(L10n::class);
+ $this->l10n = Mockery::mock(L10n::class);
$this->l10n->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
- $this->cache = \Mockery::mock(ICache::class);
+ $this->cache = Mockery::mock(ICanCache::class);
$this->cache->shouldReceive('get')->andReturn(null);
$this->cache->shouldReceive('set')->andReturn(false);
+
+ $this->lock = Mockery::mock(ICanLock::class);
+ $this->lock->shouldReceive('acquire')->andReturn(true);
+ $this->lock->shouldReceive('isLocked')->andReturn(false);
}
public function testGetModuleClass()
{
- $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache);
+ $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache, $this->lock);
$routeCollector = $router->getRouteCollector();
$routeCollector->addRoute([Router::GET], '/', 'IndexModuleClassName');
$routeCollector->addRoute([Router::GET], '/variable/{var}', 'VariableModuleClassName');
$routeCollector->addRoute([Router::GET], '/optionalvariable[/{option}]', 'OptionalVariableModuleClassName');
- $this->assertEquals('IndexModuleClassName', $router->getModuleClass('/'));
- $this->assertEquals('TestModuleClassName', $router->getModuleClass('/test'));
- $this->assertEquals('TestGetPostModuleClassName', $router->getModuleClass('/testgetpost'));
- $this->assertEquals('TestSubModuleClassName', $router->getModuleClass('/test/sub'));
- $this->assertEquals('OptionalModuleClassName', $router->getModuleClass('/optional'));
- $this->assertEquals('OptionalModuleClassName', $router->getModuleClass('/optional/option'));
- $this->assertEquals('VariableModuleClassName', $router->getModuleClass('/variable/123abc'));
- $this->assertEquals('OptionalVariableModuleClassName', $router->getModuleClass('/optionalvariable'));
- $this->assertEquals('OptionalVariableModuleClassName', $router->getModuleClass('/optionalvariable/123abc'));
+ self::assertEquals('IndexModuleClassName', $router->getModuleClass('/'));
+ self::assertEquals('TestModuleClassName', $router->getModuleClass('/test'));
+ self::assertEquals('TestGetPostModuleClassName', $router->getModuleClass('/testgetpost'));
+ self::assertEquals('TestSubModuleClassName', $router->getModuleClass('/test/sub'));
+ self::assertEquals('OptionalModuleClassName', $router->getModuleClass('/optional'));
+ self::assertEquals('OptionalModuleClassName', $router->getModuleClass('/optional/option'));
+ self::assertEquals('VariableModuleClassName', $router->getModuleClass('/variable/123abc'));
+ self::assertEquals('OptionalVariableModuleClassName', $router->getModuleClass('/optionalvariable'));
+ self::assertEquals('OptionalVariableModuleClassName', $router->getModuleClass('/optionalvariable/123abc'));
}
public function testPostModuleClass()
{
- $router = new Router(['REQUEST_METHOD' => Router::POST], '', $this->l10n, $this->cache);
+ $router = new Router(['REQUEST_METHOD' => Router::POST], '', $this->l10n, $this->cache, $this->lock);
$routeCollector = $router->getRouteCollector();
$routeCollector->addRoute([Router::POST], '/', 'IndexModuleClassName');
$routeCollector->addRoute([Router::POST], '/variable/{var}', 'VariableModuleClassName');
$routeCollector->addRoute([Router::POST], '/optionalvariable[/{option}]', 'OptionalVariableModuleClassName');
- $this->assertEquals('IndexModuleClassName', $router->getModuleClass('/'));
- $this->assertEquals('TestModuleClassName', $router->getModuleClass('/test'));
- $this->assertEquals('TestGetPostModuleClassName', $router->getModuleClass('/testgetpost'));
- $this->assertEquals('TestSubModuleClassName', $router->getModuleClass('/test/sub'));
- $this->assertEquals('OptionalModuleClassName', $router->getModuleClass('/optional'));
- $this->assertEquals('OptionalModuleClassName', $router->getModuleClass('/optional/option'));
- $this->assertEquals('VariableModuleClassName', $router->getModuleClass('/variable/123abc'));
- $this->assertEquals('OptionalVariableModuleClassName', $router->getModuleClass('/optionalvariable'));
- $this->assertEquals('OptionalVariableModuleClassName', $router->getModuleClass('/optionalvariable/123abc'));
+ self::assertEquals('IndexModuleClassName', $router->getModuleClass('/'));
+ self::assertEquals('TestModuleClassName', $router->getModuleClass('/test'));
+ self::assertEquals('TestGetPostModuleClassName', $router->getModuleClass('/testgetpost'));
+ self::assertEquals('TestSubModuleClassName', $router->getModuleClass('/test/sub'));
+ self::assertEquals('OptionalModuleClassName', $router->getModuleClass('/optional'));
+ self::assertEquals('OptionalModuleClassName', $router->getModuleClass('/optional/option'));
+ self::assertEquals('VariableModuleClassName', $router->getModuleClass('/variable/123abc'));
+ self::assertEquals('OptionalVariableModuleClassName', $router->getModuleClass('/optionalvariable'));
+ self::assertEquals('OptionalVariableModuleClassName', $router->getModuleClass('/optionalvariable/123abc'));
}
public function testGetModuleClassNotFound()
{
$this->expectException(NotFoundException::class);
- $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache);
+ $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache, $this->lock);
$router->getModuleClass('/unsupported');
}
{
$this->expectException(NotFoundException::class);
- $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache);
+ $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache, $this->lock);
$routeCollector = $router->getRouteCollector();
$routeCollector->addRoute([Router::GET], '/test', 'TestModuleClassName');
{
$this->expectException(NotFoundException::class);
- $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache);
+ $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache, $this->lock);
$routeCollector = $router->getRouteCollector();
$routeCollector->addRoute([Router::GET], '/optional[/option]', 'OptionalModuleClassName');
{
$this->expectException(NotFoundException::class);
- $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache);
+ $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache, $this->lock);
$routeCollector = $router->getRouteCollector();
$routeCollector->addRoute([Router::GET], '/variable/{var}', 'VariableModuleClassName');
{
$this->expectException(MethodNotAllowedException::class);
- $router = new Router(['REQUEST_METHOD' => Router::POST], '', $this->l10n, $this->cache);
+ $router = new Router(['REQUEST_METHOD' => Router::POST], '', $this->l10n, $this->cache, $this->lock);
$routeCollector = $router->getRouteCollector();
$routeCollector->addRoute([Router::GET], '/test', 'TestModuleClassName');
{
$this->expectException(MethodNotAllowedException::class);
- $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache);
+ $router = new Router(['REQUEST_METHOD' => Router::GET], '', $this->l10n, $this->cache, $this->lock);
$routeCollector = $router->getRouteCollector();
$routeCollector->addRoute([Router::POST], '/test', 'TestModuleClassName');
['REQUEST_METHOD' => Router::GET],
'',
$this->l10n,
- $this->cache
+ $this->cache,
+ $this->lock
))->loadRoutes($routes);
- $this->assertEquals(Module\Home::class, $router->getModuleClass('/'));
- $this->assertEquals(Module\Friendica::class, $router->getModuleClass('/group/route'));
- $this->assertEquals(Module\Xrd::class, $router->getModuleClass('/group2/group3/route'));
- $this->assertEquals(Module\Profile\Index::class, $router->getModuleClass('/double'));
+ self::assertEquals(Module\Home::class, $router->getModuleClass('/'));
+ self::assertEquals(Module\Friendica::class, $router->getModuleClass('/group/route'));
+ self::assertEquals(Module\Xrd::class, $router->getModuleClass('/group2/group3/route'));
+ self::assertEquals(Module\Profile\Index::class, $router->getModuleClass('/double'));
}
/**
{
$router = (new Router([
'REQUEST_METHOD' => Router::POST
- ], '', $this->l10n, $this->cache))->loadRoutes($routes);
+ ], '', $this->l10n, $this->cache, $this->lock))->loadRoutes($routes);
// Don't find GET
- $this->assertEquals(Module\WellKnown\NodeInfo::class, $router->getModuleClass('/post/it'));
- $this->assertEquals(Module\Profile\Index::class, $router->getModuleClass('/double'));
+ self::assertEquals(Module\WellKnown\NodeInfo::class, $router->getModuleClass('/post/it'));
+ self::assertEquals(Module\Profile\Index::class, $router->getModuleClass('/double'));
}
}