Commit b60d81fb authored by Sean McGivern's avatar Sean McGivern

Merge branch 'feature/extend-boards-api' into 'master'

Expose board project and milestone on boards API

Closes #1851

See merge request !1407
parents ff96fe79 46cdb2cd
---
title: Expose board project and milestone on boards API
merge_request:
author:
...@@ -27,6 +27,19 @@ Example response: ...@@ -27,6 +27,19 @@ Example response:
[ [
{ {
"id" : 1, "id" : 1,
"project": {
"id": 3,
"name": "Diaspora Project Site",
"name_with_namespace": "Diaspora / Diaspora Project Site",
"path": "diaspora-project-site",
"path_with_namespace": "diaspora/diaspora-project-site",
"http_url_to_repo": "http://example.com/diaspora/diaspora-project-site.git",
"web_url": "http://example.com/diaspora/diaspora-project-site"
},
"milestone": {
"id": 12
"title": "10.0"
},
"lists" : [ "lists" : [
{ {
"id" : 1, "id" : 1,
......
...@@ -567,6 +567,9 @@ module API ...@@ -567,6 +567,9 @@ module API
class Board < Grape::Entity class Board < Grape::Entity
expose :id expose :id
expose :name
expose :project, using: Entities::BasicProjectDetails
expose :milestone
expose :lists, using: Entities::List do |board| expose :lists, using: Entities::List do |board|
board.lists.destroyable board.lists.destroyable
end end
......
{
"type": "object",
"required" : [
"id",
"name",
"project",
"milestone",
"lists"
],
"properties" : {
"id": { "type": "integer" },
"name": { "type": "string" },
"project": {
"type": "object",
"required": [
"id",
"name",
"name_with_namespace",
"path",
"path_with_namespace",
"http_url_to_repo",
"web_url"
],
"properties": {
"id": { "type": "integer" },
"name": { "type": "string" },
"name_with_namespace": { "type": "string" },
"path": { "type": "string" },
"path_with_namespace": { "type": "string" },
"http_url_to_repo": { "type": "string" },
"web_url": { "type": "string" }
},
"additionalProperties": false
},
"milestone": {
"type": ["object", "null"],
"required": [
"id",
"title"
],
"properties": {
"id": { "type": "integer" },
"title": { "type": "string" }
},
"additionalProperties": false
},
"lists": {
"type": "array",
"items": {
"type": "object",
"required" : [
"id",
"label",
"position"
],
"properties" : {
"id": { "type": "integer" },
"label": {
"type": ["object", "null"],
"required": [
"id",
"color",
"description",
"name"
],
"properties": {
"id": { "type": "integer" },
"color": {
"type": "string",
"pattern": "^#[0-9A-Fa-f]{3}{1,2}+$"
},
"description": { "type": ["string", "null"] },
"name": { "type": "string" }
}
},
"position": { "type": ["integer", "null"] }
},
"additionalProperties": false
}
}
},
"additionalProperties": false
}
{
"type": "array",
"items": { "$ref": "board.json" }
}
...@@ -4,11 +4,11 @@ describe API::Boards, api: true do ...@@ -4,11 +4,11 @@ describe API::Boards, api: true do
include ApiHelpers include ApiHelpers
let(:user) { create(:user) } let(:user) { create(:user) }
let(:user2) { create(:user) }
let(:non_member) { create(:user) } let(:non_member) { create(:user) }
let(:guest) { create(:user) } let(:guest) { create(:user) }
let(:admin) { create(:user, :admin) } let(:admin) { create(:user, :admin) }
let!(:project) { create(:empty_project, :public, creator_id: user.id, namespace: user.namespace ) } let!(:project) { create(:empty_project, :public, creator_id: user.id, namespace: user.namespace ) }
let(:milestone) { create(:milestone, project: project) }
let!(:dev_label) do let!(:dev_label) do
create(:label, title: 'Development', color: '#FFAABB', project: project) create(:label, title: 'Development', color: '#FFAABB', project: project)
...@@ -31,7 +31,7 @@ describe API::Boards, api: true do ...@@ -31,7 +31,7 @@ describe API::Boards, api: true do
end end
let!(:board) do let!(:board) do
create(:board, project: project, lists: [dev_list, test_list]) create(:board, project: project, milestone: milestone, lists: [dev_list, test_list])
end end
before do before do
...@@ -56,12 +56,7 @@ describe API::Boards, api: true do ...@@ -56,12 +56,7 @@ describe API::Boards, api: true do
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
expect(response).to include_pagination_headers expect(response).to include_pagination_headers
expect(json_response).to be_an Array expect(response).to match_response_schema('public_api/v4/boards')
expect(json_response.length).to eq(1)
expect(json_response.first['id']).to eq(board.id)
expect(json_response.first['lists']).to be_an Array
expect(json_response.first['lists'].length).to eq(2)
expect(json_response.first['lists'].last).to have_key('position')
end end
end 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