BigW Consortium Gitlab

project_member_spec.rb 4.83 KB
Newer Older
gitlabhq committed
1 2
require 'spec_helper'

Douwe Maan committed
3
describe ProjectMember, models: true do
4
  describe 'associations' do
5
    it { is_expected.to belong_to(:project).with_foreign_key(:source_id) }
6 7 8 9 10
  end

  describe 'validations' do
    it { is_expected.to allow_value('Project').for(:source_type) }
    it { is_expected.not_to allow_value('project').for(:source_type) }
11
    it { is_expected.to validate_inclusion_of(:access_level).in_array(Gitlab::Access.values) }
12 13 14 15 16 17
  end

  describe 'modules' do
    it { is_expected.to include_module(Gitlab::ShellAdapter) }
  end

18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
  describe '.access_level_roles' do
    it 'returns Gitlab::Access.options' do
      expect(described_class.access_level_roles).to eq(Gitlab::Access.options)
    end
  end

  describe '.add_user' do
    context 'when called with the project owner' do
      it 'adds the user as a member' do
        project = create(:empty_project)

        expect(project.users).not_to include(project.owner)

        described_class.add_user(project, project.owner, :master, current_user: project.owner)

        expect(project.users.reload).to include(project.owner)
      end
    end
  end

38 39 40 41 42 43
  describe '#real_source_type' do
    subject { create(:project_member).real_source_type }

    it { is_expected.to eq 'Project' }
  end

44
  describe "#destroy" do
45
    let(:owner)   { create(:project_member, access_level: ProjectMember::MASTER) }
46 47 48 49 50 51 52 53 54 55 56
    let(:project) { owner.project }
    let(:master)  { create(:project_member, project: project) }

    let(:owner_todos)  { (0...2).map { create(:todo, user: owner.user, project: project) } }
    let(:master_todos) { (0...3).map { create(:todo, user: master.user, project: project) } }

    before do
      owner_todos
      master_todos
    end

57 58 59
    it "creates an expired event when left due to expiry" do
      expired = create(:project_member, project: project, expires_at: Time.now - 6.days)
      expired.destroy
60
      expect(Event.recent.first.action).to eq(Event::EXPIRED)
61 62 63 64
    end

    it "creates a left event when left due to leave" do
      master.destroy
65
      expect(Event.recent.first.action).to eq(Event::LEFT)
66 67
    end

68
    it "destroys itself and delete associated todos" do
Long Nguyen committed
69 70
      expect(owner.user.todos.size).to eq(2)
      expect(master.user.todos.size).to eq(3)
71 72 73 74 75
      expect(Todo.count).to eq(5)

      master_todo_ids = master_todos.map(&:id)
      master.destroy

Long Nguyen committed
76
      expect(owner.user.todos.size).to eq(2)
77 78 79 80 81 82 83
      expect(Todo.count).to eq(2)
      master_todo_ids.each do |id|
        expect(Todo.exists?(id)).to eq(false)
      end
    end
  end

84
  describe '.import_team' do
85
    before do
86 87
      @project_1 = create(:empty_project)
      @project_2 = create(:empty_project)
88 89 90 91

      @user_1 = create :user
      @user_2 = create :user

92 93
      @project_1.team << [ @user_1, :developer ]
      @project_2.team << [ @user_2, :reporter ]
94

95
      @status = @project_2.team.import(@project_1)
96 97
    end

98
    it { expect(@status).to be_truthy }
99 100

    describe 'project 2 should get user 1 as developer. user_2 should not be changed' do
101 102
      it { expect(@project_2.users).to include(@user_1) }
      it { expect(@project_2.users).to include(@user_2) }
103

104 105
      it { expect(Ability.allowed?(@user_1, :create_project, @project_2)).to be_truthy }
      it { expect(Ability.allowed?(@user_2, :read_project, @project_2)).to be_truthy }
106 107 108
    end

    describe 'project 1 should not be changed' do
109 110
      it { expect(@project_1.users).to include(@user_1) }
      it { expect(@project_1.users).not_to include(@user_2) }
111 112
    end
  end
113

114
  describe '.add_users_to_projects' do
115 116 117
    it 'adds the given users to the given projects' do
      projects = create_list(:empty_project, 2)
      users = create_list(:user, 2)
118

119
      described_class.add_users_to_projects(
120
        [projects.first.id, projects.second.id],
121 122
        [users.first.id, users.second],
        described_class::MASTER)
123

124 125
      expect(projects.first.users).to include(users.first)
      expect(projects.first.users).to include(users.second)
126

127 128 129
      expect(projects.second.users).to include(users.first)
      expect(projects.second.users).to include(users.second)
    end
130 131
  end

132
  describe '.truncate_teams' do
133
    before do
134 135
      @project_1 = create(:empty_project)
      @project_2 = create(:empty_project)
136 137 138 139

      @user_1 = create :user
      @user_2 = create :user

140 141
      @project_1.team << [ @user_1, :developer]
      @project_2.team << [ @user_2, :reporter]
142

143
      ProjectMember.truncate_teams([@project_1.id, @project_2.id])
144 145
    end

146 147
    it { expect(@project_1.users).to be_empty }
    it { expect(@project_2.users).to be_empty }
148
  end
149 150

  describe 'notifications' do
151 152 153
    describe '#after_accept_request' do
      it 'calls NotificationService.new_project_member' do
        member = create(:project_member, user: build_stubbed(:user), requested_at: Time.now)
154 155 156

        expect_any_instance_of(NotificationService).to receive(:new_project_member)

157
        member.__send__(:after_accept_request)
158 159 160
      end
    end
  end
gitlabhq committed
161
end