gitlab-org--gitlab-foss/spec/features/security/group/internal_group_access_spec.rb

83 lines
2.5 KiB
Ruby
Raw Normal View History

2013-09-25 10:27:16 +00:00
require 'spec_helper'
describe "Group with internal project access", feature: true do
2013-09-25 10:27:16 +00:00
describe "Group" do
let(:group) { create(:group) }
2013-09-26 11:52:17 +00:00
let(:owner) { create(:owner) }
2013-09-25 10:27:16 +00:00
let(:master) { create(:user) }
let(:reporter) { create(:user) }
let(:guest) { create(:user) }
let(:nonmember) { create(:user) }
2013-09-25 10:27:16 +00:00
before do
2013-09-26 11:52:17 +00:00
group.add_user(owner, Gitlab::Access::OWNER)
2013-09-25 10:27:16 +00:00
group.add_user(master, Gitlab::Access::MASTER)
group.add_user(reporter, Gitlab::Access::REPORTER)
group.add_user(guest, Gitlab::Access::GUEST)
2014-03-19 09:15:24 +00:00
create(:project, :internal, group: group)
end
2013-09-25 10:27:16 +00:00
describe "GET /groups/:path" do
subject { group_path(group) }
2013-09-26 11:52:17 +00:00
it { should be_allowed_for owner }
2013-09-25 10:27:16 +00:00
it { should be_allowed_for master }
it { should be_allowed_for reporter }
it { should be_allowed_for :admin }
it { should be_allowed_for guest }
it { should be_allowed_for :user }
2013-09-25 10:27:16 +00:00
it { should be_denied_for :visitor }
end
describe "GET /groups/:path/issues" do
subject { issues_group_path(group) }
2013-09-26 11:52:17 +00:00
it { should be_allowed_for owner }
2013-09-25 10:27:16 +00:00
it { should be_allowed_for master }
it { should be_allowed_for reporter }
it { should be_allowed_for :admin }
it { should be_allowed_for guest }
it { should be_allowed_for :user }
2013-09-25 10:27:16 +00:00
it { should be_denied_for :visitor }
end
describe "GET /groups/:path/merge_requests" do
subject { merge_requests_group_path(group) }
2013-09-26 11:52:17 +00:00
it { should be_allowed_for owner }
2013-09-25 10:27:16 +00:00
it { should be_allowed_for master }
it { should be_allowed_for reporter }
it { should be_allowed_for :admin }
it { should be_allowed_for guest }
it { should be_allowed_for :user }
2013-09-25 10:27:16 +00:00
it { should be_denied_for :visitor }
end
describe "GET /groups/:path/members" do
subject { members_group_path(group) }
2013-09-26 11:52:17 +00:00
it { should be_allowed_for owner }
2013-09-25 10:27:16 +00:00
it { should be_allowed_for master }
it { should be_allowed_for reporter }
it { should be_allowed_for :admin }
it { should be_allowed_for guest }
it { should be_allowed_for :user }
2013-09-25 10:27:16 +00:00
it { should be_denied_for :visitor }
end
describe "GET /groups/:path/edit" do
subject { edit_group_path(group) }
2013-09-26 11:52:17 +00:00
it { should be_allowed_for owner }
2013-09-25 10:27:16 +00:00
it { should be_denied_for master }
it { should be_denied_for reporter }
it { should be_allowed_for :admin }
it { should be_denied_for guest }
it { should be_denied_for :user }
it { should be_denied_for :visitor }
end
end
end