summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/views/users/index.api.rsb5
-rw-r--r--test/integration/api_test/users_test.rb19
2 files changed, 24 insertions, 0 deletions
diff --git a/app/views/users/index.api.rsb b/app/views/users/index.api.rsb
index 6ce38a58d..8dd376e25 100644
--- a/app/views/users/index.api.rsb
+++ b/app/views/users/index.api.rsb
@@ -15,6 +15,11 @@ api.array :users, api_meta(:total_count => @user_count, :offset => @offset, :lim
api.twofa_scheme user.twofa_scheme
api.status user.status
+ api.auth_source do
+ api.id user.auth_source.id
+ api.name user.auth_source.name
+ end if include_in_api_response?('auth_source') && user.auth_source.present?
+
render_api_custom_values user.visible_custom_field_values, api
end
end
diff --git a/test/integration/api_test/users_test.rb b/test/integration/api_test/users_test.rb
index 89d1f9f86..88f39bf20 100644
--- a/test/integration/api_test/users_test.rb
+++ b/test/integration/api_test/users_test.rb
@@ -128,6 +128,25 @@ class Redmine::ApiTest::UsersTest < Redmine::ApiTest::Base
assert_equal 0, json['users'].size
end
+ test "GET /users.json with include=auth_source" do
+ user = User.find(2)
+ user.update(:auth_source_id => 1)
+ get '/users.json?include=auth_source', :headers => credentials('admin')
+
+ json = ActiveSupport::JSON.decode(response.body)
+ assert json.key?('users')
+
+ json['users'].each do | user_json |
+ if user_json['id'] == user.id
+ assert_kind_of Hash, user_json['auth_source']
+ assert_equal user.auth_source.id, user_json['auth_source']['id']
+ assert_equal user.auth_source.name, user_json['auth_source']['name']
+ else
+ assert_nil user_json['auth_source']
+ end
+ end
+ end
+
test "GET /users.json with short filters" do
get '/users.json', headers: credentials('admin'), params: { status: "1|3" }
assert_response :success