summaryrefslogtreecommitdiff
path: root/spec/features/users_spec.rb
blob: 633616241f10867d383ad846e34b9eb5ad51ec82 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
require 'spec_helper'

feature 'Users', feature: true do
  let(:user)  { create(:user, username: 'user1', name: 'User 1', email: 'user1@gitlab.com') }
  let(:user2) { create(:user, username: 'user2', name: 'User 2', email: 'user2@gitlab.com') }

  scenario 'GET /users/sign_in creates a new user account' do
    visit new_user_session_path
    fill_in 'user_name', with: 'Name Surname'
    fill_in 'user_username', with: 'Great'
    fill_in 'user_email', with: 'name@mail.com'
    fill_in 'user_password_sign_up', with: 'password1234'
    expect { click_button 'Sign up' }.to change { User.count }.by(1)
  end

  scenario 'Successful user signin invalidates password reset token' do
    expect(user.reset_password_token).to be_nil

    visit new_user_password_path
    fill_in 'user_email', with: user.email
    click_button 'Reset password'

    user.reload
    expect(user.reset_password_token).not_to be_nil

    login_with(user)
    expect(current_path).to eq root_path

    user.reload
    expect(user.reset_password_token).to be_nil
  end

  scenario 'Should show one error if email is already taken' do
    visit new_user_session_path
    fill_in 'user_name', with: 'Another user name'
    fill_in 'user_username', with: 'anotheruser'
    fill_in 'user_email', with: user.email
    fill_in 'user_password_sign_up', with: '12341234'
    expect { click_button 'Sign up' }.to change { User.count }.by(0)
    expect(page).to have_text('Email has already been taken')
    expect(number_of_errors_on_page(page)).to be(1), 'errors on page:\n #{errors_on_page page}'
  end

  def errors_on_page(page)
    page.find('#error_explanation').find('ul').all('li').map{ |item| item.text }.join("\n")
  end

  def number_of_errors_on_page(page)
    page.find('#error_explanation').find('ul').all('li').count
  end

  context 'With a logged-in user' do
    before do
      login_as(user)
    end

    describe 'Abuse report button' do
      context 'User has never been reported for abuse' do
        it 'enables the "Report abuse" button / dropdown' do
          visit user_path(user2)

          expect(page.find('#report_abuse').find('ul.dropdown-menu').all('li').count).to be(1)
          expect(page.find('#report_abuse').all('.btn-close').count).to be(0)
        end
      end

      context 'User has already been reported for abuse' do
        before do
          @abuse_report = AbuseReport.new(user: user2, message: 'Foo bar')
          @abuse_report.reporter = user
          @abuse_report.save!
        end

        it 'disables the "Report abuse" button' do
          visit user_path(user2)

          expect(page.find('#report_abuse').all('ul.dropdown-menu').count).to be(0)
          expect(page.find('#report_abuse').all('.btn-close').count).to be(1)
        end
      end
    end

  end

end