Commit 32f5c0f7 authored by syasonik's avatar syasonik

Expose enough shifts records to fill a schedule

parent 500aa483
...@@ -3,6 +3,8 @@ ...@@ -3,6 +3,8 @@
module Types module Types
module IncidentManagement module IncidentManagement
class OncallRotationType < BaseObject class OncallRotationType < BaseObject
MAX_SHIFTS_FOR_TIMEFRAME = 350
graphql_name 'IncidentManagementOncallRotation' graphql_name 'IncidentManagementOncallRotation'
description 'Describes an incident management on-call rotation' description 'Describes an incident management on-call rotation'
...@@ -52,6 +54,7 @@ module Types ...@@ -52,6 +54,7 @@ module Types
::Types::IncidentManagement::OncallShiftType.connection_type, ::Types::IncidentManagement::OncallShiftType.connection_type,
null: true, null: true,
description: 'Blocks of time for which a participant is on-call within a given time frame. Time frame cannot exceed one month.', description: 'Blocks of time for which a participant is on-call within a given time frame. Time frame cannot exceed one month.',
max_page_size: MAX_SHIFTS_FOR_TIMEFRAME,
resolver: ::Resolvers::IncidentManagement::OncallShiftsResolver resolver: ::Resolvers::IncidentManagement::OncallShiftsResolver
end end
end end
......
...@@ -22,4 +22,9 @@ RSpec.describe GitlabSchema.types['IncidentManagementOncallRotation'] do ...@@ -22,4 +22,9 @@ RSpec.describe GitlabSchema.types['IncidentManagementOncallRotation'] do
expect(described_class).to have_graphql_fields(*expected_fields) expect(described_class).to have_graphql_fields(*expected_fields)
end end
it 'returns enough records to cover 2 weeks of hour-long shifts' do
expect(described_class::MAX_SHIFTS_FOR_TIMEFRAME).to be > 14 * 24 # 14 days * 24 hours
expect(described_class).to have_graphql_field(:shifts, max_page_size: described_class::MAX_SHIFTS_FOR_TIMEFRAME)
end
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