From 63cb3680c14b8582bc587917cac6d3ede604e412 Mon Sep 17 00:00:00 2001 From: Jean-Baptiste Barth Date: Sat, 6 Sep 2014 03:17:51 +0000 Subject: [PATCH] Include enabled modules in projects API (#17602). Contributed by Jan Schulz-Hofen git-svn-id: http://svn.redmine.org/redmine/trunk@13363 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- app/helpers/projects_helper.rb | 21 ++++++++ app/views/projects/index.api.rsb | 1 + app/views/projects/show.api.rsb | 13 +---- test/integration/api_test/projects_test.rb | 62 ++++++++++++++++++++++ 4 files changed, 85 insertions(+), 12 deletions(-) diff --git a/app/helpers/projects_helper.rb b/app/helpers/projects_helper.rb index 8337d43ab..8e23ccdda 100644 --- a/app/helpers/projects_helper.rb +++ b/app/helpers/projects_helper.rb @@ -91,4 +91,25 @@ module ProjectsHelper sharing = 'none' unless Version::VERSION_SHARINGS.include?(sharing) l("label_version_sharing_#{sharing}") end + + def render_api_includes(project, api) + api.array :trackers do + project.trackers.each do |tracker| + api.tracker(:id => tracker.id, :name => tracker.name) + end + end if include_in_api_response?('trackers') + + api.array :issue_categories do + project.issue_categories.each do |category| + api.issue_category(:id => category.id, :name => category.name) + end + end if include_in_api_response?('issue_categories') + + api.array :enabled_modules do + project.enabled_modules.each do |enabled_module| + api.enabled_module(:id => enabled_module.id, :name => enabled_module.name) + end + end if include_in_api_response?('enabled_modules') + + end end diff --git a/app/views/projects/index.api.rsb b/app/views/projects/index.api.rsb index a07db1b71..d309af241 100644 --- a/app/views/projects/index.api.rsb +++ b/app/views/projects/index.api.rsb @@ -10,6 +10,7 @@ api.array :projects, api_meta(:total_count => @project_count, :offset => @offset api.is_public project.is_public? render_api_custom_values project.visible_custom_field_values, api + render_api_includes(project, api) api.created_on project.created_on api.updated_on project.updated_on diff --git a/app/views/projects/show.api.rsb b/app/views/projects/show.api.rsb index 7a1e07c02..6e1958a34 100644 --- a/app/views/projects/show.api.rsb +++ b/app/views/projects/show.api.rsb @@ -9,19 +9,8 @@ api.project do api.is_public @project.is_public? render_api_custom_values @project.visible_custom_field_values, api + render_api_includes(@project, api) api.created_on @project.created_on api.updated_on @project.updated_on - - api.array :trackers do - @project.trackers.each do |tracker| - api.tracker(:id => tracker.id, :name => tracker.name) - end - end if include_in_api_response?('trackers') - - api.array :issue_categories do - @project.issue_categories.each do |category| - api.issue_category(:id => category.id, :name => category.name) - end - end if include_in_api_response?('issue_categories') end diff --git a/test/integration/api_test/projects_test.rb b/test/integration/api_test/projects_test.rb index efb41f03b..28b8b9452 100644 --- a/test/integration/api_test/projects_test.rb +++ b/test/integration/api_test/projects_test.rb @@ -66,6 +66,53 @@ class Redmine::ApiTest::ProjectsTest < Redmine::ApiTest::Base assert json['projects'].first.has_key?('id') end + test "GET /projects.xml with include=issue_categories should return categories" do + get '/projects.xml?include=issue_categories' + assert_response :success + assert_equal 'application/xml', @response.content_type + + assert_tag 'issue_categories', + :attributes => {:type => 'array'}, + :child => { + :tag => 'issue_category', + :attributes => { + :id => '2', + :name => 'Recipes' + } + } + end + + test "GET /projects.xml with include=trackers should return trackers" do + get '/projects.xml?include=trackers' + assert_response :success + assert_equal 'application/xml', @response.content_type + + assert_tag 'trackers', + :attributes => {:type => 'array'}, + :child => { + :tag => 'tracker', + :attributes => { + :id => '2', + :name => 'Feature request' + } + } + end + + test "GET /projects.xml with include=enabled_modules should return enabled modules" do + get '/projects.xml?include=enabled_modules' + assert_response :success + assert_equal 'application/xml', @response.content_type + + assert_tag 'enabled_modules', + :attributes => {:type => 'array'}, + :child => { + :tag => 'enabled_module', + :attributes => { + :name => 'issue_tracking' + } + } + end + test "GET /projects/:id.xml should return the project" do get '/projects/1.xml' assert_response :success @@ -132,6 +179,21 @@ class Redmine::ApiTest::ProjectsTest < Redmine::ApiTest::Base } end + test "GET /projects/:id.xml with include=enabled_modules should return enabled modules" do + get '/projects/1.xml?include=enabled_modules' + assert_response :success + assert_equal 'application/xml', @response.content_type + + assert_tag 'enabled_modules', + :attributes => {:type => 'array'}, + :child => { + :tag => 'enabled_module', + :attributes => { + :name => 'issue_tracking' + } + } + end + test "POST /projects.xml with valid parameters should create the project" do Setting.default_projects_modules = ['issue_tracking', 'repository'] -- 2.39.5