# frozen_string_literal: true require 'spec_helper' RSpec.describe GitlabSchema.types['Project'] do include GraphqlHelpers specify { expect(described_class).to expose_permissions_using(Types::PermissionTypes::Project) } specify { expect(described_class.graphql_name).to eq('Project') } specify { expect(described_class).to require_graphql_authorizations(:read_project) } it 'has the expected fields' do expected_fields = %w[ user_permissions id full_path path name_with_namespace name description description_html tag_list ssh_url_to_repo http_url_to_repo web_url star_count forks_count created_at last_activity_at archived visibility container_registry_enabled shared_runners_enabled lfs_enabled merge_requests_ff_only_enabled avatar_url issues_enabled merge_requests_enabled wiki_enabled snippets_enabled jobs_enabled public_jobs open_issues_count import_status only_allow_merge_if_pipeline_succeeds request_access_enabled only_allow_merge_if_all_discussions_are_resolved printing_merge_request_link_enabled namespace group statistics repository merge_requests merge_request issues issue milestones pipelines removeSourceBranchAfterMerge sentryDetailedError snippets grafanaIntegration autocloseReferencedIssues suggestion_commit_message environments environment boards jira_import_status jira_imports services releases release alert_management_alerts alert_management_alert alert_management_alert_status_counts container_expiration_policy service_desk_enabled service_desk_address issue_status_counts terraform_states alert_management_integrations ] expect(described_class).to include_graphql_fields(*expected_fields) end describe 'issue field' do subject { described_class.fields['issue'] } it { is_expected.to have_graphql_type(Types::IssueType) } it { is_expected.to have_graphql_resolver(Resolvers::IssuesResolver.single) } end describe 'issues field' do subject { described_class.fields['issues'] } it { is_expected.to have_graphql_type(Types::IssueType.connection_type) } it { is_expected.to have_graphql_resolver(Resolvers::IssuesResolver) } end describe 'merge_request field' do subject { described_class.fields['mergeRequest'] } it { is_expected.to have_graphql_type(Types::MergeRequestType) } it { is_expected.to have_graphql_resolver(Resolvers::MergeRequestsResolver.single) } it { is_expected.to have_graphql_arguments(:iid) } end describe 'merge_requests field' do subject { described_class.fields['mergeRequests'] } it { is_expected.to have_graphql_type(Types::MergeRequestType.connection_type) } it { is_expected.to have_graphql_resolver(Resolvers::ProjectMergeRequestsResolver) } it do is_expected.to have_graphql_arguments(:iids, :source_branches, :target_branches, :state, :labels, :before, :after, :first, :last, :merged_after, :merged_before, :author_username, :assignee_username, :milestone_title, :sort ) end end describe 'snippets field' do subject { described_class.fields['snippets'] } it { is_expected.to have_graphql_type(Types::SnippetType.connection_type) } it { is_expected.to have_graphql_resolver(Resolvers::Projects::SnippetsResolver) } end describe 'grafana_integration field' do subject { described_class.fields['grafanaIntegration'] } it { is_expected.to have_graphql_type(Types::GrafanaIntegrationType) } it { is_expected.to have_graphql_resolver(Resolvers::Projects::GrafanaIntegrationResolver) } end describe 'environments field' do subject { described_class.fields['environments'] } it { is_expected.to have_graphql_type(Types::EnvironmentType.connection_type) } it { is_expected.to have_graphql_resolver(Resolvers::EnvironmentsResolver) } end describe 'environment field' do subject { described_class.fields['environment'] } it { is_expected.to have_graphql_type(Types::EnvironmentType) } it { is_expected.to have_graphql_resolver(Resolvers::EnvironmentsResolver.single) } end describe 'members field' do subject { described_class.fields['projectMembers'] } it { is_expected.to have_graphql_type(Types::MemberInterface.connection_type) } it { is_expected.to have_graphql_resolver(Resolvers::ProjectMembersResolver) } end describe 'boards field' do subject { described_class.fields['boards'] } it { is_expected.to have_graphql_type(Types::BoardType.connection_type) } end describe 'jira_imports field' do subject { described_class.fields['jiraImports'] } it { is_expected.to have_graphql_type(Types::JiraImportType.connection_type) } end describe 'services field' do subject { described_class.fields['services'] } it { is_expected.to have_graphql_type(Types::Projects::ServiceType.connection_type) } end describe 'releases field' do subject { described_class.fields['release'] } it { is_expected.to have_graphql_type(Types::ReleaseType) } it { is_expected.to have_graphql_resolver(Resolvers::ReleaseResolver) } end describe 'release field' do subject { described_class.fields['releases'] } it { is_expected.to have_graphql_type(Types::ReleaseType.connection_type) } it { is_expected.to have_graphql_resolver(Resolvers::ReleasesResolver) } end describe 'container expiration policy field' do subject { described_class.fields['containerExpirationPolicy'] } it { is_expected.to have_graphql_type(Types::ContainerExpirationPolicyType) } end describe 'terraform states field' do subject { described_class.fields['terraformStates'] } it { is_expected.to have_graphql_type(Types::Terraform::StateType.connection_type) } it { is_expected.to have_graphql_resolver(Resolvers::Terraform::StatesResolver) } end it_behaves_like 'a GraphQL type with labels' describe 'jira_imports' do subject { resolve_field(:jira_imports, project) } let_it_be(:project) { create(:project, :public) } context 'when project has Jira imports' do let_it_be(:jira_import1) { create(:jira_import_state, :finished, project: project, jira_project_key: 'AA', created_at: 2.days.ago) } let_it_be(:jira_import2) { create(:jira_import_state, :finished, project: project, jira_project_key: 'BB', created_at: 5.days.ago) } it 'retrieves the imports' do expect(subject).to contain_exactly(jira_import1, jira_import2) end end context 'when project does not have Jira imports' do it 'returns an empty result' do expect(subject).to be_empty end end end end