123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- declare(strict_types=1);
- namespace Magento\ReleaseNotification\Test\Unit\Controller\Notification;
- use Psr\Log\LoggerInterface;
- use Magento\Backend\App\Action\Context;
- use Magento\Backend\Model\Auth\Credential\StorageInterface;
- use Magento\Backend\Model\Auth;
- use Magento\Framework\Controller\Result\Json;
- use Magento\Framework\Controller\ResultFactory;
- use Magento\Framework\Exception\LocalizedException;
- use Magento\ReleaseNotification\Model\ResourceModel\Viewer\Logger as NotificationLogger;
- use Magento\Framework\App\ProductMetadataInterface;
- use Magento\Framework\TestFramework\Unit\Helper\ObjectManager as ObjectManagerHelper;
- use Magento\ReleaseNotification\Controller\Adminhtml\Notification\MarkUserNotified;
- /**
- * @SuppressWarnings(PHPMD.CouplingBetweenObjects)
- */
- class MarkUserNotifiedTest extends \PHPUnit\Framework\TestCase
- {
- /**
- * @var \PHPUnit_Framework_MockObject_MockObject|StorageInterface
- */
- private $storageMock;
- /**
- * @var \PHPUnit_Framework_MockObject_MockObject|Auth
- */
- private $authMock;
- /**
- * @var \PHPUnit_Framework_MockObject_MockObject|LoggerInterface
- */
- private $loggerMock;
- /**
- * @var \PHPUnit_Framework_MockObject_MockObject|Json
- */
- private $resultMock;
- /**
- * @var \PHPUnit_Framework_MockObject_MockObject|ProductMetadataInterface
- */
- private $productMetadataMock;
- /**
- * @var \PHPUnit_Framework_MockObject_MockObject|NotificationLogger
- */
- private $notificationLoggerMock;
- /**
- * @var MarkUserNotified
- */
- private $action;
- public function setUp()
- {
- $this->storageMock = $this->getMockBuilder(StorageInterface::class)
- ->setMethods(['getId'])
- ->getMockForAbstractClass();
- $this->authMock = $this->getMockBuilder(Auth::class)
- ->disableOriginalConstructor()
- ->getMock();
- $contextMock = $this->getMockBuilder(Context::class)
- ->disableOriginalConstructor()
- ->getMock();
- $contextMock->expects($this->once())
- ->method('getAuth')
- ->willReturn($this->authMock);
- $this->productMetadataMock = $this->getMockBuilder(ProductMetadataInterface::class)
- ->getMockForAbstractClass();
- $this->notificationLoggerMock = $this->getMockBuilder(NotificationLogger::class)
- ->disableOriginalConstructor()
- ->getMock();
- $this->loggerMock = $this->getMockBuilder(LoggerInterface::class)
- ->getMock();
- $resultFactoryMock = $this->getMockBuilder(ResultFactory::class)
- ->disableOriginalConstructor()
- ->getMock();
- $this->resultMock = $this->getMockBuilder(Json::class)
- ->disableOriginalConstructor()
- ->getMock();
- $resultFactoryMock->expects($this->once())
- ->method('create')
- ->with(ResultFactory::TYPE_JSON)
- ->willReturn($this->resultMock);
- $objectManagerHelper = new ObjectManagerHelper($this);
- $this->action = $objectManagerHelper->getObject(
- MarkUserNotified::class,
- [
- 'resultFactory' => $resultFactoryMock,
- 'productMetadata' => $this->productMetadataMock,
- 'notificationLogger' => $this->notificationLoggerMock,
- 'context' => $contextMock,
- 'logger' => $this->loggerMock
- ]
- );
- }
- public function testExecuteSuccess()
- {
- $this->authMock->expects($this->once())
- ->method('getUser')
- ->willReturn($this->storageMock);
- $this->storageMock->expects($this->once())
- ->method('getId')
- ->willReturn(1);
- $this->productMetadataMock->expects($this->once())
- ->method('getVersion')
- ->willReturn('999.999.999-alpha');
- $this->notificationLoggerMock->expects($this->once())
- ->method('log')
- ->with(1, '999.999.999-alpha')
- ->willReturn(true);
- $this->resultMock->expects($this->once())
- ->method('setData')
- ->with(
- [
- 'success' => true,
- 'error_message' => ''
- ],
- false,
- []
- )->willReturnSelf();
- $this->assertEquals($this->resultMock, $this->action->execute());
- }
- public function testExecuteFailedWithLocalizedException()
- {
- $this->authMock->expects($this->once())
- ->method('getUser')
- ->willReturn($this->storageMock);
- $this->storageMock->expects($this->once())
- ->method('getId')
- ->willReturn(1);
- $this->productMetadataMock->expects($this->once())
- ->method('getVersion')
- ->willReturn('999.999.999-alpha');
- $this->notificationLoggerMock->expects($this->once())
- ->method('log')
- ->willThrowException(new LocalizedException(__('Error message')));
- $this->resultMock->expects($this->once())
- ->method('setData')
- ->with(
- [
- 'success' => false,
- 'error_message' => 'Error message'
- ],
- false,
- []
- )->willReturnSelf();
- $this->assertEquals($this->resultMock, $this->action->execute());
- }
- public function testExecuteFailedWithException()
- {
- $this->authMock->expects($this->once())
- ->method('getUser')
- ->willReturn($this->storageMock);
- $this->storageMock->expects($this->once())
- ->method('getId')
- ->willReturn(1);
- $this->productMetadataMock->expects($this->once())
- ->method('getVersion')
- ->willReturn('999.999.999-alpha');
- $this->notificationLoggerMock->expects($this->once())
- ->method('log')
- ->willThrowException(new \Exception('Any message'));
- $this->resultMock->expects($this->once())
- ->method('setData')
- ->with(
- [
- 'success' => false,
- 'error_message' => __('It is impossible to log user action')
- ],
- false,
- []
- )->willReturnSelf();
- $this->assertEquals($this->resultMock, $this->action->execute());
- }
- }
|