2014-09-02 18:07:02 +05:30
|
|
|
require "spec_helper"
|
|
|
|
|
2015-12-23 02:04:40 +05:30
|
|
|
describe ProjectTeam, models: true do
|
2014-09-02 18:07:02 +05:30
|
|
|
let(:master) { create(:user) }
|
|
|
|
let(:reporter) { create(:user) }
|
|
|
|
let(:guest) { create(:user) }
|
|
|
|
let(:nonmember) { create(:user) }
|
|
|
|
|
|
|
|
context 'personal project' do
|
|
|
|
let(:project) { create(:empty_project) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.team << [master, :master]
|
|
|
|
project.team << [reporter, :reporter]
|
|
|
|
project.team << [guest, :guest]
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'members collection' do
|
2015-04-26 12:48:37 +05:30
|
|
|
it { expect(project.team.masters).to include(master) }
|
|
|
|
it { expect(project.team.masters).not_to include(guest) }
|
|
|
|
it { expect(project.team.masters).not_to include(reporter) }
|
|
|
|
it { expect(project.team.masters).not_to include(nonmember) }
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'access methods' do
|
2015-04-26 12:48:37 +05:30
|
|
|
it { expect(project.team.master?(master)).to be_truthy }
|
|
|
|
it { expect(project.team.master?(guest)).to be_falsey }
|
|
|
|
it { expect(project.team.master?(reporter)).to be_falsey }
|
|
|
|
it { expect(project.team.master?(nonmember)).to be_falsey }
|
|
|
|
it { expect(project.team.member?(nonmember)).to be_falsey }
|
|
|
|
it { expect(project.team.member?(guest)).to be_truthy }
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'group project' do
|
|
|
|
let(:group) { create(:group) }
|
|
|
|
let(:project) { create(:empty_project, group: group) }
|
|
|
|
|
|
|
|
before do
|
2015-09-11 14:41:01 +05:30
|
|
|
group.add_master(master)
|
|
|
|
group.add_reporter(reporter)
|
|
|
|
group.add_guest(guest)
|
2014-09-02 18:07:02 +05:30
|
|
|
|
|
|
|
# If user is a group and a project member - GitLab uses highest permission
|
|
|
|
# So we add group guest as master and add group master as guest
|
|
|
|
# to this project to test highest access
|
|
|
|
project.team << [guest, :master]
|
|
|
|
project.team << [master, :guest]
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'members collection' do
|
2015-04-26 12:48:37 +05:30
|
|
|
it { expect(project.team.reporters).to include(reporter) }
|
|
|
|
it { expect(project.team.masters).to include(master) }
|
|
|
|
it { expect(project.team.masters).to include(guest) }
|
|
|
|
it { expect(project.team.masters).not_to include(reporter) }
|
|
|
|
it { expect(project.team.masters).not_to include(nonmember) }
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'access methods' do
|
2015-04-26 12:48:37 +05:30
|
|
|
it { expect(project.team.reporter?(reporter)).to be_truthy }
|
|
|
|
it { expect(project.team.master?(master)).to be_truthy }
|
|
|
|
it { expect(project.team.master?(guest)).to be_truthy }
|
|
|
|
it { expect(project.team.master?(reporter)).to be_falsey }
|
|
|
|
it { expect(project.team.master?(nonmember)).to be_falsey }
|
|
|
|
it { expect(project.team.member?(nonmember)).to be_falsey }
|
|
|
|
it { expect(project.team.member?(guest)).to be_truthy }
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
end
|
2015-10-24 18:46:33 +05:30
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
describe :max_invited_level do
|
|
|
|
let(:group) { create(:group) }
|
|
|
|
let(:project) { create(:empty_project) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.project_group_links.create(
|
|
|
|
group: group,
|
|
|
|
group_access: Gitlab::Access::DEVELOPER
|
|
|
|
)
|
|
|
|
|
|
|
|
group.add_user(master, Gitlab::Access::MASTER)
|
|
|
|
group.add_user(reporter, Gitlab::Access::REPORTER)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(project.team.max_invited_level(master.id)).to eq(Gitlab::Access::DEVELOPER) }
|
|
|
|
it { expect(project.team.max_invited_level(reporter.id)).to eq(Gitlab::Access::REPORTER) }
|
|
|
|
it { expect(project.team.max_invited_level(nonmember.id)).to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe :max_member_access do
|
|
|
|
let(:group) { create(:group) }
|
|
|
|
let(:project) { create(:empty_project) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.project_group_links.create(
|
|
|
|
group: group,
|
|
|
|
group_access: Gitlab::Access::DEVELOPER
|
|
|
|
)
|
|
|
|
|
|
|
|
group.add_user(master, Gitlab::Access::MASTER)
|
|
|
|
group.add_user(reporter, Gitlab::Access::REPORTER)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(project.team.max_member_access(master.id)).to eq(Gitlab::Access::DEVELOPER) }
|
|
|
|
it { expect(project.team.max_member_access(reporter.id)).to eq(Gitlab::Access::REPORTER) }
|
|
|
|
it { expect(project.team.max_member_access(nonmember.id)).to be_nil }
|
|
|
|
|
|
|
|
it "does not have an access" do
|
|
|
|
project.namespace.update(share_with_group_lock: true)
|
|
|
|
expect(project.team.max_member_access(master.id)).to be_nil
|
|
|
|
expect(project.team.max_member_access(reporter.id)).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-10-24 18:46:33 +05:30
|
|
|
describe "#human_max_access" do
|
2016-04-02 18:10:28 +05:30
|
|
|
it 'returns Master role' do
|
|
|
|
user = create(:user)
|
|
|
|
group = create(:group)
|
|
|
|
group.add_master(user)
|
|
|
|
|
|
|
|
project = build_stubbed(:empty_project, namespace: group)
|
|
|
|
|
|
|
|
expect(project.team.human_max_access(user.id)).to eq 'Master'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns Owner role' do
|
|
|
|
user = create(:user)
|
|
|
|
group = create(:group)
|
|
|
|
group.add_owner(user)
|
|
|
|
|
|
|
|
project = build_stubbed(:empty_project, namespace: group)
|
|
|
|
|
|
|
|
expect(project.team.human_max_access(user.id)).to eq 'Owner'
|
2015-10-24 18:46:33 +05:30
|
|
|
end
|
|
|
|
end
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|