|
Apache/2.4.41 (Ubuntu) Linux vmi616275.contaboserver.net 5.4.0-84-generic #94-Ubuntu SMP Thu Aug 26 20:27:37 UTC 2021 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) server ip : 62.171.164.128 | your ip : 127.0.0.1 safemode OFF > / home / dev2.destoffenstraat.com / vendor / magento / framework / HTTP / Test / Unit / |
Filename | /home/dev2.destoffenstraat.com/vendor/magento/framework/HTTP/Test/Unit/AuthenticationTest.php |
Size | 3.29 kb |
Permission | rw-r--r-- |
Owner | root : root |
Create time | 17-Aug-2025 10:26 |
Last modified | 07-Jan-2021 21:08 |
Last accessed | 23-Aug-2025 03:56 |
Actions | edit | rename | delete | download (gzip) |
View | text | code | image |
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);
namespace Magento\Framework\HTTP\Test\Unit;
use Magento\Framework\App\Request\Http;
use Magento\Framework\HTTP\Authentication;
use Magento\Framework\TestFramework\Unit\Helper\ObjectManager;
use PHPUnit\Framework\TestCase;
class AuthenticationTest extends TestCase
{
/**
* @param array $server
* @param string $expectedLogin
* @param string $expectedPass
* @dataProvider getCredentialsDataProvider
*/
public function testGetCredentials($server, $expectedLogin, $expectedPass)
{
$request = $this->createMock(Http::class);
$request->expects($this->once())->method('getServerValue')->willReturn($server);
$response = $this->createMock(\Magento\Framework\App\Response\Http::class);
$authentication = new Authentication($request, $response);
$this->assertSame([$expectedLogin, $expectedPass], $authentication->getCredentials());
}
/**
* @return array
*/
public function getCredentialsDataProvider()
{
$login = 'login';
$password = 'password';
$header = 'Basic bG9naW46cGFzc3dvcmQ=';
$anotherLogin = 'another_login';
$anotherPassword = 'another_password';
$anotherHeader = 'Basic YW5vdGhlcl9sb2dpbjphbm90aGVyX3Bhc3N3b3Jk';
return [
[[], '', ''],
[['REDIRECT_HTTP_AUTHORIZATION' => $header], $login, $password],
[['HTTP_AUTHORIZATION' => $header], $login, $password],
[['Authorization' => $header], $login, $password],
[
[
'REDIRECT_HTTP_AUTHORIZATION' => $header,
'PHP_AUTH_USER' => $anotherLogin,
'PHP_AUTH_PW' => $anotherPassword,
],
$anotherLogin,
$anotherPassword
],
[
[
'REDIRECT_HTTP_AUTHORIZATION' => $header,
'PHP_AUTH_USER' => $anotherLogin,
'PHP_AUTH_PW' => $anotherPassword,
],
$anotherLogin,
$anotherPassword
],
[
['REDIRECT_HTTP_AUTHORIZATION' => $header, 'HTTP_AUTHORIZATION' => $anotherHeader],
$anotherLogin,
$anotherPassword
]
];
}
public function testSetAuthenticationFailed()
{
$objectManager = new ObjectManager($this);
$request = $objectManager->getObject(Http::class);
$response = $objectManager->getObject(\Magento\Framework\App\Response\Http::class);
$authentication = $objectManager->getObject(
Authentication::class,
[
'httpRequest' => $request,
'httpResponse' => $response
]
);
$realm = uniqid();
$authentication->setAuthenticationFailed($realm);
$headers = $response->getHeaders();
$this->assertTrue($headers->has('WWW-Authenticate'));
$header = $headers->get('WWW-Authenticate');
$this->assertEquals('Basic realm="' . $realm . '"', $header->current()->getFieldValue());
$this->assertStringContainsString('401', $response->getBody());
}
}
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);
namespace Magento\Framework\HTTP\Test\Unit;
use Magento\Framework\App\Request\Http;
use Magento\Framework\HTTP\Authentication;
use Magento\Framework\TestFramework\Unit\Helper\ObjectManager;
use PHPUnit\Framework\TestCase;
class AuthenticationTest extends TestCase
{
/**
* @param array $server
* @param string $expectedLogin
* @param string $expectedPass
* @dataProvider getCredentialsDataProvider
*/
public function testGetCredentials($server, $expectedLogin, $expectedPass)
{
$request = $this->createMock(Http::class);
$request->expects($this->once())->method('getServerValue')->willReturn($server);
$response = $this->createMock(\Magento\Framework\App\Response\Http::class);
$authentication = new Authentication($request, $response);
$this->assertSame([$expectedLogin, $expectedPass], $authentication->getCredentials());
}
/**
* @return array
*/
public function getCredentialsDataProvider()
{
$login = 'login';
$password = 'password';
$header = 'Basic bG9naW46cGFzc3dvcmQ=';
$anotherLogin = 'another_login';
$anotherPassword = 'another_password';
$anotherHeader = 'Basic YW5vdGhlcl9sb2dpbjphbm90aGVyX3Bhc3N3b3Jk';
return [
[[], '', ''],
[['REDIRECT_HTTP_AUTHORIZATION' => $header], $login, $password],
[['HTTP_AUTHORIZATION' => $header], $login, $password],
[['Authorization' => $header], $login, $password],
[
[
'REDIRECT_HTTP_AUTHORIZATION' => $header,
'PHP_AUTH_USER' => $anotherLogin,
'PHP_AUTH_PW' => $anotherPassword,
],
$anotherLogin,
$anotherPassword
],
[
[
'REDIRECT_HTTP_AUTHORIZATION' => $header,
'PHP_AUTH_USER' => $anotherLogin,
'PHP_AUTH_PW' => $anotherPassword,
],
$anotherLogin,
$anotherPassword
],
[
['REDIRECT_HTTP_AUTHORIZATION' => $header, 'HTTP_AUTHORIZATION' => $anotherHeader],
$anotherLogin,
$anotherPassword
]
];
}
public function testSetAuthenticationFailed()
{
$objectManager = new ObjectManager($this);
$request = $objectManager->getObject(Http::class);
$response = $objectManager->getObject(\Magento\Framework\App\Response\Http::class);
$authentication = $objectManager->getObject(
Authentication::class,
[
'httpRequest' => $request,
'httpResponse' => $response
]
);
$realm = uniqid();
$authentication->setAuthenticationFailed($realm);
$headers = $response->getHeaders();
$this->assertTrue($headers->has('WWW-Authenticate'));
$header = $headers->get('WWW-Authenticate');
$this->assertEquals('Basic realm="' . $realm . '"', $header->current()->getFieldValue());
$this->assertStringContainsString('401', $response->getBody());
}
}