123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Security\Test\Unit\Model\SecurityChecker;
- use Magento\Framework\HTTP\PhpEnvironment\RemoteAddress;
- use Magento\Framework\Stdlib\DateTime\DateTime;
- use Magento\Framework\TestFramework\Unit\Helper\ObjectManager;
- use Magento\Security\Model\ConfigInterface;
- /**
- * Test class for \Magento\Security\Model\SecurityChecker\Frequency testing
- */
- class FrequencyTest extends \PHPUnit\Framework\TestCase
- {
- /**
- * @var \Magento\Security\Model\SecurityChecker\Frequency
- */
- protected $model;
- /**
- * @var ConfigInterface
- */
- protected $securityConfigMock;
- /**
- * @var \Magento\Security\Model\ResourceModel\PasswordResetRequestEvent\CollectionFactory
- */
- protected $collectionFactoryMock;
- /**
- * @var \Magento\Security\Model\ResourceModel\PasswordResetRequestEvent\Collection
- */
- protected $collectionMock;
- /**
- * @var DateTime
- */
- protected $dateTimeMock;
- /**
- * @var \Magento\Framework\TestFramework\Unit\Helper\ObjectManager
- */
- protected $objectManager;
- /*
- * @var RemoteAddress
- */
- protected $remoteAddressMock;
- /**
- * Init mocks for tests
- * @return void
- */
- public function setUp()
- {
- $this->objectManager = new ObjectManager($this);
- $this->securityConfigMock = $this->getMockBuilder(\Magento\Security\Model\ConfigInterface::class)
- ->setMethods(['getScopeByEventType'])
- ->disableOriginalConstructor()
- ->getMockForAbstractClass();
- $this->securityConfigMock->expects($this->any())
- ->method('getScopeByEventType')
- ->willReturnMap(
- [
- [0, 1],
- [1, 0]
- ]
- );
- $this->collectionFactoryMock = $this->createPartialMock(
- \Magento\Security\Model\ResourceModel\PasswordResetRequestEvent\CollectionFactory::class,
- ['create']
- );
- $this->collectionMock = $this->createPartialMock(
- \Magento\Security\Model\ResourceModel\PasswordResetRequestEvent\Collection::class,
- ['addFieldToFilter', 'filterLastItem', 'getFirstItem']
- );
- $this->dateTimeMock = $this->getMockBuilder(DateTime::class)
- ->disableOriginalConstructor()
- ->getMock();
- $this->remoteAddressMock = $this->getMockBuilder(RemoteAddress::class)
- ->disableOriginalConstructor()
- ->getMock();
- $this->model = $this->objectManager->getObject(
- \Magento\Security\Model\SecurityChecker\Frequency::class,
- [
- 'securityConfig' => $this->securityConfigMock,
- 'collectionFactory' => $this->collectionFactoryMock,
- 'dateTime' => $this->dateTimeMock,
- 'remoteAddress' => $this->remoteAddressMock
- ]
- );
- }
- /**
- * @param int $securityEventType
- * @param int $requestsMethod
- * @dataProvider dataProviderSecurityEventTypeWithRequestsMethod
- */
- public function testCheck($securityEventType, $requestsMethod)
- {
- $limitTimeBetweenPasswordResetRequests = 600;
- $timestamp = time();
- $this->prepareTestCheck($requestsMethod, $limitTimeBetweenPasswordResetRequests);
- $this->dateTimeMock->expects($this->once())
- ->method('gmtTimestamp')
- ->willReturn($timestamp);
- /** @var \Magento\Security\Model\PasswordResetRequestEvent $record */
- $record = $this->objectManager->getObject(\Magento\Security\Model\PasswordResetRequestEvent::class);
- $record->setCreatedAt(
- date("Y-m-d H:i:s", $timestamp - $limitTimeBetweenPasswordResetRequests)
- );
- $this->collectionMock->expects($this->once())
- ->method('getFirstItem')
- ->willReturn($record);
- $this->model->check($securityEventType);
- }
- /**
- * @param int $securityEventType
- * @param int $requestsMethod
- * @dataProvider dataProviderSecurityEventTypeWithRequestsMethod
- * @expectedException \Magento\Framework\Exception\SecurityViolationException
- */
- public function testCheckException($securityEventType, $requestsMethod)
- {
- $limitTimeBetweenPasswordResetRequests = 600;
- $timestamp = time();
- $this->prepareTestCheck($requestsMethod, $limitTimeBetweenPasswordResetRequests);
- $this->dateTimeMock->expects($this->once())
- ->method('gmtTimestamp')
- ->willReturn($timestamp);
- /** @var \Magento\Security\Model\PasswordResetRequestEvent $record */
- $record = $this->objectManager->getObject(\Magento\Security\Model\PasswordResetRequestEvent::class);
- $record->setCreatedAt(
- date("Y-m-d H:i:s", $timestamp - $limitTimeBetweenPasswordResetRequests + 1)
- );
- $this->collectionMock->expects($this->once())
- ->method('getFirstItem')
- ->willReturn($record);
- $this->model->check($securityEventType);
- $this->expectExceptionMessage(
- 'We received too many requests for password resets. '
- . 'Please wait and try again later or contact test@host.com.'
- );
- }
- /**
- * @return array
- */
- public function dataProviderSecurityEventTypeWithRequestsMethod()
- {
- return [
- [
- \Magento\Security\Model\PasswordResetRequestEvent::CUSTOMER_PASSWORD_RESET_REQUEST,
- \Magento\Security\Model\Config\Source\ResetMethod::OPTION_BY_IP_AND_EMAIL
- ],
- [
- \Magento\Security\Model\PasswordResetRequestEvent::CUSTOMER_PASSWORD_RESET_REQUEST,
- \Magento\Security\Model\Config\Source\ResetMethod::OPTION_BY_IP
- ],
- [
- \Magento\Security\Model\PasswordResetRequestEvent::CUSTOMER_PASSWORD_RESET_REQUEST,
- \Magento\Security\Model\Config\Source\ResetMethod::OPTION_BY_EMAIL
- ],
- [
- \Magento\Security\Model\PasswordResetRequestEvent::ADMIN_PASSWORD_RESET_REQUEST,
- \Magento\Security\Model\Config\Source\ResetMethod::OPTION_BY_IP_AND_EMAIL
- ],
- [
- \Magento\Security\Model\PasswordResetRequestEvent::ADMIN_PASSWORD_RESET_REQUEST,
- \Magento\Security\Model\Config\Source\ResetMethod::OPTION_BY_IP
- ],
- [
- \Magento\Security\Model\PasswordResetRequestEvent::ADMIN_PASSWORD_RESET_REQUEST,
- \Magento\Security\Model\Config\Source\ResetMethod::OPTION_BY_EMAIL
- ],
- ];
- }
- /**
- * @param int $requestsMethod
- * @param int $limitTimeBetweenPasswordResetRequests
- */
- protected function prepareTestCheck($requestsMethod, $limitTimeBetweenPasswordResetRequests)
- {
- $this->remoteAddressMock->expects($this->once())
- ->method('getRemoteAddress')
- ->will($this->returnValue(12345));
- $this->securityConfigMock->expects($this->any())
- ->method('getPasswordResetProtectionType')
- ->will($this->returnValue($requestsMethod));
- $this->securityConfigMock->expects($this->once())
- ->method('getMinTimeBetweenPasswordResetRequests')
- ->will($this->returnValue($limitTimeBetweenPasswordResetRequests));
- $this->securityConfigMock->expects($this->any())
- ->method('getCustomerServiceEmail')
- ->will($this->returnValue('test@host.com'));
- $this->collectionFactoryMock->expects($this->once())
- ->method('create')
- ->willReturn($this->collectionMock);
- $this->collectionMock->expects($this->any())
- ->method('addFieldToFilter')
- ->willReturnSelf();
- $this->collectionMock->expects($this->once())
- ->method('filterLastItem')
- ->willReturnSelf();
- }
- }
|