| 
									
										
										
										
											2017-02-04 19:58:42 +08:00
										 |  |  | <?php namespace Tests; | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-22 01:05:06 +08:00
										 |  |  | class SocialAuthTest extends TestCase | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 07:21:47 +08:00
										 |  |  |     public function test_social_registration() | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  |     { | 
					
						
							|  |  |  |         // http://docs.mockery.io/en/latest/reference/startup_methods.html
 | 
					
						
							| 
									
										
										
										
											2018-09-25 19:30:50 +08:00
										 |  |  |         $user = factory(\BookStack\Auth\User::class)->make(); | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->setSettings(['registration-enabled' => 'true']); | 
					
						
							| 
									
										
										
										
											2016-01-16 07:21:47 +08:00
										 |  |  |         config(['GOOGLE_APP_ID' => 'abc123', 'GOOGLE_APP_SECRET' => '123abc', 'APP_URL' => 'http://localhost']); | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-04 19:58:42 +08:00
										 |  |  |         $mockSocialite = \Mockery::mock('Laravel\Socialite\Contracts\Factory'); | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  |         $this->app['Laravel\Socialite\Contracts\Factory'] = $mockSocialite; | 
					
						
							| 
									
										
										
										
											2017-02-04 19:58:42 +08:00
										 |  |  |         $mockSocialDriver = \Mockery::mock('Laravel\Socialite\Contracts\Provider'); | 
					
						
							|  |  |  |         $mockSocialUser = \Mockery::mock('\Laravel\Socialite\Contracts\User'); | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $mockSocialite->shouldReceive('driver')->twice()->with('google')->andReturn($mockSocialDriver); | 
					
						
							|  |  |  |         $mockSocialDriver->shouldReceive('redirect')->once()->andReturn(redirect('/')); | 
					
						
							|  |  |  |         $mockSocialDriver->shouldReceive('user')->once()->andReturn($mockSocialUser); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getId')->twice()->andReturn(1); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getEmail')->twice()->andReturn($user->email); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getName')->once()->andReturn($user->name); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getAvatar')->once()->andReturn('avatar_placeholder'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-22 01:05:06 +08:00
										 |  |  |         $this->get('/register/service/google'); | 
					
						
							|  |  |  |         $this->get('/login/service/google/callback'); | 
					
						
							|  |  |  |         $this->assertDatabaseHas('users', ['name' => $user->name, 'email' => $user->email]); | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  |         $user = $user->whereEmail($user->email)->first(); | 
					
						
							| 
									
										
										
										
											2018-09-22 01:05:06 +08:00
										 |  |  |         $this->assertDatabaseHas('social_accounts', ['user_id' => $user->id]); | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-02 22:56:58 +08:00
										 |  |  |     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' | 
					
						
							|  |  |  |         ]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-04 19:58:42 +08:00
										 |  |  |         $mockSocialite = \Mockery::mock('Laravel\Socialite\Contracts\Factory'); | 
					
						
							| 
									
										
										
										
											2017-01-02 22:56:58 +08:00
										 |  |  |         $this->app['Laravel\Socialite\Contracts\Factory'] = $mockSocialite; | 
					
						
							| 
									
										
										
										
											2017-02-04 19:58:42 +08:00
										 |  |  |         $mockSocialDriver = \Mockery::mock('Laravel\Socialite\Contracts\Provider'); | 
					
						
							|  |  |  |         $mockSocialUser = \Mockery::mock('\Laravel\Socialite\Contracts\User'); | 
					
						
							| 
									
										
										
										
											2017-01-02 22:56:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $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
 | 
					
						
							| 
									
										
										
										
											2018-09-22 01:05:06 +08:00
										 |  |  |         $resp = $this->get('/login'); | 
					
						
							|  |  |  |         $resp->assertElementExists('a#social-login-google[href$="/login/service/google"]'); | 
					
						
							|  |  |  |         $resp = $this->followingRedirects()->get("/login/service/google"); | 
					
						
							|  |  |  |         $resp->assertSee('login-form'); | 
					
						
							| 
									
										
										
										
											2017-01-02 22:56:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // Test social callback
 | 
					
						
							| 
									
										
										
										
											2018-09-22 01:05:06 +08:00
										 |  |  |         $resp = $this->followingRedirects()->get('/login/service/google/callback'); | 
					
						
							|  |  |  |         $resp->assertSee('login-form'); | 
					
						
							|  |  |  |         $resp->assertSee(trans('errors.social_account_not_used', ['socialAccount' => 'Google'])); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $resp = $this->get('/login'); | 
					
						
							|  |  |  |         $resp->assertElementExists('a#social-login-github[href$="/login/service/github"]'); | 
					
						
							|  |  |  |         $resp = $this->followingRedirects()->get("/login/service/github"); | 
					
						
							|  |  |  |         $resp->assertSee('login-form'); | 
					
						
							| 
									
										
										
										
											2017-01-02 22:56:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Test social callback with matching social account
 | 
					
						
							| 
									
										
										
										
											2017-02-04 19:58:42 +08:00
										 |  |  |         \DB::table('social_accounts')->insert([ | 
					
						
							| 
									
										
										
										
											2017-01-02 22:56:58 +08:00
										 |  |  |             'user_id' => $this->getAdmin()->id, | 
					
						
							|  |  |  |             'driver' => 'github', | 
					
						
							|  |  |  |             'driver_id' => 'logintest123' | 
					
						
							|  |  |  |         ]); | 
					
						
							| 
									
										
										
										
											2018-09-22 01:05:06 +08:00
										 |  |  |         $resp = $this->followingRedirects()->get('/login/service/github/callback'); | 
					
						
							|  |  |  |         $resp->assertDontSee("login-form"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function test_social_autoregister() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         config([ | 
					
						
							|  |  |  |             'services.google.client_id' => 'abc123', 'services.google.client_secret' => '123abc', | 
					
						
							|  |  |  |             'APP_URL' => 'http://localhost' | 
					
						
							|  |  |  |         ]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-25 19:30:50 +08:00
										 |  |  |         $user = factory(\BookStack\Auth\User::class)->make(); | 
					
						
							| 
									
										
										
										
											2018-09-22 01:05:06 +08:00
										 |  |  |         $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')->times(4)->andReturn(1); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getEmail')->times(2)->andReturn($user->email); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getName')->once()->andReturn($user->name); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getAvatar')->once()->andReturn('avatar_placeholder'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $mockSocialDriver->shouldReceive('user')->times(2)->andReturn($mockSocialUser); | 
					
						
							|  |  |  |         $mockSocialite->shouldReceive('driver')->times(4)->with('google')->andReturn($mockSocialDriver); | 
					
						
							|  |  |  |         $mockSocialDriver->shouldReceive('redirect')->twice()->andReturn(redirect('/')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $googleAccountNotUsedMessage = trans('errors.social_account_not_used', ['socialAccount' => 'Google']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->get('/login/service/google'); | 
					
						
							|  |  |  |         $resp = $this->followingRedirects()->get('/login/service/google/callback'); | 
					
						
							|  |  |  |         $resp->assertSee($googleAccountNotUsedMessage); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         config(['services.google.auto_register' => true]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->get('/login/service/google'); | 
					
						
							|  |  |  |         $resp = $this->followingRedirects()->get('/login/service/google/callback'); | 
					
						
							|  |  |  |         $resp->assertDontSee($googleAccountNotUsedMessage); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->assertDatabaseHas('users', ['name' => $user->name, 'email' => $user->email, 'email_confirmed' => false]); | 
					
						
							|  |  |  |         $user = $user->whereEmail($user->email)->first(); | 
					
						
							|  |  |  |         $this->assertDatabaseHas('social_accounts', ['user_id' => $user->id]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function test_social_auto_email_confirm() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         config([ | 
					
						
							|  |  |  |             'services.google.client_id' => 'abc123', 'services.google.client_secret' => '123abc', | 
					
						
							|  |  |  |             'APP_URL' => 'http://localhost', 'services.google.auto_register' => true, 'services.google.auto_confirm' => true | 
					
						
							|  |  |  |         ]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-25 19:30:50 +08:00
										 |  |  |         $user = factory(\BookStack\Auth\User::class)->make(); | 
					
						
							| 
									
										
										
										
											2018-09-22 01:05:06 +08:00
										 |  |  |         $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')->times(3)->andReturn(1); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getEmail')->times(2)->andReturn($user->email); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getName')->once()->andReturn($user->name); | 
					
						
							|  |  |  |         $mockSocialUser->shouldReceive('getAvatar')->once()->andReturn('avatar_placeholder'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $mockSocialDriver->shouldReceive('user')->times(1)->andReturn($mockSocialUser); | 
					
						
							|  |  |  |         $mockSocialite->shouldReceive('driver')->times(2)->with('google')->andReturn($mockSocialDriver); | 
					
						
							|  |  |  |         $mockSocialDriver->shouldReceive('redirect')->once()->andReturn(redirect('/')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->get('/login/service/google'); | 
					
						
							|  |  |  |         $this->get('/login/service/google/callback'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->assertDatabaseHas('users', ['name' => $user->name, 'email' => $user->email, 'email_confirmed' => true]); | 
					
						
							|  |  |  |         $user = $user->whereEmail($user->email)->first(); | 
					
						
							|  |  |  |         $this->assertDatabaseHas('social_accounts', ['user_id' => $user->id]); | 
					
						
							| 
									
										
										
										
											2017-01-02 22:56:58 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-10 22:52:43 +08:00
										 |  |  |     public function test_google_select_account_option_changes_redirect_url() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         config()->set('services.google.select_account', 'true'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $resp = $this->get('/login/service/google'); | 
					
						
							|  |  |  |         $this->assertContains('prompt=select_account', $resp->headers->get('Location')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-23 04:07:50 +08:00
										 |  |  | } |