aboutsummaryrefslogblamecommitdiffstats
path: root/library/oauth2/test/OAuth2/Storage/AccessTokenTest.php
blob: b34e0bfc010144a2483b8f7b85abe4f0c7ae967f (plain) (tree)





































































































                                                                                                   
<?php

namespace OAuth2\Storage;

class AccessTokenTest extends BaseTest
{
    /** @dataProvider provideStorage */
    public function testSetAccessToken(AccessTokenInterface $storage)
    {
        if ($storage instanceof NullStorage) {
            $this->markTestSkipped('Skipped Storage: ' . $storage->getMessage());

            return;
        }

        // assert token we are about to add does not exist
        $token = $storage->getAccessToken('newtoken');
        $this->assertFalse($token);

        // add new token
        $expires = time() + 20;
        $success = $storage->setAccessToken('newtoken', 'client ID', 'SOMEUSERID', $expires);
        $this->assertTrue($success);

        $token = $storage->getAccessToken('newtoken');
        $this->assertNotNull($token);
        $this->assertArrayHasKey('access_token', $token);
        $this->assertArrayHasKey('client_id', $token);
        $this->assertArrayHasKey('user_id', $token);
        $this->assertArrayHasKey('expires', $token);
        $this->assertEquals($token['access_token'], 'newtoken');
        $this->assertEquals($token['client_id'], 'client ID');
        $this->assertEquals($token['user_id'], 'SOMEUSERID');
        $this->assertEquals($token['expires'], $expires);

        // change existing token
        $expires = time() + 42;
        $success = $storage->setAccessToken('newtoken', 'client ID2', 'SOMEOTHERID', $expires);
        $this->assertTrue($success);

        $token = $storage->getAccessToken('newtoken');
        $this->assertNotNull($token);
        $this->assertArrayHasKey('access_token', $token);
        $this->assertArrayHasKey('client_id', $token);
        $this->assertArrayHasKey('user_id', $token);
        $this->assertArrayHasKey('expires', $token);
        $this->assertEquals($token['access_token'], 'newtoken');
        $this->assertEquals($token['client_id'], 'client ID2');
        $this->assertEquals($token['user_id'], 'SOMEOTHERID');
        $this->assertEquals($token['expires'], $expires);

        // add token with scope having an empty string value
        $expires = time() + 42;
        $success = $storage->setAccessToken('newtoken', 'client ID', 'SOMEOTHERID', $expires, '');
        $this->assertTrue($success);
    }

    /** @dataProvider provideStorage */
    public function testUnsetAccessToken(AccessTokenInterface $storage)
    {
        if ($storage instanceof NullStorage || !method_exists($storage, 'unsetAccessToken')) {
            $this->markTestSkipped('Skipped Storage: ' . $storage->getMessage());

            return;
        }

        // assert token we are about to unset does not exist
        $token = $storage->getAccessToken('revokabletoken');
        $this->assertFalse($token);

        // add new token
        $expires = time() + 20;
        $success = $storage->setAccessToken('revokabletoken', 'client ID', 'SOMEUSERID', $expires);
        $this->assertTrue($success);

        // assert unsetAccessToken returns true
        $result = $storage->unsetAccessToken('revokabletoken');
        $this->assertTrue($result);

        // assert token we unset does not exist
        $token = $storage->getAccessToken('revokabletoken');
        $this->assertFalse($token);
    }

    /** @dataProvider provideStorage */
    public function testUnsetAccessTokenReturnsFalse(AccessTokenInterface $storage)
    {
        if ($storage instanceof NullStorage || !method_exists($storage, 'unsetAccessToken')) {
            $this->markTestSkipped('Skipped Storage: ' . $storage->getMessage());

            return;
        }

        // assert token we are about to unset does not exist
        $token = $storage->getAccessToken('nonexistanttoken');
        $this->assertFalse($token);

        // assert unsetAccessToken returns false
        $result = $storage->unsetAccessToken('nonexistanttoken');
        $this->assertFalse($result);
    }
}