Commit 2adbed48 authored by Jan Provaznik's avatar Jan Provaznik

Add pagination to epics API

Epics returned by epics API endpoint are now paginated.
parent 258e73a8
...@@ -18,6 +18,13 @@ Since start date and due date can be dynamically sourced from related issue mile ...@@ -18,6 +18,13 @@ Since start date and due date can be dynamically sourced from related issue mile
`end_date` has been deprecated in favor of `due_date`. `end_date` has been deprecated in favor of `due_date`.
## Epics pagination
By default, `GET` requests return 20 results at a time because the API results
are paginated.
Read more on [pagination](README.md#pagination).
## List epics for a group ## List epics for a group
Gets all epics of the requested group and its subgroups. Gets all epics of the requested group and its subgroups.
......
---
title: Added pagination to epics API endpoint.
merge_request:
author:
type: added
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
module API module API
class Epics < Grape::API class Epics < Grape::API
include PaginationParams
before do before do
authenticate! authenticate!
authorize_epics_feature! authorize_epics_feature!
...@@ -64,9 +66,12 @@ module API ...@@ -64,9 +66,12 @@ module API
desc: 'Return opened, closed, or all epics' desc: 'Return opened, closed, or all epics'
optional :author_id, type: Integer, desc: 'Return epics which are authored by the user with the given ID' optional :author_id, type: Integer, desc: 'Return epics which are authored by the user with the given ID'
optional :labels, type: String, desc: 'Comma-separated list of label names' optional :labels, type: String, desc: 'Comma-separated list of label names'
use :pagination
end end
get ':id/(-/)epics' do get ':id/(-/)epics' do
present find_epics(group_id: user_group.id), with: EE::API::Entities::Epic, user: current_user epics = find_epics(group_id: user_group.id)
present paginate(epics), with: EE::API::Entities::Epic, user: current_user
end end
desc 'Get details of an epic' do desc 'Get details of an epic' do
......
...@@ -69,6 +69,16 @@ describe API::Epics do ...@@ -69,6 +69,16 @@ describe API::Epics do
describe 'GET /groups/:id/epics' do describe 'GET /groups/:id/epics' do
let(:url) { "/groups/#{group.path}/epics" } let(:url) { "/groups/#{group.path}/epics" }
def expect_paginated_array_of_items(expected)
expect(response).to have_gitlab_http_status(200)
expect(response).to include_pagination_headers
expect(json_response).to be_an Array
items = json_response.map { |i| i['id'] }
expect(items).to eq(expected)
end
it_behaves_like 'error requests' it_behaves_like 'error requests'
context 'when the request is correct' do context 'when the request is correct' do
...@@ -112,74 +122,103 @@ describe API::Epics do ...@@ -112,74 +122,103 @@ describe API::Epics do
stub_licensed_features(epics: true) stub_licensed_features(epics: true)
end end
def expect_array_response(expected)
items = json_response.map { |i| i['id'] }
expect(items).to eq(expected)
end
it 'returns epics authored by the given author id' do it 'returns epics authored by the given author id' do
get api(url, user), params: { author_id: user2.id } get api(url, user), params: { author_id: user2.id }
expect_array_response([epic2.id]) expect_paginated_array_of_items([epic2.id])
end end
it 'returns epics matching given search string for title' do it 'returns epics matching given search string for title' do
get api(url, user), params: { search: epic2.title } get api(url, user), params: { search: epic2.title }
expect_array_response([epic2.id]) expect_paginated_array_of_items([epic2.id])
end end
it 'returns epics matching given search string for description' do it 'returns epics matching given search string for description' do
get api(url, user), params: { search: epic2.description } get api(url, user), params: { search: epic2.description }
expect_array_response([epic2.id]) expect_paginated_array_of_items([epic2.id])
end end
it 'returns epics matching given status' do it 'returns epics matching given status' do
get api(url, user), params: { state: :opened } get api(url, user), params: { state: :opened }
expect_array_response([epic2.id]) expect_paginated_array_of_items([epic2.id])
end end
it 'returns all epics when state set to all' do it 'returns all epics when state set to all' do
get api(url, user), params: { state: :all } get api(url, user), params: { state: :all }
expect_array_response([epic2.id, epic.id]) expect_paginated_array_of_items([epic2.id, epic.id])
end end
it 'sorts by created_at descending by default' do it 'sorts by created_at descending by default' do
get api(url, user) get api(url, user)
expect_array_response([epic2.id, epic.id]) expect_paginated_array_of_items([epic2.id, epic.id])
end end
it 'sorts ascending when requested' do it 'sorts ascending when requested' do
get api(url, user), params: { sort: :asc } get api(url, user), params: { sort: :asc }
expect_array_response([epic.id, epic2.id]) expect_paginated_array_of_items([epic.id, epic2.id])
end end
it 'sorts by updated_at descending when requested' do it 'sorts by updated_at descending when requested' do
get api(url, user), params: { order_by: :updated_at } get api(url, user), params: { order_by: :updated_at }
expect_array_response([epic.id, epic2.id]) expect_paginated_array_of_items([epic.id, epic2.id])
end end
it 'sorts by updated_at ascending when requested' do it 'sorts by updated_at ascending when requested' do
get api(url, user), params: { order_by: :updated_at, sort: :asc } get api(url, user), params: { order_by: :updated_at, sort: :asc }
expect_array_response([epic2.id, epic.id]) expect_paginated_array_of_items([epic2.id, epic.id])
end end
it 'returns an array of labeled epics' do it 'returns an array of labeled epics' do
get api(url, user), params: { labels: label.title } get api(url, user), params: { labels: label.title }
expect_array_response([epic2.id]) expect_paginated_array_of_items([epic2.id])
end end
it_behaves_like 'can admin epics' it_behaves_like 'can admin epics'
end end
context 'with pagination params' do
let(:page) { 1 }
let(:per_page) { 2 }
let!(:epic1) { create(:epic, group: group, created_at: 3.days.ago) }
let!(:epic2) { create(:epic, group: group, created_at: 2.days.ago) }
let!(:epic3) { create(:epic, group: group, created_at: 1.day.ago) }
before do
stub_licensed_features(epics: true)
end
shared_examples 'paginated API endpoint' do
it 'returns the correct page' do
get api(url, user), params: { page: page, per_page: per_page }
expect(response.headers['X-Page']).to eq(page.to_s)
expect_paginated_array_of_items(expected)
end
end
context 'when viewing the first page' do
let(:expected) { [epic3.id, epic2.id] }
let(:page) { 1 }
it_behaves_like 'paginated API endpoint'
end
context 'viewing the second page' do
let(:expected) { [epic1.id] }
let(:page) { 2 }
it_behaves_like 'paginated API endpoint'
end
end
end end
describe 'GET /groups/:id/epics/:epic_iid' do describe 'GET /groups/:id/epics/:epic_iid' do
......
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