| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536 | <?php/** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */namespace Magento\Webapi\Test\Unit\Model\Authorization;use Magento\Webapi\Model\Authorization\TokenUserContext;use Magento\Framework\TestFramework\Unit\Helper\ObjectManager;use Magento\Authorization\Model\UserContextInterface;use Magento\Integration\Model\Oauth\TokenFactory;use Magento\Integration\Model\Oauth\Token;use Magento\Integration\Api\IntegrationServiceInterface;use Magento\Framework\Webapi\Request;use Magento\Integration\Helper\Oauth\Data as OauthHelper;use Magento\Framework\Stdlib\DateTime\DateTime as Date;use Magento\Framework\Stdlib\DateTime;use Magento\Integration\Model\Integration;/** * Tests for TokenUserContext. */class TokenUserContextTest extends \PHPUnit\Framework\TestCase{    /**     * @var ObjectManager     */    protected $objectManager;    /**     * @var TokenUserContext     */    protected $tokenUserContext;    /**     * @var TokenFactory|\PHPUnit_Framework_MockObject_MockObject     */    protected $tokenFactory;    /**     * @var IntegrationServiceInterface|\PHPUnit_Framework_MockObject_MockObject     */    protected $integrationService;    /**     * @var Request|\PHPUnit_Framework_MockObject_MockObject     */    protected $request;    /**     * @var OauthHelper|\PHPUnit_Framework_MockObject_MockObject     */    private $oauthHelperMock;    /**     * @var Date|\PHPUnit_Framework_MockObject_MockObject     */    private $dateMock;    /**     * @var DateTime|\PHPUnit_Framework_MockObject_MockObject     */    private $dateTimeMock;    protected function setUp()    {        $this->objectManager = new ObjectManager($this);        $this->request = $this->getMockBuilder(Request::class)            ->disableOriginalConstructor()            ->setMethods(['getHeader'])            ->getMock();        $this->tokenFactory = $this->getMockBuilder(TokenFactory::class)            ->disableOriginalConstructor()            ->setMethods(['create'])            ->getMock();        $this->integrationService = $this->getMockBuilder(IntegrationServiceInterface::class)            ->disableOriginalConstructor()            ->setMethods(                [                    'findByName',                    'update',                    'create',                    'get',                    'findByConsumerId',                    'findActiveIntegrationByConsumerId',                    'delete',                    'getSelectedResources',                ]            )            ->getMock();        $this->oauthHelperMock = $this->getMockBuilder(OauthHelper::class)            ->disableOriginalConstructor()            ->setMethods(['getAdminTokenLifetime', 'getCustomerTokenLifetime'])            ->getMock();        $this->dateMock = $this->getMockBuilder(Date::class)            ->disableOriginalConstructor()            ->setMethods(['gmtTimestamp'])            ->getMock();        $this->dateTimeMock = $this->getMockBuilder(DateTime::class)            ->disableOriginalConstructor()            ->setMethods(['strToTime'])            ->getMock();        $this->dateTimeMock->expects($this->any())            ->method('strToTime')            ->will(                $this->returnCallback(                    function ($str) {                        return strtotime($str);                    }                )            );        $this->tokenUserContext = $this->objectManager->getObject(            TokenUserContext::class,            [                'request' => $this->request,                'tokenFactory' => $this->tokenFactory,                'integrationService' => $this->integrationService,                'oauthHelper' => $this->oauthHelperMock,                'date' => $this->dateMock,                'dateTime' => $this->dateTimeMock,            ]        );    }    public function testNoAuthorizationHeader()    {        $this->request->expects($this->once())            ->method('getHeader')            ->with('Authorization')            ->will($this->returnValue(null));        $this->assertNull($this->tokenUserContext->getUserType());        $this->assertNull($this->tokenUserContext->getUserId());    }    public function testNoTokenInHeader()    {        $this->request->expects($this->once())            ->method('getHeader')            ->with('Authorization')            ->will($this->returnValue('Bearer'));        $this->assertNull($this->tokenUserContext->getUserType());        $this->assertNull($this->tokenUserContext->getUserId());    }    public function testNotBearerToken()    {        $this->request->expects($this->once())            ->method('getHeader')            ->with('Authorization')            ->will($this->returnValue('Access'));        $this->assertNull($this->tokenUserContext->getUserType());        $this->assertNull($this->tokenUserContext->getUserId());    }    public function testNoTokenInDatabase()    {        $bearerToken = 'bearer1234';        $this->request->expects($this->once())            ->method('getHeader')            ->with('Authorization')            ->will($this->returnValue("Bearer {$bearerToken}"));        $token = $this->getMockBuilder(Token::class)            ->disableOriginalConstructor()            ->setMethods(['loadByToken', 'getId', '__wakeup'])            ->getMock();        $this->tokenFactory->expects($this->once())            ->method('create')            ->will($this->returnValue($token));        $token->expects($this->once())            ->method('loadByToken')            ->with($bearerToken)            ->will($this->returnSelf());        $token->expects($this->once())            ->method('getId')            ->will($this->returnValue(null));        $this->assertNull($this->tokenUserContext->getUserType());        $this->assertNull($this->tokenUserContext->getUserId());    }    public function testRevokedToken()    {        $bearerToken = 'bearer1234';        $this->request->expects($this->once())            ->method('getHeader')            ->with('Authorization')            ->will($this->returnValue("Bearer {$bearerToken}"));        $token = $this->getMockBuilder(Token::class)            ->disableOriginalConstructor()            ->setMethods(['loadByToken', 'getId', 'getRevoked', '__wakeup'])            ->getMock();        $this->tokenFactory->expects($this->once())            ->method('create')            ->will($this->returnValue($token));        $token->expects($this->once())            ->method('loadByToken')            ->with($bearerToken)            ->will($this->returnSelf());        $token->expects($this->once())            ->method('getId')            ->will($this->returnValue(1));        $token->expects($this->once())            ->method('getRevoked')            ->will($this->returnValue(1));        $this->assertNull($this->tokenUserContext->getUserType());        $this->assertNull($this->tokenUserContext->getUserId());    }    /**     * @dataProvider getValidTokenData     */    public function testValidToken($userType, $userId, $expectedUserType, $expectedUserId)    {        $bearerToken = 'bearer1234';        $this->request->expects($this->once())            ->method('getHeader')            ->with('Authorization')            ->will($this->returnValue("Bearer {$bearerToken}"));        $token = $this->getMockBuilder(Token::class)            ->disableOriginalConstructor()            ->setMethods(                [                    'loadByToken',                    'getId',                    'getUserType',                    'getCustomerId',                    'getAdminId',                    '__wakeup',                    'getCreatedAt',                ]            )->getMock();        $this->tokenFactory->expects($this->once())            ->method('create')            ->will($this->returnValue($token));        $token->expects($this->once())            ->method('loadByToken')            ->with($bearerToken)            ->will($this->returnSelf());        $token->expects($this->once())            ->method('getId')            ->will($this->returnValue(1));        $token->expects($this->any())            ->method('getUserType')            ->will($this->returnValue($userType));        $token->expects($this->any())            ->method('getCreatedAt')            ->willReturn(date('Y-m-d H:i:s', time()));        switch ($userType) {            case UserContextInterface::USER_TYPE_INTEGRATION:                $integration = $this->getMockBuilder(Integration::class)                    ->disableOriginalConstructor()                    ->setMethods(['getId', '__wakeup'])                    ->getMock();                $integration->expects($this->once())                    ->method('getId')                    ->will($this->returnValue($userId));                $this->integrationService->expects($this->once())                    ->method('findByConsumerId')                    ->will($this->returnValue($integration));                break;            case UserContextInterface::USER_TYPE_ADMIN:                $token->expects($this->once())                    ->method('getAdminId')                    ->will($this->returnValue($userId));                break;            case UserContextInterface::USER_TYPE_CUSTOMER:                $token->expects($this->once())                    ->method('getCustomerId')                    ->will($this->returnValue($userId));                break;        }        $this->assertEquals($expectedUserType, $this->tokenUserContext->getUserType());        $this->assertEquals($expectedUserId, $this->tokenUserContext->getUserId());        /* check again to make sure that the above methods were only called once */        $this->assertEquals($expectedUserType, $this->tokenUserContext->getUserType());        $this->assertEquals($expectedUserId, $this->tokenUserContext->getUserId());    }    /**     * @return array     */    public function getValidTokenData()    {        return [            'admin token' => [                UserContextInterface::USER_TYPE_ADMIN,                1234,                UserContextInterface::USER_TYPE_ADMIN,                1234,            ],            'customer token' => [                UserContextInterface::USER_TYPE_CUSTOMER,                1234,                UserContextInterface::USER_TYPE_CUSTOMER,                1234,            ],            'integration token' => [                UserContextInterface::USER_TYPE_INTEGRATION,                1234,                UserContextInterface::USER_TYPE_INTEGRATION,                1234,            ],            'guest user type' => [                UserContextInterface::USER_TYPE_GUEST,                1234,                null,                null,            ]        ];    }    /**     * @param array $tokenData     * @param int $tokenTtl     * @param int $currentTime     * @param int|null $expectedUserType     * @param int|null $expectedUserId     * @return void     * @dataProvider getExpiredTestTokenData     */    public function testExpiredToken(        array $tokenData,        int $tokenTtl,        int $currentTime,        $expectedUserType,        $expectedUserId    ) {        $bearerToken = 'bearer1234';        $this->dateMock->expects($this->any())            ->method('gmtTimestamp')            ->willReturn($currentTime);        $this->request->expects($this->once())            ->method('getHeader')            ->with('Authorization')            ->will($this->returnValue("Bearer {$bearerToken}"));        $token = $this->getMockBuilder(Token::class)            ->disableOriginalConstructor()            ->setMethods(                [                    'loadByToken',                    'getCreatedAt',                    'getId',                    'getUserType',                    'getCustomerId',                    'getAdminId',                    '__wakeup',                ]            )->getMock();        $token->expects($this->once())            ->method('loadByToken')            ->with($bearerToken)            ->will($this->returnSelf());        $token->expects($this->any())            ->method('getId')            ->will($this->returnValue(1));        $token->expects($this->any())            ->method('getUserType')            ->will($this->returnValue($tokenData['user_type']));        $token->expects($this->any())            ->method('getCreatedAt')            ->willReturn($tokenData['created_at']);        $this->tokenFactory->expects($this->once())            ->method('create')            ->will($this->returnValue($token));        $this->oauthHelperMock->expects($this->any())            ->method('getAdminTokenLifetime')            ->willReturn($tokenTtl);        $this->oauthHelperMock->expects($this->any())            ->method('getCustomerTokenLifetime')            ->willReturn($tokenTtl);        switch ($tokenData['user_type']) {            case UserContextInterface::USER_TYPE_INTEGRATION:                $integration = $this->getMockBuilder(Integration::class)                    ->disableOriginalConstructor()                    ->setMethods(['getId', '__wakeup'])                    ->getMock();                $integration->expects($this->any())                    ->method('getId')                    ->will($this->returnValue($tokenData['user_id']));                $this->integrationService->expects($this->any())                    ->method('findByConsumerId')                    ->will($this->returnValue($integration));                break;            case UserContextInterface::USER_TYPE_ADMIN:                $token->expects($this->any())                    ->method('getAdminId')                    ->will($this->returnValue($tokenData['user_id']));                break;            case UserContextInterface::USER_TYPE_CUSTOMER:                $token->expects($this->any())                    ->method('getCustomerId')                    ->will($this->returnValue($tokenData['user_id']));                break;        }        $this->assertEquals($expectedUserType, $this->tokenUserContext->getUserType());        $this->assertEquals($expectedUserId, $this->tokenUserContext->getUserId());        /* check again to make sure that the above method loadByToken in only called once */        $this->assertEquals($expectedUserType, $this->tokenUserContext->getUserType());        $this->assertEquals($expectedUserId, $this->tokenUserContext->getUserId());    }    /**     * Data provider for expired token test.     *     * @return array     */    public function getExpiredTestTokenData()    {        $time = time();        return [            'token_expired_admin' => [                'tokenData' => [                    'user_type' => UserContextInterface::USER_TYPE_ADMIN,                    'user_id' => 1234,                    'created_at' => date('Y-m-d H:i:s', $time - 3600 - 400),                ],                'tokenTtl' => 1,                'currentTime' => $time,                'expectedUserType' => null,                'expectedUserId' => null,            ],            'token_vigent_admin' => [                'tokenData' => [                    'user_type' => UserContextInterface::USER_TYPE_ADMIN,                    'user_id' => 1234,                    'created_at' => date('Y-m-d H:i:s', $time - 400),                ],                'tokenTtl' => 1,                'currentTime' => $time,                'expectedUserType' => UserContextInterface::USER_TYPE_ADMIN,                'expectedUserId' => 1234,            ],            'token_expired_customer' => [                'tokenData' => [                    'user_type' => UserContextInterface::USER_TYPE_CUSTOMER,                    'user_id' => 1234,                    'created_at' => date('Y-m-d H:i:s', $time - 3600 - 400),                ],                'tokenTtl' => 1,                'currentTime' => $time,                'expectedUserType' => null,                'expectedUserId' => null,            ],            'token_vigent_customer' => [                'tokenData' => [                    'user_type' => UserContextInterface::USER_TYPE_CUSTOMER,                    'user_id' => 1234,                    'created_at' => date('Y-m-d H:i:s', $time - 400),                ],                'tokenTtl' => 1,                'currentTime' => $time,                'expectedUserType' => UserContextInterface::USER_TYPE_CUSTOMER,                'expectedUserId' => 1234,            ],            'token_expired_integration' => [                'tokenData' => [                    'user_type' => UserContextInterface::USER_TYPE_INTEGRATION,                    'user_id' => 1234,                    'created_at' => date('Y-m-d H:i:s', $time - 3600 - 400),                ],                'tokenTtl' => 1,                'currentTime' => $time,                'expectedUserType' => UserContextInterface::USER_TYPE_INTEGRATION,                'expectedUserId' => 1234,            ],            'token_vigent_integration' => [                'tokenData' => [                    'user_type' => UserContextInterface::USER_TYPE_INTEGRATION,                    'user_id' => 1234,                    'created_at' => date('Y-m-d H:i:s', $time - 400),                ],                'tokenTtl' => 1,                'currentTime' => $time,                'expectedUserType' => UserContextInterface::USER_TYPE_INTEGRATION,                'expectedUserId' => 1234,            ],            'token_expired_guest' => [                'tokenData' => [                    'user_type' => UserContextInterface::USER_TYPE_GUEST,                    'user_id' => 1234,                    'created_at' => date('Y-m-d H:i:s', $time - 3600 - 400),                ],                'tokenTtl' => 1,                'currentTime' => $time,                'expectedUserType' => null,                'expectedUserId' => null,            ],            'token_vigent_guest' => [                'tokenData' => [                    'user_type' => UserContextInterface::USER_TYPE_GUEST,                    'user_id' => 1234,                    'created_at' => date('Y-m-d H:i:s', $time - 400),                ],                'tokenTtl' => 1,                'currentTime' => $time,                'expectedUserType' => null,                'expectedUserId' => null,            ],        ];    }}
 |