BigW Consortium Gitlab

users_spec.rb 1.7 KB
Newer Older
1 2
require 'spec_helper'

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

6 7
  scenario 'GET /users/sign_in creates a new user account' do
    visit new_user_session_path
8 9 10 11
    fill_in 'new_user_name',     with: 'Name Surname'
    fill_in 'new_user_username', with: 'Great'
    fill_in 'new_user_email',    with: 'name@mail.com'
    fill_in 'new_user_password', with: 'password1234'
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
    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
30
  end
31 32 33

  scenario 'Should show one error if email is already taken' do
    visit new_user_session_path
34 35 36 37
    fill_in 'new_user_name',     with: 'Another user name'
    fill_in 'new_user_username', with: 'anotheruser'
    fill_in 'new_user_email',    with: user.email
    fill_in 'new_user_password', with: '12341234'
38 39 40 41 42 43 44 45 46 47 48 49
    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
50
end