2013-01-04 16:35:31 -05:00
|
|
|
require "spec_helper"
|
|
|
|
|
2013-01-20 16:07:17 -05:00
|
|
|
describe ProjectTeam do
|
2014-06-04 04:52:17 -04:00
|
|
|
let(:master) { create(:user) }
|
|
|
|
let(:reporter) { create(:user) }
|
|
|
|
let(:guest) { create(:user) }
|
|
|
|
let(:nonmember) { create(:user) }
|
2013-01-04 16:35:31 -05:00
|
|
|
|
2014-06-20 05:54:03 -04:00
|
|
|
context 'personal project' do
|
|
|
|
let(:project) { create(:empty_project) }
|
2014-06-04 04:52:17 -04:00
|
|
|
|
2014-06-20 05:54:03 -04:00
|
|
|
before do
|
|
|
|
project.team << [master, :master]
|
|
|
|
project.team << [reporter, :reporter]
|
|
|
|
project.team << [guest, :guest]
|
|
|
|
end
|
2014-06-04 04:52:17 -04:00
|
|
|
|
2014-06-20 05:54:03 -04:00
|
|
|
describe 'members collection' do
|
|
|
|
it { project.team.masters.should include(master) }
|
|
|
|
it { project.team.masters.should_not include(guest) }
|
|
|
|
it { project.team.masters.should_not include(reporter) }
|
|
|
|
it { project.team.masters.should_not include(nonmember) }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'access methods' do
|
|
|
|
it { project.team.master?(master).should be_true }
|
|
|
|
it { project.team.master?(guest).should be_false }
|
|
|
|
it { project.team.master?(reporter).should be_false }
|
|
|
|
it { project.team.master?(nonmember).should be_false }
|
|
|
|
end
|
2014-06-04 04:52:17 -04:00
|
|
|
end
|
|
|
|
|
2014-06-20 05:54:03 -04:00
|
|
|
context 'group project' do
|
|
|
|
let(:group) { create(:group) }
|
|
|
|
let(:project) { create(:empty_project, group: group) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
group.add_user(master, Gitlab::Access::MASTER)
|
|
|
|
group.add_user(reporter, Gitlab::Access::REPORTER)
|
|
|
|
group.add_user(guest, Gitlab::Access::GUEST)
|
|
|
|
|
|
|
|
# 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
|
|
|
|
it { project.team.reporters.should include(reporter) }
|
|
|
|
it { project.team.masters.should include(master) }
|
|
|
|
it { project.team.masters.should include(guest) }
|
|
|
|
it { project.team.masters.should_not include(reporter) }
|
|
|
|
it { project.team.masters.should_not include(nonmember) }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'access methods' do
|
|
|
|
it { project.team.reporter?(reporter).should be_true }
|
|
|
|
it { project.team.master?(master).should be_true }
|
|
|
|
it { project.team.master?(guest).should be_true }
|
|
|
|
it { project.team.master?(reporter).should be_false }
|
|
|
|
it { project.team.master?(nonmember).should be_false }
|
|
|
|
end
|
2013-01-04 01:43:25 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|