X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/0821672e70cf9eb81091032514634b299cc5900b..refs/pull/446/head:/tests/Auth/SocialAuthTest.php diff --git a/tests/Auth/SocialAuthTest.php b/tests/Auth/SocialAuthTest.php index d5a7e6921..e3494d073 100644 --- a/tests/Auth/SocialAuthTest.php +++ b/tests/Auth/SocialAuthTest.php @@ -1,6 +1,6 @@ -setSettings(['registration-enabled' => 'true']); config(['GOOGLE_APP_ID' => 'abc123', 'GOOGLE_APP_SECRET' => '123abc', 'APP_URL' => 'http://localhost']); - $mockSocialite = Mockery::mock('Laravel\Socialite\Contracts\Factory'); + $mockSocialite = \Mockery::mock('Laravel\Socialite\Contracts\Factory'); $this->app['Laravel\Socialite\Contracts\Factory'] = $mockSocialite; - $mockSocialDriver = Mockery::mock('Laravel\Socialite\Contracts\Provider'); - $mockSocialUser = Mockery::mock('\Laravel\Socialite\Contracts\User'); + $mockSocialDriver = \Mockery::mock('Laravel\Socialite\Contracts\Provider'); + $mockSocialUser = \Mockery::mock('\Laravel\Socialite\Contracts\User'); $mockSocialite->shouldReceive('driver')->twice()->with('google')->andReturn($mockSocialDriver); $mockSocialDriver->shouldReceive('redirect')->once()->andReturn(redirect('/')); @@ -32,4 +32,46 @@ class SocialAuthTest extends TestCase $this->seeInDatabase('social_accounts', ['user_id' => $user->id]); } + public function test_social_login() + { + config([ + 'GOOGLE_APP_ID' => 'abc123', 'GOOGLE_APP_SECRET' => '123abc', + 'GITHUB_APP_ID' => 'abc123', 'GITHUB_APP_SECRET' => '123abc', + 'APP_URL' => 'http://localhost' + ]); + + $mockSocialite = \Mockery::mock('Laravel\Socialite\Contracts\Factory'); + $this->app['Laravel\Socialite\Contracts\Factory'] = $mockSocialite; + $mockSocialDriver = \Mockery::mock('Laravel\Socialite\Contracts\Provider'); + $mockSocialUser = \Mockery::mock('\Laravel\Socialite\Contracts\User'); + + $mockSocialUser->shouldReceive('getId')->twice()->andReturn('logintest123'); + + $mockSocialDriver->shouldReceive('user')->twice()->andReturn($mockSocialUser); + $mockSocialite->shouldReceive('driver')->twice()->with('google')->andReturn($mockSocialDriver); + $mockSocialite->shouldReceive('driver')->twice()->with('github')->andReturn($mockSocialDriver); + $mockSocialDriver->shouldReceive('redirect')->twice()->andReturn(redirect('/')); + + // Test login routes + $this->visit('/login')->seeElement('#social-login-google') + ->click('#social-login-google') + ->seePageIs('/login'); + + // Test social callback + $this->visit('/login/service/google/callback')->seePageIs('/login') + ->see(trans('errors.social_account_not_used', ['socialAccount' => 'Google'])); + + $this->visit('/login')->seeElement('#social-login-github') + ->click('#social-login-github') + ->seePageIs('/login'); + + // Test social callback with matching social account + \DB::table('social_accounts')->insert([ + 'user_id' => $this->getAdmin()->id, + 'driver' => 'github', + 'driver_id' => 'logintest123' + ]); + $this->visit('/login/service/github/callback')->seePageIs('/'); + } + }