Merge remote-tracking branch 'upstream/pull/2839'

This commit is contained in:
Tom Hughes 2020-09-30 11:54:30 +01:00
commit ddac660f3b
8 changed files with 125 additions and 8 deletions

View file

@ -9,9 +9,15 @@ module Api
around_action :api_call_handle_error
before_action :lookup_user_by_id, :only => [:show]
before_action :set_request_formats, :except => [:gpx_files]
def show
if @user.visible?
render :content_type => "text/xml"
# Render the result
respond_to do |format|
format.xml
format.json
end
else
head :gone
end
@ -19,7 +25,11 @@ module Api
def details
@user = current_user
render :action => :show, :content_type => "text/xml"
# Render the result
respond_to do |format|
format.xml { render :show }
format.json { render :show }
end
end
def index
@ -31,7 +41,11 @@ module Api
@users = User.visible.find(ids)
render :content_type => "text/xml"
# Render the result
respond_to do |format|
format.xml
format.json
end
end
def gpx_files

View file

@ -0,0 +1,69 @@
json.user do
json.id user.id
json.display_name user.display_name
json.account_created user.creation_time.xmlschema
json.description user.description if user.description
if current_user && current_user == user
json.contributor_terms do
json.agreed user.terms_agreed.present?
json.pd user.consider_pd
end
else
json.contributor_terms do
json.agreed user.terms_agreed.present?
end
end
json.img do
json.href user_image_url(user) if user.avatar.attached? || user.image_use_gravatar
end
json.roles do
json.array! user.roles.map(&:role)
end
json.changesets do
json.count user.changesets.size
end
json.traces do
json.count user.traces.size
end
json.blocks do
json.received do
json.count user.blocks.size
json.active user.blocks.active.size
end
if user.moderator?
json.issued do
json.count user.blocks_created.size
json.active user.blocks_created.active.size
end
end
end
if current_user && current_user == user
if user.home_lat && user.home_lon
json.home do
json.lat user.home_lat
json.lon user.home_lon
json.zoom user.home_zoom
end
end
json.languages user.languages if user.languages?
json.messages do
json.received do
json.count user.messages.size
json.unread user.new_messages.size
end
json.sent do
json.count user.sent_messages.size
end
end
end
end

View file

@ -0,0 +1,3 @@
json.users(@users) do |user|
json.partial! user
end

View file

@ -0,0 +1 @@
json.partial! @user

View file

@ -9,10 +9,18 @@ module Api
{ :path => "/api/0.6/user/1", :method => :get },
{ :controller => "api/users", :action => "show", :id => "1" }
)
assert_routing(
{ :path => "/api/0.6/user/1.json", :method => :get },
{ :controller => "api/users", :action => "show", :id => "1", :format => "json" }
)
assert_routing(
{ :path => "/api/0.6/user/details", :method => :get },
{ :controller => "api/users", :action => "details" }
)
assert_routing(
{ :path => "/api/0.6/user/details.json", :method => :get },
{ :controller => "api/users", :action => "details", :format => "json" }
)
assert_routing(
{ :path => "/api/0.6/user/gpx_files", :method => :get },
{ :controller => "api/users", :action => "gpx_files" }
@ -21,6 +29,10 @@ module Api
{ :path => "/api/0.6/users", :method => :get },
{ :controller => "api/users", :action => "index" }
)
assert_routing(
{ :path => "/api/0.6/users.json", :method => :get },
{ :controller => "api/users", :action => "index", :format => "json" }
)
end
def test_show
@ -28,7 +40,7 @@ module Api
# check that a visible user is returned properly
get api_user_path(:id => user.id)
assert_response :success
assert_equal "text/xml", response.media_type
assert_equal "application/xml", response.media_type
# check the data that is returned
assert_select "description", :count => 1, :text => "test"
@ -69,6 +81,15 @@ module Api
# check that a non-existent user is not returned
get api_user_path(:id => 0)
assert_response :not_found
# check that a visible user is returned properly in json
get api_user_path(:id => user.id, :format => "json")
assert_response :success
assert_equal "application/json", response.media_type
js = ActiveSupport::JSON.decode(@response.body)
assert_not_nil js
assert_equal user.id, js["user"]["id"]
end
def test_details
@ -84,7 +105,7 @@ module Api
auth_header = basic_authorization_header user.email, "test"
get user_details_path, :headers => auth_header
assert_response :success
assert_equal "text/xml", response.media_type
assert_equal "application/xml", response.media_type
# check the data that is returned
assert_select "description", :count => 1, :text => "test"
@ -130,16 +151,25 @@ module Api
get api_users_path(:users => user1.id)
assert_response :success
assert_equal "text/xml", response.media_type
assert_equal "application/xml", response.media_type
assert_select "user", :count => 1 do
assert_select "user[id='#{user1.id}']", :count => 1
assert_select "user[id='#{user2.id}']", :count => 0
assert_select "user[id='#{user3.id}']", :count => 0
end
# Test json
get api_users_path(:users => user1.id, :format => "json")
assert_response :success
assert_equal "application/json", response.media_type
js = ActiveSupport::JSON.decode(@response.body)
assert_not_nil js
assert_equal 1, js["users"].count
get api_users_path(:users => user2.id)
assert_response :success
assert_equal "text/xml", response.media_type
assert_equal "application/xml", response.media_type
assert_select "user", :count => 1 do
assert_select "user[id='#{user1.id}']", :count => 0
assert_select "user[id='#{user2.id}']", :count => 1
@ -148,7 +178,7 @@ module Api
get api_users_path(:users => "#{user1.id},#{user3.id}")
assert_response :success
assert_equal "text/xml", response.media_type
assert_equal "application/xml", response.media_type
assert_select "user", :count => 2 do
assert_select "user[id='#{user1.id}']", :count => 1
assert_select "user[id='#{user2.id}']", :count => 0