123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279 |
- <?php
- namespace SocialiteProviders\Manager\Test;
- use Illuminate\Contracts\Session\Session as SessionContract;
- use Illuminate\Http\Request;
- use Laravel\Socialite\Two\InvalidStateException;
- use Laravel\Socialite\Two\User as SocialiteOAuth2User;
- use Mockery as m;
- use PHPUnit\Framework\TestCase;
- use SocialiteProviders\Manager\OAuth2\User;
- use SocialiteProviders\Manager\Test\Stubs\OAuthTwoTestProviderStub;
- use stdClass;
- use Symfony\Component\HttpFoundation\RedirectResponse;
- use Symfony\Component\HttpFoundation\Session\SessionInterface;
- class OAuthTwoTest extends TestCase
- {
- use ManagerTestTrait;
- /**
- * @test
- */
- public function redirectGeneratesTheProperSymfonyRedirectResponse(): void
- {
- $session = m::mock(SessionContract::class);
- $request = Request::create('foo');
- $request->setLaravelSession($session);
- $session
- ->shouldReceive('put')
- ->once();
- $provider = new OAuthTwoTestProviderStub($request, 'client_id', 'client_secret', 'redirect');
- $response = $provider->redirect();
- $this->assertInstanceOf(RedirectResponse::class, $response);
- $this->assertSame('http://auth.url', $response->getTargetUrl());
- }
- /**
- * @test
- */
- public function it_can_return_the_service_container_key(): void
- {
- $result = OAuthTwoTestProviderStub::serviceContainerKey(OAuthTwoTestProviderStub::PROVIDER_NAME);
- $this->assertSame('SocialiteProviders.config.test', $result);
- }
- /**
- * @test
- */
- public function userReturnsAUserInstanceForTheAuthenticatedRequest(): void
- {
- $session = m::mock(SessionInterface::class);
- $request = Request::create('foo', 'GET', [
- 'state' => str_repeat('A', 40),
- 'code' => 'code',
- ]);
- $request->setSession($session);
- $session
- ->shouldReceive('pull')
- ->once()
- ->with('state')
- ->andReturn(str_repeat('A', 40));
- $provider = new OAuthTwoTestProviderStub($request, 'client_id', 'client_secret', 'redirect_uri');
- $provider->http = m::mock(stdClass::class);
- $provider->http
- ->shouldReceive('post')
- ->once()
- ->with('http://token.url', [
- 'headers' => [
- 'Accept' => 'application/json',
- ],
- 'form_params' => [
- 'grant_type' => 'authorization_code',
- 'client_id' => 'client_id',
- 'client_secret' => 'client_secret',
- 'code' => 'code',
- 'redirect_uri' => 'redirect_uri',
- ],
- ])
- ->andReturn($response = m::mock(stdClass::class));
- $response
- ->shouldReceive('getBody')
- ->andReturn('{"access_token": "access_token", "test": "test"}');
- $user = $provider->user();
- $this->assertInstanceOf(User::class, $user);
- $this->assertSame('foo', $user->id);
- }
- /**
- * @test
- */
- public function access_token_response_body_is_accessible_from_user(): void
- {
- $session = m::mock(SessionInterface::class);
- $accessTokenResponseBody = '{"access_token": "access_token", "test": "test"}';
- $request = Request::create('foo', 'GET', [
- 'state' => str_repeat('A', 40),
- 'code' => 'code',
- ]);
- $request->setSession($session);
- $session
- ->shouldReceive('pull')
- ->once()
- ->with('state')
- ->andReturn(str_repeat('A', 40));
- $provider = new OAuthTwoTestProviderStub($request, 'client_id', 'client_secret', 'redirect_uri');
- $provider->http = m::mock(stdClass::class);
- $provider->http
- ->shouldReceive('post')
- ->once()
- ->with('http://token.url', [
- 'headers' => [
- 'Accept' => 'application/json',
- ],
- 'form_params' => [
- 'grant_type' => 'authorization_code',
- 'client_id' => 'client_id',
- 'client_secret' => 'client_secret',
- 'code' => 'code',
- 'redirect_uri' => 'redirect_uri',
- ],
- ])
- ->andReturn($response = m::mock(stdClass::class));
- $response
- ->shouldReceive('getBody')
- ->andReturn($accessTokenResponseBody);
- $user = $provider->user();
- $this->assertInstanceOf(User::class, $user);
- $this->assertSame('foo', $user->id);
- $this->assertSame($user->accessTokenResponseBody, json_decode($accessTokenResponseBody, true));
- }
- /**
- * @test
- */
- public function regular_laravel_socialite_class_works_as_well(): void
- {
- $session = m::mock(SessionInterface::class);
- $accessTokenResponseBody = '{"access_token": "access_token", "test": "test"}';
- $request = Request::create('foo', 'GET', [
- 'state' => str_repeat('A', 40),
- 'code' => 'code',
- ]);
- $request->setSession($session);
- $session
- ->shouldReceive('pull')
- ->once()
- ->with('state')
- ->andReturn(str_repeat('A', 40));
- $provider = new OAuthTwoTestProviderStub($request, 'client_id', 'client_secret', 'redirect_uri');
- $provider->http = m::mock(stdClass::class);
- $provider->http
- ->shouldReceive('post')
- ->once()
- ->with('http://token.url', [
- 'headers' => [
- 'Accept' => 'application/json',
- ],
- 'form_params' => [
- 'grant_type' => 'authorization_code',
- 'client_id' => 'client_id',
- 'client_secret' => 'client_secret',
- 'code' => 'code',
- 'redirect_uri' => 'redirect_uri',
- ],
- ])
- ->andReturn($response = m::mock(stdClass::class));
- $response
- ->shouldReceive('getBody')
- ->andReturn($accessTokenResponseBody);
- $user = $provider->user();
- $this->assertInstanceOf(SocialiteOAuth2User::class, $user);
- $this->assertSame('foo', $user->id);
- }
- /**
- * @test
- */
- public function exceptionIsThrownIfStateIsInvalid(): void
- {
- $this->expectExceptionObject(new InvalidStateException());
- $session = m::mock(SessionInterface::class);
- $request = Request::create('foo', 'GET', [
- 'state' => str_repeat('B', 40),
- 'code' => 'code',
- ]);
- $request->setSession($session);
- $session
- ->shouldReceive('pull')
- ->once()
- ->with('state')
- ->andReturn(str_repeat('A', 40));
- $provider = new OAuthTwoTestProviderStub($request, 'client_id', 'client_secret', 'redirect');
- $provider->user();
- }
- /**
- * @test
- */
- public function exceptionIsThrownIfStateIsNotSet(): void
- {
- $this->expectExceptionObject(new InvalidStateException());
- $session = m::mock(SessionInterface::class);
- $request = Request::create('foo', 'GET', [
- 'state' => 'state',
- 'code' => 'code',
- ]);
- $request->setSession($session);
- $session
- ->shouldReceive('pull')
- ->once()
- ->with('state');
- $provider = new OAuthTwoTestProviderStub($request, 'client_id', 'client_secret', 'redirect');
- $provider->user();
- }
- /**
- * @test
- */
- public function userObjectShouldBeCachedOnFirstCall(): void
- {
- $session = m::mock(SessionInterface::class);
- $accessTokenResponseBody = '{"access_token": "access_token", "test": "test"}';
- $request = Request::create('foo', 'GET', [
- 'state' => str_repeat('A', 40),
- 'code' => 'code',
- ]);
- $request->setSession($session);
- $session
- ->shouldReceive('pull')
- ->once()
- ->with('state')
- ->andReturn(str_repeat('A', 40));
- $provider = new OAuthTwoTestProviderStub($request, 'client_id', 'client_secret', 'redirect_uri');
- $provider->http = m::mock(stdClass::class);
- $provider->http
- ->shouldReceive('post')
- ->once()
- ->with('http://token.url', [
- 'headers' => [
- 'Accept' => 'application/json',
- ],
- 'form_params' => [
- 'grant_type' => 'authorization_code',
- 'client_id' => 'client_id',
- 'client_secret' => 'client_secret',
- 'code' => 'code',
- 'redirect_uri' => 'redirect_uri',
- ],
- ])
- ->andReturn($response = m::mock(stdClass::class));
- $response
- ->shouldReceive('getBody')
- ->andReturn($accessTokenResponseBody);
- $reflection = new \ReflectionClass($provider);
- $reflectionProperty = $reflection->getProperty('user');
- $reflectionProperty->setAccessible(true);
- $this->assertNull($reflectionProperty->getValue($provider));
- $firstCall = $provider->user();
- $this->assertInstanceOf(SocialiteOAuth2User::class, $reflectionProperty->getValue($provider));
- $secondCall = $provider->user();
- $this->assertSame($firstCall, $secondCall);
- }
- }
|