Commit 83c1861b authored by charlie ablett's avatar charlie ablett

Merge branch 'fix-fetch-iteration-cadence-by-id' into 'master'

Fix fetch iteration cadence by id

See merge request gitlab-org/gitlab!67083
parents 5f150140 23048f87
...@@ -26,16 +26,25 @@ module Resolvers ...@@ -26,16 +26,25 @@ module Resolvers
type ::Types::Iterations::CadenceType.connection_type, null: true type ::Types::Iterations::CadenceType.connection_type, null: true
def resolve(**args) def resolve(id: nil, **args)
authorize! authorize!
cadences = ::Iterations::CadencesFinder.new(context[:current_user], group, args).execute args[:id] = parse_id(id) if id.present?
cadences = ::Iterations::CadencesFinder.new(current_user, group, args).execute
offset_pagination(cadences) offset_pagination(cadences)
end end
private private
def parse_id(id)
GitlabSchema.parse_gid(id, expected_type: ::Iterations::Cadence).model_id
rescue Gitlab::Graphql::Errors::ArgumentError
# we need to support parameter as a raw model ID, not just valid global ID.
id
end
def group def group
@parent ||= object.respond_to?(:sync) ? object.sync : object @parent ||= object.respond_to?(:sync) ? object.sync : object
......
...@@ -29,6 +29,12 @@ RSpec.describe Resolvers::Iterations::CadencesResolver do ...@@ -29,6 +29,12 @@ RSpec.describe Resolvers::Iterations::CadencesResolver do
expect(resolve_group_iteration_cadences).to contain_exactly(active_group_iteration_cadence) expect(resolve_group_iteration_cadences).to contain_exactly(active_group_iteration_cadence)
end end
context 'iteration cadences by id' do
it 'returns iterations cadence by global id' do
expect(resolve_group_iteration_cadences({ id: active_group_iteration_cadence.to_global_id }, parent, { current_user: current_user })).to contain_exactly(active_group_iteration_cadence)
end
end
context 'when iteration cadences feature is disabled' do context 'when iteration cadences feature is disabled' do
before do before do
stub_feature_flags(iteration_cadences: false) stub_feature_flags(iteration_cadences: false)
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'getting iterations' do
include GraphqlHelpers
let_it_be(:now) { Time.now }
let_it_be(:user) { create(:user) }
let_it_be(:group) { create(:group) }
let_it_be(:project) { create(:project, group: group) }
let_it_be(:iteration_cadence1) { create(:iterations_cadence, group: group, active: true, duration_in_weeks: 1, title: 'one week iterations') }
let_it_be(:iteration_cadence2) { create(:iterations_cadence, group: group, active: true, duration_in_weeks: 2, title: 'two week iterations') }
before do
group.add_developer(user)
end
describe 'query for iteration cadence' do
shared_examples 'returns cadence by id' do
it 'returns cadence' do
post_graphql(iteration_cadence_by_id(group_or_project), current_user: user, variables: { id: cadence_id })
expect_iteration_cadences_response(group_or_project.class.name.downcase.to_sym, expected_result)
end
end
it 'returns all group cadences' do
post_graphql(iteration_cadences_query(group), current_user: user)
expect_iteration_cadences_response(:group, [iteration_cadence1, iteration_cadence2])
end
context 'by global id' do
let(:cadence_id) { iteration_cadence1.to_global_id.to_s }
let(:expected_result) { [iteration_cadence1] }
context 'fetching cadences from group level' do
let(:group_or_project) { group }
it_behaves_like 'returns cadence by id'
context 'from a different group' do
let(:other_group) { create(:group) }
let(:group_or_project) { other_group }
let(:expected_result) { [] }
it_behaves_like 'returns cadence by id'
end
end
context 'fetching cadences from project level' do
let(:group_or_project) { project }
it_behaves_like 'returns cadence by id'
end
end
context 'by integer id' do
let(:cadence_id) { iteration_cadence1.id.to_s }
let(:expected_result) { [iteration_cadence1] }
context 'fetching cadences from group level' do
let(:group_or_project) { group }
it_behaves_like 'returns cadence by id'
context 'from a different group' do
let(:other_group) { create(:group) }
let(:group_or_project) { other_group }
let(:expected_result) { [] }
it_behaves_like 'returns cadence by id'
end
end
context 'fetching cadences from project level' do
let(:group_or_project) { project }
it_behaves_like 'returns cadence by id'
end
end
end
def iteration_cadences_query(group)
<<~QUERY
query {
group(fullPath: "#{group.full_path}") {
id,
iterationCadences {
nodes {
id
}
}
}
}
QUERY
end
def iteration_cadence_by_id(parent)
if parent.is_a?(Group)
<<~QUERY
query($id: ID!) {
group(fullPath: "#{parent.full_path}") {
id,
iterationCadences(id: $id) {
nodes {
id
}
}
}
}
QUERY
else
<<~QUERY
query($id: ID!) {
project(fullPath: "#{parent.full_path}") {
id,
iterationCadences(id: $id) {
nodes {
id
}
}
}
}
QUERY
end
end
def expect_iteration_cadences_response(group_or_project, cadences)
actual_cadences = graphql_data_at(group_or_project.to_sym, :iterationCadences, :nodes).map { |cadence| cadence['id'] }
expected_cadences = cadences.map { |cadence| cadence.to_global_id.to_s }
expect(actual_cadences).to contain_exactly(*expected_cadences)
expect(graphql_errors).to be_nil
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment