Merge pull request #443 from MyIgel/legacy-url-support
UrlGeneratorInterface and "Legacy URL" supportmain
commit
a3ce3ea23d
@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Engelsystem\Routing;
|
||||||
|
|
||||||
|
class LegacyUrlGenerator extends UrlGenerator
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param string $path
|
||||||
|
* @param array $parameters
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function to($path, $parameters = [])
|
||||||
|
{
|
||||||
|
$page = ltrim($path, '/');
|
||||||
|
if (!empty($page)) {
|
||||||
|
$page = str_replace('-', '_', $page);
|
||||||
|
$parameters = array_merge(['p' => $page], $parameters);
|
||||||
|
}
|
||||||
|
|
||||||
|
$uri = parent::to('index.php', $parameters);
|
||||||
|
$uri = preg_replace('~(/index\.php)+~', '/index.php', $uri);
|
||||||
|
|
||||||
|
return $uri;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Engelsystem\Routing;
|
||||||
|
|
||||||
|
interface UrlGeneratorInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param string $path
|
||||||
|
* @param array $parameters
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function to($path, $parameters = []);
|
||||||
|
}
|
@ -0,0 +1,54 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Engelsystem\Test\Unit\Routing;
|
||||||
|
|
||||||
|
use Engelsystem\Application;
|
||||||
|
use Engelsystem\Container\Container;
|
||||||
|
use Engelsystem\Http\Request;
|
||||||
|
use Engelsystem\Routing\LegacyUrlGenerator;
|
||||||
|
use Engelsystem\Routing\UrlGeneratorInterface;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
class LegacyUrlGeneratorTest extends TestCase
|
||||||
|
{
|
||||||
|
public function provideLinksTo()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
['/', 'http://foo.bar/index.php', [], 'http://foo.bar/index.php'],
|
||||||
|
['/foo-path', 'http://foo.bar/index.php/index.php', [], 'http://foo.bar/index.php?p=foo_path'],
|
||||||
|
['/foo', 'http://foo.bar/index.php/index.php', [], 'http://foo.bar/index.php?p=foo'],
|
||||||
|
['foo', 'http://foo.bar/index.php', ['test' => 'abc'], 'http://foo.bar/index.php?p=foo&test=abc'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider provideLinksTo
|
||||||
|
* @covers \Engelsystem\Routing\LegacyUrlGenerator::to
|
||||||
|
*
|
||||||
|
* @param string $urlToPath
|
||||||
|
* @param string $willReturn
|
||||||
|
* @param string[] $arguments
|
||||||
|
* @param string $expectedUrl
|
||||||
|
*/
|
||||||
|
public function testTo($urlToPath, $willReturn, $arguments, $expectedUrl)
|
||||||
|
{
|
||||||
|
$app = new Container();
|
||||||
|
Application::setInstance($app);
|
||||||
|
|
||||||
|
$request = $this->getMockBuilder(Request::class)
|
||||||
|
->getMock();
|
||||||
|
|
||||||
|
$request->expects($this->once())
|
||||||
|
->method('getUriForPath')
|
||||||
|
->with('/index.php')
|
||||||
|
->willReturn($willReturn);
|
||||||
|
|
||||||
|
$app->instance('request', $request);
|
||||||
|
|
||||||
|
$urlGenerator = new LegacyUrlGenerator();
|
||||||
|
$this->assertInstanceOf(UrlGeneratorInterface::class, $urlGenerator);
|
||||||
|
|
||||||
|
$url = $urlGenerator->to($urlToPath, $arguments);
|
||||||
|
$this->assertEquals($expectedUrl, $url);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue