2020-10-24 23:57:45 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Mutations::Issues::SetSubscription do
|
2021-09-04 01:27:46 +05:30
|
|
|
let_it_be_with_reload(:project) { create(:project) }
|
|
|
|
let_it_be_with_reload(:resource) { create(:issue, project: project) }
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
|
|
|
|
specify { expect(described_class).to require_graphql_authorizations(:update_subscription) }
|
|
|
|
|
|
|
|
context 'when user does not have access to the project' do
|
|
|
|
it_behaves_like 'a subscribeable not accessible graphql resource'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when user is developer member of the project' do
|
|
|
|
before do
|
|
|
|
project.add_developer(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'a subscribeable graphql resource'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the project is public' do
|
|
|
|
before do
|
|
|
|
project.update!(visibility_level: Gitlab::VisibilityLevel::PUBLIC)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'a subscribeable graphql resource'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the project is public but the issue is confidential' do
|
|
|
|
before do
|
|
|
|
project.update!(visibility_level: Gitlab::VisibilityLevel::PUBLIC)
|
|
|
|
resource.update!(confidential: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'a subscribeable not accessible graphql resource'
|
2020-10-24 23:57:45 +05:30
|
|
|
end
|
|
|
|
end
|