debian-mirror-gitlab/spec/requests/api/graphql/ci/stages_spec.rb
2021-11-11 11:23:49 +05:30

76 lines
1.7 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'Query.project.pipeline.stages' do
include GraphqlHelpers
subject(:post_query) { post_graphql(query, current_user: user) }
let_it_be(:project) { create(:project, :repository, :public) }
let_it_be(:user) { create(:user) }
let_it_be(:pipeline) { create(:ci_pipeline, project: project, user: user) }
let(:stage_nodes) { graphql_data_at(:project, :pipeline, :stages, :nodes) }
let(:params) { {} }
let(:fields) do
<<~QUERY
nodes {
#{all_graphql_fields_for('CiStage')}
}
QUERY
end
let(:query) do
%(
query {
project(fullPath: "#{project.full_path}") {
pipeline(iid: "#{pipeline.iid}") {
stages {
#{fields}
}
}
}
}
)
end
before_all do
create(:ci_stage_entity, pipeline: pipeline, name: 'deploy')
create_list(:ci_build, 2, pipeline: pipeline, stage: 'deploy')
end
it_behaves_like 'a working graphql query' do
before do
post_query
end
end
it 'returns the stage of a pipeline' do
post_query
expect(stage_nodes.first['name']).to eq('deploy')
end
describe 'job pagination' do
let(:job_nodes) { graphql_dig_at(stage_nodes, :jobs, :nodes) }
it 'returns up to default limit jobs per stage' do
post_query
expect(job_nodes.count).to eq(2)
end
context 'when the limit is manually set' do
before do
stub_application_setting(jobs_per_stage_page_size: 1)
end
it 'returns up to custom limit jobs per stage' do
post_query
expect(job_nodes.count).to eq(1)
end
end
end
end