Commit 72d09bd8 authored by charlie ablett's avatar charlie ablett

Add created_at filters to MR resolver

Changelog: added
parent 02ab3b58
...@@ -68,6 +68,12 @@ module Resolvers ...@@ -68,6 +68,12 @@ module Resolvers
description: 'Sort merge requests by this criteria.', description: 'Sort merge requests by this criteria.',
required: false, required: false,
default_value: :created_desc default_value: :created_desc
argument :created_after, Types::TimeType,
required: false,
description: 'Merge requests created after this timestamp.'
argument :created_before, Types::TimeType,
required: false,
description: 'Merge requests created before this timestamp.'
negated do negated do
argument :labels, [GraphQL::Types::String], argument :labels, [GraphQL::Types::String],
......
This diff is collapsed.
...@@ -218,6 +218,54 @@ RSpec.describe Resolvers::MergeRequestsResolver do ...@@ -218,6 +218,54 @@ RSpec.describe Resolvers::MergeRequestsResolver do
end end
end end
context 'with created_after and created_before arguments' do
before do
merge_request_1.update!(created_at: 4.days.ago)
end
let(:all_mrs) do
[merge_request_1, merge_request_2, merge_request_3, merge_request_4, merge_request_5, merge_request_6, merge_request_with_milestone]
end
it 'returns merge requests created within a given period' do
result = resolve_mr(project, created_after: 5.days.ago, created_before: 2.days.ago)
expect(result).to contain_exactly(
merge_request_1
)
end
it 'returns some values filtered with created_before' do
result = resolve_mr(project, created_before: 1.day.ago)
expect(result).to contain_exactly(merge_request_1)
end
it 'returns some values filtered with created_after' do
result = resolve_mr(project, created_after: 3.days.ago)
expect(result).to match_array(all_mrs - [merge_request_1])
end
it 'does not return anything for dates (even in the future) not matching any MRs' do
result = resolve_mr(project, created_after: 5.days.from_now)
expect(result).to be_empty
end
it 'does not return anything for dates not matching any MRs' do
result = resolve_mr(project, created_before: 15.days.ago)
expect(result).to be_empty
end
it 'does not return any values for an impossible set' do
result = resolve_mr(project, created_after: 5.days.ago, created_before: 6.days.ago)
expect(result).to be_empty
end
end
context 'with milestone argument' do context 'with milestone argument' do
it 'filters merge requests by milestone title' do it 'filters merge requests by milestone title' do
result = resolve_mr(project, milestone_title: milestone.title) result = resolve_mr(project, milestone_title: milestone.title)
......
...@@ -296,6 +296,8 @@ RSpec.describe GitlabSchema.types['Project'] do ...@@ -296,6 +296,8 @@ RSpec.describe GitlabSchema.types['Project'] do
:last, :last,
:merged_after, :merged_after,
:merged_before, :merged_before,
:created_after,
:created_before,
:author_username, :author_username,
:assignee_username, :assignee_username,
:reviewer_username, :reviewer_username,
......
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