PageRenderTime 42ms CodeModel.GetById 18ms RepoModel.GetById 0ms app.codeStats 0ms

/spec/controllers/profiles/accounts_controller_spec.rb

https://bitbucket.org/terrchen/gitlab-ce
Ruby | 47 lines | 35 code | 12 blank | 0 comment | 0 complexity | 6f0cd14a687bfa3de3bf7d89c65f7fd1 MD5 | raw file
Possible License(s): Apache-2.0, CC0-1.0
  1. require 'spec_helper'
  2. describe Profiles::AccountsController do
  3. describe 'DELETE unlink' do
  4. let(:user) { create(:omniauth_user) }
  5. before do
  6. sign_in(user)
  7. end
  8. it 'renders 404 if someone tries to unlink a non existent provider' do
  9. delete :unlink, provider: 'github'
  10. expect(response).to have_gitlab_http_status(404)
  11. end
  12. [:saml, :cas3].each do |provider|
  13. describe "#{provider} provider" do
  14. let(:user) { create(:omniauth_user, provider: provider.to_s) }
  15. it "does not allow to unlink connected account" do
  16. identity = user.identities.last
  17. delete :unlink, provider: provider.to_s
  18. expect(response).to have_gitlab_http_status(302)
  19. expect(user.reload.identities).to include(identity)
  20. end
  21. end
  22. end
  23. [:twitter, :facebook, :google_oauth2, :gitlab, :github, :bitbucket, :crowd, :auth0, :authentiq].each do |provider|
  24. describe "#{provider} provider" do
  25. let(:user) { create(:omniauth_user, provider: provider.to_s) }
  26. it 'allows to unlink connected account' do
  27. identity = user.identities.last
  28. delete :unlink, provider: provider.to_s
  29. expect(response).to have_gitlab_http_status(302)
  30. expect(user.reload.identities).not_to include(identity)
  31. end
  32. end
  33. end
  34. end
  35. end