Commit 405e5720 authored by Rémy Coutable's avatar Rémy Coutable

Merge branch 'tc-expose_more_attributes-ee' into 'master'

CE to EE: Expose more attributes ee

See merge request !2642
parents 72360817 aa6ab7cd
...@@ -76,13 +76,6 @@ module API ...@@ -76,13 +76,6 @@ module API
expose :file_name_regex, :max_file_size expose :file_name_regex, :max_file_size
end end
class BasicProjectDetails < Grape::Entity
expose :id
expose :http_url_to_repo, :web_url
expose :name, :name_with_namespace
expose :path, :path_with_namespace
end
class SharedGroup < Grape::Entity class SharedGroup < Grape::Entity
expose :group_id expose :group_id
expose :group_name do |group_link, options| expose :group_name do |group_link, options|
...@@ -91,7 +84,16 @@ module API ...@@ -91,7 +84,16 @@ module API
expose :group_access, as: :group_access_level expose :group_access, as: :group_access_level
end end
class Project < Grape::Entity class BasicProjectDetails < Grape::Entity
expose :id, :description, :default_branch, :tag_list
expose :ssh_url_to_repo, :http_url_to_repo, :web_url
expose :name, :name_with_namespace
expose :path, :path_with_namespace
expose :star_count, :forks_count
expose :created_at, :last_activity_at
end
class Project < BasicProjectDetails
include ::API::Helpers::RelatedResourcesHelpers include ::API::Helpers::RelatedResourcesHelpers
expose :_links do expose :_links do
...@@ -124,12 +126,9 @@ module API ...@@ -124,12 +126,9 @@ module API
end end
end end
expose :id, :description, :default_branch, :tag_list
expose :archived?, as: :archived expose :archived?, as: :archived
expose :visibility, :ssh_url_to_repo, :http_url_to_repo, :web_url expose :visibility
expose :owner, using: Entities::UserBasic, unless: ->(project, options) { project.group } expose :owner, using: Entities::UserBasic, unless: ->(project, options) { project.group }
expose :name, :name_with_namespace
expose :path, :path_with_namespace
expose :container_registry_enabled expose :container_registry_enabled
# Expose old field names with the new permissions methods to keep API compatible # Expose old field names with the new permissions methods to keep API compatible
...@@ -139,7 +138,6 @@ module API ...@@ -139,7 +138,6 @@ module API
expose(:jobs_enabled) { |project, options| project.feature_available?(:builds, options[:current_user]) } expose(:jobs_enabled) { |project, options| project.feature_available?(:builds, options[:current_user]) }
expose(:snippets_enabled) { |project, options| project.feature_available?(:snippets, options[:current_user]) } expose(:snippets_enabled) { |project, options| project.feature_available?(:snippets, options[:current_user]) }
expose :created_at, :last_activity_at
expose :shared_runners_enabled expose :shared_runners_enabled
expose :lfs_enabled?, as: :lfs_enabled expose :lfs_enabled?, as: :lfs_enabled
expose :creator_id expose :creator_id
...@@ -150,7 +148,6 @@ module API ...@@ -150,7 +148,6 @@ module API
expose :avatar_url do |user, options| expose :avatar_url do |user, options|
user.avatar_url(only_path: false) user.avatar_url(only_path: false)
end end
expose :star_count, :forks_count
expose :open_issues_count, if: lambda { |project, options| project.feature_available?(:issues, options[:current_user]) } expose :open_issues_count, if: lambda { |project, options| project.feature_available?(:issues, options[:current_user]) }
expose :runners_token, if: lambda { |_project, options| options[:user_can_admin_project] } expose :runners_token, if: lambda { |_project, options| options[:user_can_admin_project] }
expose :public_builds, as: :public_jobs expose :public_builds, as: :public_jobs
......
...@@ -14,21 +14,37 @@ ...@@ -14,21 +14,37 @@
"type": "object", "type": "object",
"required": [ "required": [
"id", "id",
"description",
"default_branch",
"tag_list",
"ssh_url_to_repo",
"http_url_to_repo",
"web_url",
"name", "name",
"name_with_namespace", "name_with_namespace",
"path", "path",
"path_with_namespace", "path_with_namespace",
"http_url_to_repo", "star_count",
"web_url" "forks_count",
"created_at",
"last_activity_at"
], ],
"properties": { "properties": {
"id": { "type": "integer" }, "id": { "type": "integer" },
"description": { "type": ["string", "null"] },
"default_branch": { "type": ["string", "null"] },
"tag_list": { "type": "array" },
"ssh_url_to_repo": { "type": "string" },
"http_url_to_repo": { "type": "string" },
"web_url": { "type": "string" },
"name": { "type": "string" }, "name": { "type": "string" },
"name_with_namespace": { "type": "string" }, "name_with_namespace": { "type": "string" },
"path": { "type": "string" }, "path": { "type": "string" },
"path_with_namespace": { "type": "string" }, "path_with_namespace": { "type": "string" },
"http_url_to_repo": { "type": "string" }, "star_count": { "type": "integer" },
"web_url": { "type": "string" } "forks_count": { "type": "integer" },
"created_at": { "type": "date" },
"last_activity_at": { "type": "date" }
}, },
"additionalProperties": false "additionalProperties": false
}, },
......
...@@ -13,7 +13,14 @@ describe API::Environments do ...@@ -13,7 +13,14 @@ describe API::Environments do
describe 'GET /projects/:id/environments' do describe 'GET /projects/:id/environments' do
context 'as member of the project' do context 'as member of the project' do
it 'returns project environments' do it 'returns project environments' do
project_data_keys = %w(id http_url_to_repo web_url name name_with_namespace path path_with_namespace) project_data_keys = %w(
id description default_branch tag_list
ssh_url_to_repo http_url_to_repo web_url
name name_with_namespace
path path_with_namespace
star_count forks_count
created_at last_activity_at
)
get api("/projects/#{project.id}/environments", user) get api("/projects/#{project.id}/environments", user)
......
...@@ -186,7 +186,14 @@ describe API::Projects do ...@@ -186,7 +186,14 @@ describe API::Projects do
context 'and with simple=true' do context 'and with simple=true' do
it 'returns a simplified version of all the projects' do it 'returns a simplified version of all the projects' do
expected_keys = %w(id http_url_to_repo web_url name name_with_namespace path path_with_namespace) expected_keys = %w(
id description default_branch tag_list
ssh_url_to_repo http_url_to_repo web_url
name name_with_namespace
path path_with_namespace
star_count forks_count
created_at last_activity_at
)
get api('/projects?simple=true', user) get api('/projects?simple=true', user)
...@@ -689,6 +696,7 @@ describe API::Projects do ...@@ -689,6 +696,7 @@ describe API::Projects do
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
expect(json_response['id']).to eq(public_project.id) expect(json_response['id']).to eq(public_project.id)
expect(json_response['description']).to eq(public_project.description) expect(json_response['description']).to eq(public_project.description)
expect(json_response['default_branch']).to eq(public_project.default_branch)
expect(json_response.keys).not_to include('permissions') expect(json_response.keys).not_to include('permissions')
end end
end end
......
...@@ -82,7 +82,14 @@ describe API::V3::Projects do ...@@ -82,7 +82,14 @@ describe API::V3::Projects do
context 'GET /projects?simple=true' do context 'GET /projects?simple=true' do
it 'returns a simplified version of all the projects' do it 'returns a simplified version of all the projects' do
expected_keys = %w(id http_url_to_repo web_url name name_with_namespace path path_with_namespace) expected_keys = %w(
id description default_branch tag_list
ssh_url_to_repo http_url_to_repo web_url
name name_with_namespace
path path_with_namespace
star_count forks_count
created_at last_activity_at
)
get v3_api('/projects?simple=true', user) get v3_api('/projects?simple=true', user)
...@@ -644,6 +651,7 @@ describe API::V3::Projects do ...@@ -644,6 +651,7 @@ describe API::V3::Projects do
expect(response).to have_http_status(200) expect(response).to have_http_status(200)
expect(json_response['id']).to eq(public_project.id) expect(json_response['id']).to eq(public_project.id)
expect(json_response['description']).to eq(public_project.description) expect(json_response['description']).to eq(public_project.description)
expect(json_response['default_branch']).to eq(public_project.default_branch)
expect(json_response.keys).not_to include('permissions') expect(json_response.keys).not_to include('permissions')
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