Commit 06dd530edecf90711c5bf7fe6918729a0096a572
Exists in
master
and in
4 other branches
Merge branch 'user_delete_account' of /home/git/repositories/gitlab/gitlabhq
Showing
3 changed files
with
66 additions
and
1 deletions
Show diff stats
app/controllers/registrations_controller.rb
1 | class RegistrationsController < Devise::RegistrationsController | 1 | class RegistrationsController < Devise::RegistrationsController |
2 | before_filter :signup_enabled? | 2 | before_filter :signup_enabled? |
3 | 3 | ||
4 | + def destroy | ||
5 | + if current_user.owned_projects.count > 0 | ||
6 | + redirect_to account_profile_path, alert: "Remove projects and groups before removing account." and return | ||
7 | + end | ||
8 | + current_user.destroy | ||
9 | + | ||
10 | + respond_to do |format| | ||
11 | + format.html { redirect_to new_user_session_path, notice: "Account successfully removed." } | ||
12 | + end | ||
13 | + end | ||
14 | + | ||
4 | private | 15 | private |
5 | 16 | ||
6 | def signup_enabled? | 17 | def signup_enabled? |
app/views/profiles/account.html.haml
@@ -77,4 +77,10 @@ | @@ -77,4 +77,10 @@ | ||
77 | .input | 77 | .input |
78 | = f.submit 'Save username', class: "btn btn-save" | 78 | = f.submit 'Save username', class: "btn btn-save" |
79 | 79 | ||
80 | - | 80 | +- if Gitlab.config.gitlab.signup_enabled |
81 | + %fieldset.remove-account | ||
82 | + %legend | ||
83 | + Remove account | ||
84 | + %small.cred.pull-right | ||
85 | + Before removing the account you must remove all projects! | ||
86 | + = link_to 'Delete account', user_registration_path, confirm: "REMOVE #{current_user.name}? Are you sure?", method: :delete, class: "btn btn-remove delete-key btn-small pull-right" | ||
81 | \ No newline at end of file | 87 | \ No newline at end of file |
@@ -0,0 +1,48 @@ | @@ -0,0 +1,48 @@ | ||
1 | +require 'spec_helper' | ||
2 | + | ||
3 | +describe "Profile account page" do | ||
4 | + let(:user) { create(:user) } | ||
5 | + | ||
6 | + before do | ||
7 | + login_as :user | ||
8 | + end | ||
9 | + | ||
10 | + describe "when signup is enabled" do | ||
11 | + before do | ||
12 | + Gitlab.config.gitlab.stub(:signup_enabled).and_return(true) | ||
13 | + visit account_profile_path | ||
14 | + end | ||
15 | + it { page.should have_content("Remove account") } | ||
16 | + | ||
17 | + it "should delete the account", js: true do | ||
18 | + expect { click_link "Delete account" }.to change {User.count}.by(-1) | ||
19 | + current_path.should == new_user_session_path | ||
20 | + end | ||
21 | + end | ||
22 | + | ||
23 | + describe "when signup is enabled and user has a project" do | ||
24 | + before do | ||
25 | + Gitlab.config.gitlab.stub(:signup_enabled).and_return(true) | ||
26 | + @project = create(:project, namespace: @user.namespace) | ||
27 | + @project.team << [@user, :master] | ||
28 | + visit account_profile_path | ||
29 | + end | ||
30 | + it { page.should have_content("Remove account") } | ||
31 | + | ||
32 | + it "should not allow user to delete the account" do | ||
33 | + expect { click_link "Delete account" }.not_to change {User.count}.by(-1) | ||
34 | + end | ||
35 | + end | ||
36 | + | ||
37 | + describe "when signup is disabled" do | ||
38 | + before do | ||
39 | + Gitlab.config.gitlab.stub(:signup_enabled).and_return(false) | ||
40 | + visit account_profile_path | ||
41 | + end | ||
42 | + | ||
43 | + it "should not have option to remove account" do | ||
44 | + page.should_not have_content("Remove account") | ||
45 | + current_path.should == account_profile_path | ||
46 | + end | ||
47 | + end | ||
48 | +end | ||
0 | \ No newline at end of file | 49 | \ No newline at end of file |