# frozen_string_literal: true require 'spec_helper' RSpec.describe Resolvers::AlertManagement::HttpIntegrationsResolver do include GraphqlHelpers let_it_be(:guest) { create(:user) } let_it_be(:developer) { create(:user) } let_it_be(:maintainer) { create(:user) } let_it_be(:project) { create(:project) } let_it_be(:prometheus_integration) { create(:prometheus_integration, project: project) } let_it_be(:active_http_integration) { create(:alert_management_http_integration, project: project) } let_it_be(:inactive_http_integration) { create(:alert_management_http_integration, :inactive, project: project) } let_it_be(:other_proj_integration) { create(:alert_management_http_integration) } let(:params) { {} } subject { sync(resolve_http_integrations(params)) } before do project.add_developer(developer) project.add_maintainer(maintainer) end specify do expect(described_class).to have_nullable_graphql_type(Types::AlertManagement::HttpIntegrationType.connection_type) end context 'user does not have permission' do let(:current_user) { guest } it { is_expected.to be_empty } end context 'user has developer permission' do let(:current_user) { developer } it { is_expected.to be_empty } end context 'user has maintainer permission' do let(:current_user) { maintainer } it { is_expected.to contain_exactly(active_http_integration) } context 'when HTTP Integration ID is given' do context 'when integration is from the current project' do let(:params) { { id: global_id_of(inactive_http_integration) } } it { is_expected.to contain_exactly(inactive_http_integration) } end context 'when integration is from other project' do let(:params) { { id: global_id_of(other_proj_integration) } } it { is_expected.to be_empty } end end end private def resolve_http_integrations(args = {}, context = { current_user: current_user }) resolve(described_class, obj: project, args: args, ctx: context) end end