1
0
Fork 0
composer/tests/Composer/Test/Util/Http/ProxyManagerTest.php

176 lines
5.6 KiB
PHP
Raw Normal View History

2020-09-24 15:48:22 +00:00
<?php
/*
* This file is part of Composer.
*
* (c) Nils Adermann <naderman@naderman.de>
* Jordi Boggiano <j.boggiano@seld.be>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Composer\Test\Util\Http;
use Composer\Util\Http\ProxyManager;
use Composer\Test\TestCase;
class ProxyManagerTest extends TestCase
{
2021-12-08 16:03:05 +00:00
protected function setUp(): void
2020-09-24 15:48:22 +00:00
{
unset(
$_SERVER['HTTP_PROXY'],
$_SERVER['http_proxy'],
$_SERVER['HTTPS_PROXY'],
$_SERVER['https_proxy'],
$_SERVER['NO_PROXY'],
$_SERVER['no_proxy'],
$_SERVER['CGI_HTTP_PROXY']
);
ProxyManager::reset();
}
2021-12-08 16:03:05 +00:00
protected function tearDown(): void
2020-09-24 15:48:22 +00:00
{
parent::tearDown();
2020-09-24 15:48:22 +00:00
unset(
$_SERVER['HTTP_PROXY'],
$_SERVER['http_proxy'],
$_SERVER['HTTPS_PROXY'],
$_SERVER['https_proxy'],
$_SERVER['NO_PROXY'],
$_SERVER['no_proxy'],
$_SERVER['CGI_HTTP_PROXY']
);
ProxyManager::reset();
}
public function testInstantiation(): void
2020-09-24 15:48:22 +00:00
{
$originalInstance = ProxyManager::getInstance();
$this->assertInstanceOf('Composer\Util\Http\ProxyManager', $originalInstance);
$sameInstance = ProxyManager::getInstance();
$this->assertTrue($originalInstance === $sameInstance);
ProxyManager::reset();
$newInstance = ProxyManager::getInstance();
$this->assertFalse($sameInstance === $newInstance);
}
public function testGetProxyForRequestThrowsOnBadProxyUrl(): void
2020-09-24 15:48:22 +00:00
{
$_SERVER['http_proxy'] = 'localhost';
$proxyManager = ProxyManager::getInstance();
2021-12-09 19:55:26 +00:00
self::expectException('Composer\Downloader\TransportException');
2020-09-24 15:48:22 +00:00
$proxyManager->getProxyForRequest('http://example.com');
}
/**
* @dataProvider dataRequest
2021-10-27 14:18:46 +00:00
*
* @param array<string, mixed> $server
* @param string $url
* @param string $expectedUrl
* @param mixed[] $expectedOptions
* @param bool $expectedSecure
* @param string $expectedMessage
2020-09-24 15:48:22 +00:00
*/
2022-02-22 15:47:09 +00:00
public function testGetProxyForRequest(array $server, string $url, string $expectedUrl, array $expectedOptions, bool $expectedSecure, string $expectedMessage): void
2020-09-24 15:48:22 +00:00
{
$_SERVER = array_merge($_SERVER, $server);
$proxyManager = ProxyManager::getInstance();
$proxy = $proxyManager->getProxyForRequest($url);
$this->assertInstanceOf('Composer\Util\Http\RequestProxy', $proxy);
$this->assertSame($expectedUrl, $proxy->getUrl());
$this->assertSame($expectedOptions, $proxy->getContextOptions());
$this->assertSame($expectedSecure, $proxy->isSecure());
$message = $proxy->getFormattedUrl();
2020-09-24 15:48:22 +00:00
if ($expectedMessage) {
$condition = stripos($message, $expectedMessage) !== false;
} else {
$condition = $expectedMessage === $message;
}
$this->assertTrue($condition, 'lastProxy check');
}
2022-02-21 12:42:28 +00:00
public function dataRequest(): array
2020-09-24 15:48:22 +00:00
{
$server = array(
'http_proxy' => 'http://user:p%40ss@proxy.com',
'https_proxy' => 'https://proxy.com:443',
'no_proxy' => 'other.repo.org',
);
// server, url, expectedUrl, expectedOptions, expectedSecure, expectedMessage
return array(
array(array(), 'http://repo.org', '', array(), false, ''),
array($server, 'http://repo.org', 'http://user:p%40ss@proxy.com:80',
array('http' => array(
'proxy' => 'tcp://proxy.com:80',
'header' => 'Proxy-Authorization: Basic dXNlcjpwQHNz',
'request_fulluri' => true,
2020-11-22 13:48:56 +00:00
)),
2020-09-24 15:48:22 +00:00
false,
'http://user:***@proxy.com:80',
),
array(
$server, 'https://repo.org', 'https://proxy.com:443',
array('http' => array(
'proxy' => 'ssl://proxy.com:443',
2020-11-22 13:48:56 +00:00
)),
2020-09-24 15:48:22 +00:00
true,
'https://proxy.com:443',
),
array($server, 'https://other.repo.org', '', array(), false, 'no_proxy'),
);
}
/**
* @dataProvider dataStatus
2021-10-27 14:18:46 +00:00
*
* @param array<string, mixed> $server
2020-09-24 15:48:22 +00:00
*/
2022-02-22 15:47:09 +00:00
public function testGetStatus(array $server, bool $expectedStatus, ?string $expectedMessage): void
2020-09-24 15:48:22 +00:00
{
$_SERVER = array_merge($_SERVER, $server);
$proxyManager = ProxyManager::getInstance();
$status = $proxyManager->isProxying();
$message = $proxyManager->getFormattedProxy();
2020-09-24 15:48:22 +00:00
$this->assertSame($expectedStatus, $status);
2022-02-22 15:47:09 +00:00
if ($expectedMessage !== null) {
2020-09-24 15:48:22 +00:00
$condition = stripos($message, $expectedMessage) !== false;
} else {
$condition = $expectedMessage === $message;
}
$this->assertTrue($condition, 'message check');
}
2022-02-21 12:42:28 +00:00
public function dataStatus(): array
2020-09-24 15:48:22 +00:00
{
// server, expectedStatus, expectedMessage
return array(
array(array(), false, null),
array(array('http_proxy' => 'localhost'), false, 'malformed'),
array(
array('http_proxy' => 'http://user:p%40ss@proxy.com:80'),
true,
2020-11-22 13:48:56 +00:00
'http=http://user:***@proxy.com:80',
2020-09-24 15:48:22 +00:00
),
array(
array('http_proxy' => 'proxy.com:80', 'https_proxy' => 'proxy.com:80'),
true,
2020-11-22 13:48:56 +00:00
'http=proxy.com:80, https=proxy.com:80',
2020-09-24 15:48:22 +00:00
),
);
}
}