2022-02-23 15:58:18 +00:00
|
|
|
<?php declare(strict_types=1);
|
2018-11-16 13:43:25 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* 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;
|
|
|
|
|
2021-11-24 15:00:57 +00:00
|
|
|
use Composer\IO\BufferIO;
|
2018-11-16 13:43:25 +00:00
|
|
|
use Composer\Util\HttpDownloader;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
|
|
|
class HttpDownloaderTest extends TestCase
|
|
|
|
{
|
2021-10-27 14:18:46 +00:00
|
|
|
/**
|
|
|
|
* @return \PHPUnit\Framework\MockObject\MockObject&\Composer\Config
|
|
|
|
*/
|
2018-11-16 13:43:25 +00:00
|
|
|
private function getConfigMock()
|
|
|
|
{
|
|
|
|
$config = $this->getMockBuilder('Composer\Config')->getMock();
|
|
|
|
$config->expects($this->any())
|
|
|
|
->method('get')
|
|
|
|
->will($this->returnCallback(function ($key) {
|
|
|
|
if ($key === 'github-domains' || $key === 'gitlab-domains') {
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
|
|
|
|
return $config;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @group slow
|
|
|
|
*/
|
2022-02-18 09:38:54 +00:00
|
|
|
public function testCaptureAuthenticationParamsFromUrl(): void
|
2018-11-16 13:43:25 +00:00
|
|
|
{
|
|
|
|
$io = $this->getMockBuilder('Composer\IO\IOInterface')->getMock();
|
|
|
|
$io->expects($this->once())
|
|
|
|
->method('setAuthentication')
|
|
|
|
->with($this->equalTo('github.com'), $this->equalTo('user'), $this->equalTo('pass'));
|
|
|
|
|
|
|
|
$fs = new HttpDownloader($io, $this->getConfigMock());
|
|
|
|
try {
|
|
|
|
$fs->get('https://user:pass@github.com/composer/composer/404');
|
|
|
|
} catch (\Composer\Downloader\TransportException $e) {
|
|
|
|
$this->assertNotEquals(200, $e->getCode());
|
|
|
|
}
|
|
|
|
}
|
2021-11-24 15:00:57 +00:00
|
|
|
|
2022-02-18 09:38:54 +00:00
|
|
|
public function testOutputWarnings(): void
|
2021-11-24 15:00:57 +00:00
|
|
|
{
|
|
|
|
$io = new BufferIO();
|
|
|
|
HttpDownloader::outputWarnings($io, '$URL', array());
|
|
|
|
$this->assertSame('', $io->getOutput());
|
|
|
|
HttpDownloader::outputWarnings($io, '$URL', array(
|
|
|
|
'warning' => 'old warning msg',
|
|
|
|
'warning-versions' => '>=2.0',
|
|
|
|
'info' => 'old info msg',
|
|
|
|
'info-versions' => '>=2.0',
|
|
|
|
'warnings' => array(
|
|
|
|
array('message' => 'should not appear', 'versions' => '<2.2'),
|
|
|
|
array('message' => 'visible warning', 'versions' => '>=2.2-dev'),
|
|
|
|
),
|
|
|
|
'infos' => array(
|
|
|
|
array('message' => 'should not appear', 'versions' => '<2.2'),
|
|
|
|
array('message' => 'visible info', 'versions' => '>=2.2-dev'),
|
|
|
|
),
|
|
|
|
));
|
|
|
|
|
|
|
|
// the <info> tag are consumed by the OutputFormatter, but not <warning> as that is not a default output format
|
2021-11-24 15:19:37 +00:00
|
|
|
$this->assertSame(
|
|
|
|
'<warning>Warning from $URL: old warning msg</warning>'.PHP_EOL.
|
|
|
|
'Info from $URL: old info msg'.PHP_EOL.
|
|
|
|
'<warning>Warning from $URL: visible warning</warning>'.PHP_EOL.
|
|
|
|
'Info from $URL: visible info'.PHP_EOL,
|
|
|
|
$io->getOutput()
|
|
|
|
);
|
2021-11-24 15:00:57 +00:00
|
|
|
}
|
2018-11-16 13:43:25 +00:00
|
|
|
}
|