File: member_presenter_spec.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (59 lines) | stat: -rw-r--r-- 2,017 bytes parent folder | download
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
# frozen_string_literal: true

require 'spec_helper'

# Creation is necessary due to relations and the need to check in the presenter
#
# rubocop:disable RSpec/FactoryBot/AvoidCreate
RSpec.describe MemberPresenter, feature_category: :groups_and_projects do
  let_it_be(:root_group) { create(:group) }
  let_it_be(:subgroup) { create(:group, parent: root_group) }
  let_it_be(:user) { create(:user) }

  let_it_be(:root_member) { create(:group_member, :reporter, group: root_group, user: user) }
  let_it_be(:subgroup_member) { create(:group_member, :reporter, group: subgroup, user: user) }

  let(:presenter) { described_class.new(root_member) }

  describe '#last_owner?' do
    it 'raises `NotImplementedError`' do
      expect { presenter.last_owner? }.to raise_error(NotImplementedError)
    end
  end

  describe '#member_role_description' do
    it 'returns the correct role description' do
      description = Gitlab::Access.option_descriptions[Gitlab::Access::REPORTER]

      expect(presenter.member_role_description).to eq(description)
    end
  end

  describe '#role_type' do
    it "returns 'default'" do
      expect(presenter.role_type).to eq('default')
    end
  end

  describe '#valid_level_roles' do
    it 'does not return levels lower than user highest membership in the hierarchy' do
      expect(described_class.new(subgroup_member).valid_level_roles).to eq(
        'Reporter' => Gitlab::Access::REPORTER,
        'Developer' => Gitlab::Access::DEVELOPER,
        'Maintainer' => Gitlab::Access::MAINTAINER,
        'Owner' => Gitlab::Access::OWNER
      )
    end

    it 'returns all roles for the root group' do
      expect(described_class.new(root_member).valid_level_roles).to eq(
        'Guest' => Gitlab::Access::GUEST,
        'Reporter' => Gitlab::Access::REPORTER,
        'Developer' => Gitlab::Access::DEVELOPER,
        'Maintainer' => Gitlab::Access::MAINTAINER,
        'Owner' => Gitlab::Access::OWNER
      )
    end
  end
end
# rubocop:enable RSpec/FactoryBot/AvoidCreate