summaryrefslogtreecommitdiff
path: root/spec/features
diff options
context:
space:
mode:
authorTimothy Andrew <mail@timothyandrew.net>2017-06-19 07:55:09 +0000
committerTimothy Andrew <mail@timothyandrew.net>2017-07-06 06:30:06 +0000
commit15dba34c9a469c95ea6112419dca33c2c63c6247 (patch)
treead1feceefeebd02679588be7f24aab722c6c4baf /spec/features
parentfd94855893b96ccab2227330ffd3134a92f4cb45 (diff)
downloadgitlab-ce-15dba34c9a469c95ea6112419dca33c2c63c6247.tar.gz
Add Omniauth OAuth config to the test section of `gitlab.yml`
- I tried to get this to work by stubbing out portions of the config within the test. This didn't work as expected because Devise/Omniauth loaded before the stub could run, and the stubbed config was ignored. - I attempted to fix this by reloading Devise/Omniauth after stubbing the config. This successfully got Devise to load the stubbed providers, but failed while trying to access a route such as `user_gitlab_omniauth_authorize_path`. - I spent a while trying to figure this out (even trying `Rails.application.reload_routes!`), but nothing seemed to work. - I settled for adding this config directly to `gitlab.yml` rather than go down this path any further.
Diffstat (limited to 'spec/features')
-rw-r--r--spec/features/oauth_login_spec.rb52
1 files changed, 1 insertions, 51 deletions
diff --git a/spec/features/oauth_login_spec.rb b/spec/features/oauth_login_spec.rb
index b37c14bd638..8e02bc88fad 100644
--- a/spec/features/oauth_login_spec.rb
+++ b/spec/features/oauth_login_spec.rb
@@ -6,23 +6,6 @@ feature 'OAuth Login', feature: true, js: true do
click_button 'Verify code'
end
- def provider_config(provider)
- if provider == :saml
- OpenStruct.new(
- name: 'saml', label: 'saml',
- args: {
- assertion_consumer_service_url: 'https://localhost:3443/users/auth/saml/callback',
- idp_cert_fingerprint: '26:43:2C:47:AF:F0:6B:D0:07:9C:AD:A3:74:FE:5D:94:5F:4E:9E:52',
- idp_sso_target_url: 'https://idp.example.com/sso/saml',
- issuer: 'https://localhost:3443/',
- name_identifier_format: 'urn:oasis:names:tc:SAML:2.0:nameid-format:transient'
- }
- )
- else
- OpenStruct.new(name: provider.to_s, app_id: 'app_id', app_secret: 'app_secret')
- end
- end
-
def stub_omniauth_config(provider)
OmniAuth.config.add_mock(provider, OmniAuth::AuthHash.new({ provider: provider.to_s, uid: "12345" }))
Rails.application.env_config['devise.mapping'] = Devise.mappings[:user]
@@ -32,43 +15,10 @@ feature 'OAuth Login', feature: true, js: true do
providers = [:github, :twitter, :bitbucket, :gitlab, :google_oauth2,
:facebook, :authentiq, :cas3, :auth0]
- before do
+ before(:all) do
OmniAuth.config.full_host = ->(request) { request['REQUEST_URI'].sub(/#{request['REQUEST_PATH']}.*/, '') }
-
- messages = {
- enabled: true,
- allow_single_sign_on: providers.map(&:to_s),
- auto_link_saml_user: true,
- providers: providers.map { |provider| provider_config(provider) }
- }
-
- allow(Gitlab.config.omniauth).to receive_messages(messages)
end
- # context 'logging in via OAuth' do
- # def saml_config
-
- # end
- # def stub_omniauth_config(messages)
- # Rails.application.env_config['devise.mapping'] = Devise.mappings[:user]
- # Rails.application.routes.disable_clear_and_finalize = true
- # Rails.application.routes.draw do
- # post '/users/auth/saml' => 'omniauth_callbacks#saml'
- # end
- # allow(Gitlab::OAuth::Provider).to receive_messages(providers: [:saml], config_for: saml_config)
- # allow(Gitlab.config.omniauth).to receive_messages(messages)
- # expect_any_instance_of(Object).to receive(:omniauth_authorize_path).with(:user, "saml").and_return('/users/auth/saml')
- # end
- # it 'shows 2FA prompt after OAuth login' do
- # stub_omniauth_config(enabled: true, auto_link_saml_user: true, allow_single_sign_on: ['saml'], providers: [saml_config])
- # user = create(:omniauth_user, :two_factor, extern_uid: 'my-uid', provider: 'saml')
- # login_via('saml', user, 'my-uid')
- # expect(page).to have_content('Two-Factor Authentication')
- # enter_code(user.current_otp)
- # expect(current_path).to eq root_path
- # end
- # end
-
providers.each do |provider|
context "when the user logs in using the #{provider} provider" do
context "when two-factor authentication is disabled" do