BigW Consortium Gitlab

sorting_spec.rb 3.39 KB
Newer Older
1 2 3 4 5 6 7 8
require 'spec_helper'

feature 'Projects > Members > Sorting', feature: true do
  let(:master)    { create(:user, name: 'John Doe') }
  let(:developer) { create(:user, name: 'Mary Jane', last_sign_in_at: 5.days.ago) }
  let(:project)   { create(:empty_project) }

  background do
9 10
    create(:project_member, :master, user: master, project: project, created_at: 5.days.ago)
    create(:project_member, :developer, user: developer, project: project, created_at: 3.days.ago)
11 12 13 14

    login_as(master)
  end

15 16 17 18 19
  scenario 'sorts alphabetically by default' do
    visit_members_list(sort: nil)

    expect(first_member).to include(master.name)
    expect(second_member).to include(developer.name)
20
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Name, ascending')
21 22
  end

23 24 25 26 27
  scenario 'sorts by access level ascending' do
    visit_members_list(sort: :access_level_asc)

    expect(first_member).to include(developer.name)
    expect(second_member).to include(master.name)
28
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Access level, ascending')
29 30 31 32 33 34 35
  end

  scenario 'sorts by access level descending' do
    visit_members_list(sort: :access_level_desc)

    expect(first_member).to include(master.name)
    expect(second_member).to include(developer.name)
36
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Access level, descending')
37 38 39 40 41 42 43
  end

  scenario 'sorts by last joined' do
    visit_members_list(sort: :last_joined)

    expect(first_member).to include(developer.name)
    expect(second_member).to include(master.name)
44
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Last joined')
45 46 47 48 49 50 51
  end

  scenario 'sorts by oldest joined' do
    visit_members_list(sort: :oldest_joined)

    expect(first_member).to include(master.name)
    expect(second_member).to include(developer.name)
52
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Oldest joined')
53 54 55 56 57 58 59
  end

  scenario 'sorts by name ascending' do
    visit_members_list(sort: :name_asc)

    expect(first_member).to include(master.name)
    expect(second_member).to include(developer.name)
60
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Name, ascending')
61 62 63 64 65 66 67
  end

  scenario 'sorts by name descending' do
    visit_members_list(sort: :name_desc)

    expect(first_member).to include(developer.name)
    expect(second_member).to include(master.name)
68
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Name, descending')
69 70 71 72 73 74 75
  end

  scenario 'sorts by recent sign in' do
    visit_members_list(sort: :recent_sign_in)

    expect(first_member).to include(master.name)
    expect(second_member).to include(developer.name)
76
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Recent sign in')
77 78 79 80 81 82 83
  end

  scenario 'sorts by oldest sign in' do
    visit_members_list(sort: :oldest_sign_in)

    expect(first_member).to include(developer.name)
    expect(second_member).to include(master.name)
84
    expect(page).to have_css('.member-sort-dropdown .dropdown-toggle-text', text: 'Oldest sign in')
85 86 87
  end

  def visit_members_list(sort:)
88
    visit namespace_project_project_members_path(project.namespace.to_param, project, sort: sort)
89 90 91 92 93 94 95 96 97 98
  end

  def first_member
    page.all('ul.content-list > li').first.text
  end

  def second_member
    page.all('ul.content-list > li').last.text
  end
end