From f35ac14cf5adba71be963828ff883d377b88969c Mon Sep 17 00:00:00 2001 From: Marius BALTEANU Date: Tue, 10 Mar 2020 23:28:00 +0200 Subject: [PATCH] Show default asignee and default version in projects API response --- app/views/projects/show.api.rsb | 2 ++ test/integration/api_test/projects_test.rb | 26 ++++++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/app/views/projects/show.api.rsb b/app/views/projects/show.api.rsb index 240b18883..7ad4ecc30 100644 --- a/app/views/projects/show.api.rsb +++ b/app/views/projects/show.api.rsb @@ -8,6 +8,8 @@ api.project do api.status @project.status api.is_public @project.is_public? api.inherit_members @project.inherit_members? + api.default_version(:id => @project.default_version.id, :name => @project.default_version.name) if @project.default_version + api.default_assignee(:id => @project.project.default_assigned_to.id, :name => @project.project.default_assigned_to.name) if @project.default_assigned_to render_api_custom_values @project.visible_custom_field_values, api render_api_includes(@project, api) diff --git a/test/integration/api_test/projects_test.rb b/test/integration/api_test/projects_test.rb index 39d7dccd5..4b00dd65a 100644 --- a/test/integration/api_test/projects_test.rb +++ b/test/integration/api_test/projects_test.rb @@ -108,6 +108,8 @@ class Redmine::ApiTest::ProjectsTest < Redmine::ApiTest::Base assert_kind_of Hash, json['project'] assert_equal 1, json['project']['id'] assert_equal false, json['project']['inherit_members'] + assert_equal false, json['project'].has_key?('default_version') + assert_equal false, json['project'].has_key?('default_assignee') end test "GET /projects/:id.xml with hidden custom fields should not display hidden custom fields" do @@ -152,6 +154,30 @@ class Redmine::ApiTest::ProjectsTest < Redmine::ApiTest::Base assert_select 'enabled_modules[type=array] enabled_module[name=issue_tracking]' end + def test_get_project_with_default_version_and_assignee + user = User.find(3) + version = Version.find(1) + Project.find(1).update!(default_assigned_to_id: user.id, default_version_id: version.id) + + get '/projects/1.json' + + json = ActiveSupport::JSON.decode(response.body) + assert_kind_of Hash, json + assert_kind_of Hash, json['project'] + assert_equal 1, json['project']['id'] + puts json.inspect + + assert json['project'].has_key?('default_assignee') + assert_equal 2, json['project']['default_assignee'].length + assert_equal user.id, json['project']['default_assignee']['id'] + assert_equal user.name, json['project']['default_assignee']['name'] + + assert json['project'].has_key?('default_version') + assert_equal 2, json['project']['default_version'].length + assert_equal version.id, json['project']['default_version']['id'] + assert_equal version.name, json['project']['default_version']['name'] + end + test "POST /projects.xml with valid parameters should create the project" do with_settings :default_projects_modules => ['issue_tracking', 'repository'] do assert_difference('Project.count') do -- 2.22.0