diff options
| author | Bob Van Landuyt <bob@vanlanduyt.co> | 2018-06-08 13:20:44 +0200 | 
|---|---|---|
| committer | Bob Van Landuyt <bob@vanlanduyt.co> | 2018-06-08 19:17:00 +0200 | 
| commit | 3d713ac114085e091815aa486fb96905347c3002 (patch) | |
| tree | 64c7ee7c43e2a313bf75e10c14b09ef9c1ccd0d4 /spec/features/users | |
| parent | ebdc7f11d9c1a2a492e4af6918d407882ce5737d (diff) | |
| download | gitlab-ce-3d713ac114085e091815aa486fb96905347c3002.tar.gz | |
Users can accept terms during registration
When a user checks the `accept` checkbox, we will track that
acceptance as usual. That way they don't need to accept again after
they complete the registration.
When an unauthenticated user visits the `/-/users/terms` page, there
is no button to accept, decline or continue. The 'current-user menu'
is also hidden from the top bar.
Diffstat (limited to 'spec/features/users')
| -rw-r--r-- | spec/features/users/signup_spec.rb | 21 | ||||
| -rw-r--r-- | spec/features/users/terms_spec.rb | 143 | 
2 files changed, 96 insertions, 68 deletions
| diff --git a/spec/features/users/signup_spec.rb b/spec/features/users/signup_spec.rb index b5bd5c505f2..b51ca5d130b 100644 --- a/spec/features/users/signup_spec.rb +++ b/spec/features/users/signup_spec.rb @@ -140,7 +140,7 @@ describe 'Signup' do        enforce_terms      end -    it 'asks the user to accept terms before going to the dashboard' do +    it 'requires the user to check the checkbox' do        visit root_path        fill_in 'new_user_name',                with: new_user.name @@ -148,11 +148,24 @@ describe 'Signup' do        fill_in 'new_user_email',               with: new_user.email        fill_in 'new_user_email_confirmation',  with: new_user.email        fill_in 'new_user_password',            with: new_user.password -      click_button "Register" -      expect_to_be_on_terms_page +      click_button 'Register' + +      expect(current_path).to eq new_user_session_path +      expect(page).to have_content(/you must accept our terms of service/i) +    end + +    it 'asks the user to accept terms before going to the dashboard' do +      visit root_path + +      fill_in 'new_user_name',                with: new_user.name +      fill_in 'new_user_username',            with: new_user.username +      fill_in 'new_user_email',               with: new_user.email +      fill_in 'new_user_email_confirmation',  with: new_user.email +      fill_in 'new_user_password',            with: new_user.password +      check :terms_opt_in -      click_button 'Accept terms' +      click_button "Register"        expect(current_path).to eq dashboard_projects_path      end diff --git a/spec/features/users/terms_spec.rb b/spec/features/users/terms_spec.rb index af407c52917..5b2e7605c4d 100644 --- a/spec/features/users/terms_spec.rb +++ b/spec/features/users/terms_spec.rb @@ -3,12 +3,10 @@ require 'spec_helper'  describe 'Users > Terms' do    include TermsHelper -  let(:user) { create(:user) }    let!(:term) { create(:term, terms: 'By accepting, you promise to be nice!') }    before do      stub_env('IN_MEMORY_APPLICATION_SETTINGS', 'false') -    sign_in(user)    end    it 'shows the terms' do @@ -17,102 +15,119 @@ describe 'Users > Terms' do      expect(page).to have_content('By accepting, you promise to be nice!')    end -  context 'declining the terms' do -    it 'returns the user to the app' do -      visit terms_path +  it 'does not show buttons to accept, decline or sign out', :aggregate_failures do +    visit terms_path + +    expect(page).not_to have_css('.footer-block') +    expect(page).not_to have_content('Accept terms') +    expect(page).not_to have_content('Decline and sign out') +    expect(page).not_to have_content('Continue') +  end -      click_button 'Decline and sign out' +  context 'when signed in' do +    let(:user) { create(:user) } -      expect(page).not_to have_content(term.terms) -      expect(user.reload.terms_accepted?).to be(false) +    before do +      sign_in(user)      end -  end -  context 'accepting the terms' do -    it 'returns the user to the app' do -      visit terms_path +    context 'declining the terms' do +      it 'returns the user to the app' do +        visit terms_path -      click_button 'Accept terms' +        click_button 'Decline and sign out' -      expect(page).not_to have_content(term.terms) -      expect(user.reload.terms_accepted?).to be(true) +        expect(page).not_to have_content(term.terms) +        expect(user.reload.terms_accepted?).to be(false) +      end      end -  end -  context 'when the user has already accepted the terms' do -    before do -      accept_terms(user) +    context 'accepting the terms' do +      it 'returns the user to the app' do +        visit terms_path + +        click_button 'Accept terms' + +        expect(page).not_to have_content(term.terms) +        expect(user.reload.terms_accepted?).to be(true) +      end      end -    it 'allows the user to continue to the app' do -      visit terms_path +    context 'when the user has already accepted the terms' do +      before do +        accept_terms(user) +      end + +      it 'allows the user to continue to the app' do +        visit terms_path -      expect(page).to have_content "You have already accepted the Terms of Service as #{user.to_reference}" +        expect(page).to have_content "You have already accepted the Terms of Service as #{user.to_reference}" -      click_link 'Continue' +        click_link 'Continue' -      expect(current_path).to eq(root_path) +        expect(current_path).to eq(root_path) +      end      end -  end -  context 'terms were enforced while session is active', :js do -    let(:project) { create(:project) } +    context 'terms were enforced while session is active', :js do +      let(:project) { create(:project) } -    before do -      project.add_developer(user) -    end +      before do +        project.add_developer(user) +      end -    it 'redirects to terms and back to where the user was going'  do -      visit project_path(project) +      it 'redirects to terms and back to where the user was going'  do +        visit project_path(project) -      enforce_terms +        enforce_terms -      within('.nav-sidebar') do -        click_link 'Issues' -      end +        within('.nav-sidebar') do +          click_link 'Issues' +        end -      expect_to_be_on_terms_page +        expect_to_be_on_terms_page -      click_button('Accept terms') +        click_button('Accept terms') -      expect(current_path).to eq(project_issues_path(project)) -    end +        expect(current_path).to eq(project_issues_path(project)) +      end -    # Disabled until https://gitlab.com/gitlab-org/gitlab-ce/issues/37162 is solved properly -    xit 'redirects back to the page the user was trying to save' do -      visit new_project_issue_path(project) +      # Disabled until https://gitlab.com/gitlab-org/gitlab-ce/issues/37162 is solved properly +      xit 'redirects back to the page the user was trying to save' do +        visit new_project_issue_path(project) -      fill_in :issue_title, with: 'Hello world, a new issue' -      fill_in :issue_description, with: "We don't want to lose what the user typed" +        fill_in :issue_title, with: 'Hello world, a new issue' +        fill_in :issue_description, with: "We don't want to lose what the user typed" -      enforce_terms +        enforce_terms -      click_button 'Submit issue' +        click_button 'Submit issue' -      expect(current_path).to eq(terms_path) +        expect(current_path).to eq(terms_path) -      click_button('Accept terms') +        click_button('Accept terms') -      expect(current_path).to eq(new_project_issue_path(project)) -      expect(find_field('issue_title').value).to eq('Hello world, a new issue') -      expect(find_field('issue_description').value).to eq("We don't want to lose what the user typed") +        expect(current_path).to eq(new_project_issue_path(project)) +        expect(find_field('issue_title').value).to eq('Hello world, a new issue') +        expect(find_field('issue_description').value).to eq("We don't want to lose what the user typed") +      end      end -  end -  context 'when the terms are enforced' do -    before do -      enforce_terms -    end +    context 'when the terms are enforced' do +      before do +        enforce_terms +      end -    context 'signing out', :js do -      it 'allows the user to sign out without a response' do -        visit terms_path +      context 'signing out', :js do +        it 'allows the user to sign out without a response' do +          visit terms_path -        find('.header-user-dropdown-toggle').click -        click_link('Sign out') +          find('.header-user-dropdown-toggle').click +          click_link('Sign out') -        expect(page).to have_content('Sign in') -        expect(page).to have_content('Register') +          expect(page).to have_content('Sign in') +          expect(page).to have_content('Register') +        end        end      end    end | 
