added override power to server parameters provided on request method
This commit is contained in:
parent
9068875a5e
commit
289da16681
@ -302,6 +302,15 @@ abstract class Client
|
|||||||
}
|
}
|
||||||
|
|
||||||
$uri = $this->getAbsoluteUri($uri);
|
$uri = $this->getAbsoluteUri($uri);
|
||||||
|
|
||||||
|
if (isset($server['HTTP_HOST'])) {
|
||||||
|
$uri = str_replace(parse_url($uri, PHP_URL_HOST), $server['HTTP_HOST'], $uri);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($server['HTTPS'])) {
|
||||||
|
$uri = str_replace(parse_url($uri, PHP_URL_SCHEME), $server['HTTPS'] ? 'https' : 'http', $uri);
|
||||||
|
}
|
||||||
|
|
||||||
$server = array_merge($this->server, $server);
|
$server = array_merge($this->server, $server);
|
||||||
|
|
||||||
if (!$this->history->isEmpty()) {
|
if (!$this->history->isEmpty()) {
|
||||||
@ -518,7 +527,7 @@ abstract class Client
|
|||||||
}
|
}
|
||||||
|
|
||||||
$server = $request->getServer();
|
$server = $request->getServer();
|
||||||
unset($server['HTTP_IF_NONE_MATCH'], $server['HTTP_IF_MODIFIED_SINCE']);
|
$server = $this->updateServerFromUri($server, $this->redirect);
|
||||||
|
|
||||||
$this->isMainRequest = false;
|
$this->isMainRequest = false;
|
||||||
|
|
||||||
@ -600,4 +609,13 @@ abstract class Client
|
|||||||
{
|
{
|
||||||
return $this->request($request->getMethod(), $request->getUri(), $request->getParameters(), $request->getFiles(), $request->getServer(), $request->getContent(), $changeHistory);
|
return $this->request($request->getMethod(), $request->getUri(), $request->getParameters(), $request->getFiles(), $request->getServer(), $request->getContent(), $changeHistory);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function updateServerFromUri($server, $uri)
|
||||||
|
{
|
||||||
|
$server['HTTP_HOST'] = parse_url($uri, PHP_URL_HOST);
|
||||||
|
$server['HTTPS'] = 'https' == parse_url($uri, PHP_URL_SCHEME);
|
||||||
|
unset($server['HTTP_IF_NONE_MATCH'], $server['HTTP_IF_MODIFIED_SINCE']);
|
||||||
|
|
||||||
|
return $server;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -399,7 +399,7 @@ class ClientTest extends \PHPUnit_Framework_TestCase
|
|||||||
$this->assertEquals('http://www.example.com/redirected', $client->getRequest()->getUri(), '->followRedirect() follows relative URLs');
|
$this->assertEquals('http://www.example.com/redirected', $client->getRequest()->getUri(), '->followRedirect() follows relative URLs');
|
||||||
|
|
||||||
$client = new TestClient();
|
$client = new TestClient();
|
||||||
$client->setNextResponse(new Response('', 302, array('Location' => '//www.example.org/')));
|
$client->setNextResponse(new Response('', 302, array('Location' => 'https://www.example.org/')));
|
||||||
$client->request('GET', 'https://www.example.com/');
|
$client->request('GET', 'https://www.example.com/');
|
||||||
|
|
||||||
$this->assertEquals('https://www.example.org/', $client->getRequest()->getUri(), '->followRedirect() follows protocol-relative URLs');
|
$this->assertEquals('https://www.example.org/', $client->getRequest()->getUri(), '->followRedirect() follows protocol-relative URLs');
|
||||||
@ -585,4 +585,38 @@ class ClientTest extends \PHPUnit_Framework_TestCase
|
|||||||
$client->setServerParameter('HTTP_USER_AGENT', 'testua');
|
$client->setServerParameter('HTTP_USER_AGENT', 'testua');
|
||||||
$this->assertEquals('testua', $client->getServerParameter('HTTP_USER_AGENT'));
|
$this->assertEquals('testua', $client->getServerParameter('HTTP_USER_AGENT'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testSetServerParameterInRequest()
|
||||||
|
{
|
||||||
|
$client = new TestClient();
|
||||||
|
|
||||||
|
$this->assertEquals('localhost', $client->getServerParameter('HTTP_HOST'));
|
||||||
|
$this->assertEquals('Symfony2 BrowserKit', $client->getServerParameter('HTTP_USER_AGENT'));
|
||||||
|
|
||||||
|
$client->request('GET', 'https://www.example.com/foo', array(), array(), array(
|
||||||
|
'HTTP_HOST' => 'testhost',
|
||||||
|
'HTTP_USER_AGENT' => 'testua',
|
||||||
|
'HTTPS' => false,
|
||||||
|
'NEW_SERVER_KEY' => 'new-server-key-value'
|
||||||
|
));
|
||||||
|
|
||||||
|
$this->assertEquals('localhost', $client->getServerParameter('HTTP_HOST'));
|
||||||
|
$this->assertEquals('Symfony2 BrowserKit', $client->getServerParameter('HTTP_USER_AGENT'));
|
||||||
|
|
||||||
|
$this->assertEquals('http://testhost/foo', $client->getRequest()->getUri());
|
||||||
|
|
||||||
|
$server = $client->getRequest()->getServer();
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('HTTP_USER_AGENT', $server);
|
||||||
|
$this->assertEquals('testua', $server['HTTP_USER_AGENT']);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('HTTP_HOST', $server);
|
||||||
|
$this->assertEquals('testhost', $server['HTTP_HOST']);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('NEW_SERVER_KEY', $server);
|
||||||
|
$this->assertEquals('new-server-key-value', $server['NEW_SERVER_KEY']);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('HTTPS', $server);
|
||||||
|
$this->assertFalse($server['HTTPS']);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user