407 lines
14 KiB
PHP
407 lines
14 KiB
PHP
<?php
|
|
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
|
|
|
|
namespace Tests\Icinga\Web;
|
|
|
|
use Mockery;
|
|
use Icinga\Web\Url;
|
|
use Icinga\Test\BaseTestCase;
|
|
|
|
class UrlTest extends BaseTestCase
|
|
{
|
|
public function testWhetherFromPathCutsOfTheFirstCharOfThePathIfUrlIsInternalAndHasAUsernameInIt()
|
|
{
|
|
$this->getRequestMock()->shouldReceive('getServer')->with("SERVER_NAME")->andReturn('localhost')
|
|
->shouldReceive('getServer')->with("SERVER_PORT")->andReturn('8080');
|
|
|
|
$url = Url::fromPath('http://testusername:testpassword@localhost:8080/path/to/my/url.html');
|
|
$this->assertEquals(
|
|
'path/to/my/url.html',
|
|
$url->getPath(),
|
|
'Url::fromPath does not cut of the first char of path if the url is internal and has a username in it'
|
|
);
|
|
}
|
|
|
|
public function testWhetherGetAbsoluteUrlReturnsTheBasePathIfUrlIsInternalAndHasAUsernameInIt()
|
|
{
|
|
$this->getRequestMock()->shouldReceive('getServer')->with("SERVER_NAME")->andReturn('localhost')
|
|
->shouldReceive('getServer')->with("SERVER_PORT")->andReturn('8080');
|
|
|
|
$url = Url::fromPath('http://testusername:testpassword@localhost:8080/path/to/my/url.html');
|
|
$this->assertEquals(
|
|
'http://testusername:testpassword@localhost:8080/path/to/my/url.html',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::getAbsoluteUrl does not reassemble the correct basePath'
|
|
);
|
|
}
|
|
|
|
public function testWhetherGetAbsoluteUrlReturnsTheBasePathIfUrlIsInternalAndHasNoUsernameInIt()
|
|
{
|
|
$url = Url::fromPath('/path/to/my/url.html');
|
|
$this->assertEquals(
|
|
'/path/to/my/url.html',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::getAbsoluteUrl does not reassemble the correct basePath'
|
|
);
|
|
}
|
|
|
|
public function testWhetherGetAbsoluteUrlReturnsTheBasePathIfUrlIsExternalAndHasAUsernameInIt()
|
|
{
|
|
$this->getRequestMock()->shouldReceive('getServer')->with("SERVER_NAME")->andReturn('localhost')
|
|
->shouldReceive('getServer')->with("SERVER_PORT")->andReturn('8080');
|
|
|
|
$url = Url::fromPath('http://testusername:testpassword@testhost/path/to/my/url.html');
|
|
$this->assertEquals(
|
|
'http://testusername:testpassword@testhost/path/to/my/url.html',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::getAbsoluteUrl does not reassemble the correct basePath'
|
|
);
|
|
}
|
|
|
|
public function testWhetherGetAbsoluteUrlReturnsTheBasePathIfUrlIsExternalAndHasNoUsernameInIt()
|
|
{
|
|
$this->getRequestMock()->shouldReceive('getServer')->with("SERVER_NAME")->andReturn('localhost')
|
|
->shouldReceive('getServer')->with("SERVER_PORT")->andReturn('8080');
|
|
|
|
$url = Url::fromPath('http://testhost/path/to/my/url.html');
|
|
$this->assertEquals(
|
|
'http://testhost/path/to/my/url.html',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::getAbsoluteUrl does not reassemble the correct basePath'
|
|
);
|
|
}
|
|
|
|
public function testWhetherGetAbsoluteUrlReturnsTheGivenUsernameAndPassword()
|
|
{
|
|
$url = Url::fromPath('http://testusername:testpassword@testsite.com/path/to/my/url.html');
|
|
$this->assertEquals(
|
|
'http://testusername:testpassword@testsite.com/path/to/my/url.html',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::fromPath does not reassemble the correct url'
|
|
);
|
|
}
|
|
|
|
public function testWhetherFromRequestWorksWithoutARequest()
|
|
{
|
|
$this->getRequestMock()->shouldReceive('getBaseUrl')->andReturn('/path/to')
|
|
->shouldReceive('getPathInfo')->andReturn('my/test/url.html')
|
|
->shouldReceive('getQuery')->andReturn(array('param1' => 'value1', 'param2' => 'value2'));
|
|
|
|
$url = Url::fromRequest();
|
|
$this->assertEquals(
|
|
'/path/to/my/test/url.html?param1=value1&param2=value2',
|
|
$url->getAbsoluteUrl('&'),
|
|
'Url::fromRequest does not reassemble the correct url from the global request'
|
|
);
|
|
}
|
|
|
|
public function testWhetherFromRequestWorksWithARequest()
|
|
{
|
|
$request = Mockery::mock('Icinga\Web\Request');
|
|
$request->shouldReceive('getPathInfo')->andReturn('my/test/url.html')
|
|
->shouldReceive('getBaseUrl')->andReturn('/path/to')
|
|
->shouldReceive('getQuery')->andReturn(array());
|
|
|
|
$url = Url::fromRequest(array(), $request);
|
|
$this->assertEquals(
|
|
'/path/to/my/test/url.html',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::fromRequest does not reassemble the correct url from a given request'
|
|
);
|
|
}
|
|
|
|
public function testWhetherFromRequestAcceptsAdditionalParameters()
|
|
{
|
|
$request = Mockery::mock('Icinga\Web\Request');
|
|
$request->shouldReceive('getPathInfo')->andReturn('')
|
|
->shouldReceive('getBaseUrl')->andReturn('/')
|
|
->shouldReceive('getQuery')->andReturn(array('key1' => 'val1'));
|
|
|
|
$url = Url::fromRequest(array('key1' => 'newval1', 'key2' => 'val2'), $request);
|
|
$this->assertEquals(
|
|
'val2',
|
|
$url->getParam('key2', 'wrongval'),
|
|
'Url::fromRequest does not accept additional parameters'
|
|
);
|
|
$this->assertEquals(
|
|
'newval1',
|
|
$url->getParam('key1', 'wrongval1'),
|
|
'Url::fromRequest does not overwrite existing parameters with additional ones'
|
|
);
|
|
}
|
|
|
|
public function testWhetherFromPathProperlyHandlesInvalidUrls()
|
|
{
|
|
$this->expectException(\Icinga\Exception\ProgrammingError::class);
|
|
|
|
Url::fromPath(null);
|
|
}
|
|
|
|
public function testWhetherFromPathAcceptsAdditionalParameters()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html', array('key' => 'value'));
|
|
|
|
$this->assertEquals(
|
|
'value',
|
|
$url->getParam('key', 'wrongvalue'),
|
|
'Url::fromPath does not accept additional parameters'
|
|
);
|
|
}
|
|
|
|
public function testWhetherFromPathProperlyParsesUrlsWithoutQuery()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html');
|
|
|
|
$this->assertEquals(
|
|
'',
|
|
$url->getBasePath(),
|
|
'Url::fromPath does not recognize the correct base path'
|
|
);
|
|
$this->assertEquals(
|
|
'/my/test/url.html',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::fromPath does not recognize the correct url path'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyParsesUrlsWithoutQuery
|
|
*/
|
|
public function testWhetherFromPathProperlyRecognizesTheBaseUrl()
|
|
{
|
|
$url = Url::fromPath(
|
|
'/path/to/my/test/url.html',
|
|
array(),
|
|
Mockery::mock(array('getBaseUrl' => '/path/to'))
|
|
);
|
|
|
|
$this->assertEquals(
|
|
'/path/to/my/test/url.html',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::fromPath does not properly differentiate between the base url and its path'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyRecognizesTheBaseUrl
|
|
*/
|
|
public function testWhetherFromPathProperlyRecognizesAndDecodesQueryParameters()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param1=%25arg1¶m2=arg%202'
|
|
. '¶m3[]=1¶m3[]=2¶m3[]=3¶m4[key1]=val1¶m4[key2]=val2');
|
|
|
|
$this->assertEquals(
|
|
'%arg1',
|
|
$url->getParam('param1', 'wrongval'),
|
|
'Url::fromPath does not properly decode escaped characters in query parameter values'
|
|
);
|
|
$this->assertEquals(
|
|
'arg 2',
|
|
$url->getParam('param2', 'wrongval'),
|
|
'Url::fromPath does not properly decode aliases characters in query parameter values'
|
|
);
|
|
/*
|
|
// Temporarily disabled, no [] support right now
|
|
$this->assertEquals(
|
|
array('1', '2', '3'),
|
|
$url->getParam('param3'),
|
|
'Url::fromPath does not properly reassemble query parameter values as sequenced values'
|
|
);
|
|
$this->assertEquals(
|
|
array('key1' => 'val1', 'key2' => 'val2'),
|
|
$url->getParam('param4'),
|
|
'Url::fromPath does not properly reassemble query parameters as associative arrays'
|
|
);
|
|
*/
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyRecognizesAndDecodesQueryParameters
|
|
*/
|
|
public function testWhetherGetAbsoluteUrlReturnsTheAbsoluteUrl()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2');
|
|
|
|
$this->assertEquals(
|
|
'/my/test/url.html?param=val¶m2=val2',
|
|
$url->getAbsoluteUrl(),
|
|
'Url::getAbsoluteUrl does not return the absolute url'
|
|
);
|
|
}
|
|
|
|
public function testWhetherGetRelativeUrlReturnsTheEmptyStringForAbsoluteUrls()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2');
|
|
|
|
$this->assertEquals(
|
|
'',
|
|
$url->getRelativeUrl(),
|
|
'Url::getRelativeUrl does not return the empty string for absolute urls'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyRecognizesAndDecodesQueryParameters
|
|
*/
|
|
public function testWhetherGetParamReturnsTheCorrectParameter()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2');
|
|
|
|
$this->assertEquals(
|
|
'val',
|
|
$url->getParam('param', 'wrongval'),
|
|
'Url::getParam does not return the correct value for an existing parameter'
|
|
);
|
|
$this->assertEquals(
|
|
'val2',
|
|
$url->getParam('param2', 'wrongval2'),
|
|
'Url::getParam does not return the correct value for an existing parameter'
|
|
);
|
|
$this->assertEquals(
|
|
'nonexisting',
|
|
$url->getParam('param3', 'nonexisting'),
|
|
'Url::getParam does not return the default value for a non existing parameter'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyRecognizesAndDecodesQueryParameters
|
|
*/
|
|
public function testWhetherRemoveRemovesAGivenSingleParameter()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2');
|
|
$url->remove('param');
|
|
|
|
$this->assertEquals(
|
|
'val2',
|
|
$url->getParam('param2', 'wrongval2'),
|
|
'Url::remove removes not only the given parameter'
|
|
);
|
|
$this->assertEquals(
|
|
'rightval',
|
|
$url->getParam('param', 'rightval'),
|
|
'Url::remove does not remove the given parameter'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyRecognizesAndDecodesQueryParameters
|
|
*/
|
|
public function testWhetherRemoveRemovesAGivenSetOfParameters()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2¶m3=val3');
|
|
$url->remove(array('param', 'param2'));
|
|
|
|
$this->assertEquals(
|
|
'val3',
|
|
$url->getParam('param3', 'wrongval'),
|
|
'Url::remove removes not only the given parameters'
|
|
);
|
|
$this->assertEquals(
|
|
'rightval',
|
|
$url->getParam('param', 'rightval'),
|
|
'Url::remove does not remove all given parameters'
|
|
);
|
|
$this->assertEquals(
|
|
'rightval',
|
|
$url->getParam('param2', 'rightval'),
|
|
'Url::remove does not remove all given parameters'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyRecognizesAndDecodesQueryParameters
|
|
*/
|
|
public function testWhetherGetUrlWithoutReturnsACopyOfTheUrlWithoutAGivenSetOfParameters()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2¶m3=val3');
|
|
$url2 = $url->getUrlWithout(array('param', 'param2'));
|
|
|
|
$this->assertNotSame($url, $url2, 'Url::getUrlWithout does not return a new copy of the url');
|
|
$this->assertEquals(
|
|
array(array('param3', 'val3')),
|
|
$url2->getParams()->toArray(),
|
|
'Url::getUrlWithout does not remove a given set of parameters from the url'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyRecognizesAndDecodesQueryParameters
|
|
*/
|
|
public function testWhetherAddParamsDoesNotOverwriteExistingParameters()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2¶m3=val3');
|
|
$url->addParams(array('param4' => 'val4', 'param3' => 'newval3'));
|
|
|
|
$this->assertEquals(
|
|
'val4',
|
|
$url->getParam('param4', 'wrongval'),
|
|
'Url::addParams does not add new parameters'
|
|
);
|
|
$this->assertEquals(
|
|
'newval3',
|
|
$url->getParam('param3', 'wrongval'),
|
|
'Url::addParams does not overwrite existing existing parameters'
|
|
);
|
|
$this->assertEquals(
|
|
array('val3', 'newval3'),
|
|
$url->getParams()->getValues('param3'),
|
|
'Url::addParams does not overwrite existing existing parameters'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherFromPathProperlyRecognizesAndDecodesQueryParameters
|
|
*/
|
|
public function testWhetherOverwriteParamsOverwritesExistingParameters()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2¶m3=val3');
|
|
$url->overwriteParams(array('param4' => 'val4', 'param3' => 'newval3'));
|
|
|
|
$this->assertEquals(
|
|
'val4',
|
|
$url->getParam('param4', 'wrongval'),
|
|
'Url::addParams does not add new parameters'
|
|
);
|
|
$this->assertEquals(
|
|
'newval3',
|
|
$url->getParam('param3', 'wrongval'),
|
|
'Url::addParams does not overwrite existing parameters'
|
|
);
|
|
}
|
|
|
|
public function testWhetherEqualUrlMaches()
|
|
{
|
|
$url1 = '/whatever/is/here?a=b&c=d';
|
|
$url2 = Url::fromPath('whatever/is/here', array('a' => 'b', 'c' => 'd'));
|
|
$this->assertEquals(
|
|
true,
|
|
$url2->matches($url1)
|
|
);
|
|
}
|
|
|
|
public function testWhetherDifferentUrlDoesNotMatch()
|
|
{
|
|
$url1 = '/whatever/is/here?a=b&d=d';
|
|
$url2 = Url::fromPath('whatever/is/here', array('a' => 'b', 'c' => 'd'));
|
|
$this->assertEquals(
|
|
false,
|
|
$url2->matches($url1)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @depends testWhetherGetAbsoluteUrlReturnsTheAbsoluteUrl
|
|
*/
|
|
public function testWhetherToStringConversionReturnsTheAbsoluteUrlForHtmlAttributes()
|
|
{
|
|
$url = Url::fromPath('/my/test/url.html?param=val¶m2=val2¶m3=val3');
|
|
|
|
$this->assertEquals(
|
|
'/my/test/url.html?param=val&param2=val2&param3=val3',
|
|
(string) $url,
|
|
'Converting a url to string does not return the absolute url'
|
|
);
|
|
}
|
|
}
|