Commit 8abf0db0 authored by Vasilii Iakliushin's avatar Vasilii Iakliushin

Add `web_url` to branch API response

* Add test for API::Entities::Branch
* Add `web_url` example to API documentation
* Update schema for branches endpoint
* Add Changelog entry
parent 3c1182f1
---
title: Add `web_url` to branch API response
merge_request: 30147
author:
type: added
...@@ -41,6 +41,7 @@ Example response: ...@@ -41,6 +41,7 @@ Example response:
"developers_can_push": false, "developers_can_push": false,
"developers_can_merge": false, "developers_can_merge": false,
"can_push": true, "can_push": true,
"web_url": "http://gitlab.example.com/my-group/my-project/-/tree/master",
"commit": { "commit": {
"author_email": "john@example.com", "author_email": "john@example.com",
"author_name": "John Smith", "author_name": "John Smith",
...@@ -96,6 +97,7 @@ Example response: ...@@ -96,6 +97,7 @@ Example response:
"developers_can_push": false, "developers_can_push": false,
"developers_can_merge": false, "developers_can_merge": false,
"can_push": true, "can_push": true,
"web_url": "http://gitlab.example.com/my-group/my-project/-/tree/master",
"commit": { "commit": {
"author_email": "john@example.com", "author_email": "john@example.com",
"author_name": "John Smith", "author_name": "John Smith",
...@@ -171,7 +173,8 @@ Example response: ...@@ -171,7 +173,8 @@ Example response:
"default": false, "default": false,
"developers_can_push": false, "developers_can_push": false,
"developers_can_merge": false, "developers_can_merge": false,
"can_push": true "can_push": true,
"web_url": "http://gitlab.example.com/my-group/my-project/-/tree/newbranch"
} }
``` ```
......
...@@ -3,6 +3,8 @@ ...@@ -3,6 +3,8 @@
module API module API
module Entities module Entities
class Branch < Grape::Entity class Branch < Grape::Entity
include Gitlab::Routing
expose :name expose :name
expose :commit, using: Entities::Commit do |repo_branch, options| expose :commit, using: Entities::Commit do |repo_branch, options|
...@@ -36,6 +38,10 @@ module API ...@@ -36,6 +38,10 @@ module API
expose :default do |repo_branch, options| expose :default do |repo_branch, options|
options[:project].default_branch == repo_branch.name options[:project].default_branch == repo_branch.name
end end
expose :web_url do |repo_branch|
project_tree_url(options[:project], repo_branch.name)
end
end end
end end
end end
...@@ -7,7 +7,8 @@ ...@@ -7,7 +7,8 @@
"protected", "protected",
"default", "default",
"developers_can_push", "developers_can_push",
"developers_can_merge" "developers_can_merge",
"web_url"
], ],
"properties" : { "properties" : {
"name": { "type": "string" }, "name": { "type": "string" },
...@@ -17,7 +18,8 @@ ...@@ -17,7 +18,8 @@
"default": { "type": "boolean" }, "default": { "type": "boolean" },
"developers_can_push": { "type": "boolean" }, "developers_can_push": { "type": "boolean" },
"developers_can_merge": { "type": "boolean" }, "developers_can_merge": { "type": "boolean" },
"can_push": { "type": "boolean" } "can_push": { "type": "boolean" },
"web_url": { "type": "uri" }
}, },
"additionalProperties": false "additionalProperties": false
} }
# frozen_string_literal: true
require 'spec_helper'
describe API::Entities::Branch do
describe '#as_json' do
subject { entity.as_json }
let(:project) { create(:project, :public, :repository) }
let(:repository) { project.repository }
let(:branch) { repository.find_branch('master') }
let(:entity) { described_class.new(branch, project: project) }
it 'includes basic fields', :aggregate_failures do
is_expected.to include(
name: 'master',
commit: a_kind_of(Hash),
merged: false,
protected: false,
developers_can_push: false,
developers_can_merge: false,
can_push: false,
default: true,
web_url: Gitlab::Routing.url_helpers.project_tree_url(project, 'master')
)
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