authorize_resource
before_action :check_database_writable
- before_action :lookup_friend
+ before_action :lookup_user
def show
- @already_follows = current_user.follows?(@friend)
+ @already_follows = current_user.follows?(@user)
end
def create
follow = Follow.new
follow.follower = current_user
- follow.following = @friend
- if current_user.follows?(@friend)
- flash[:warning] = t ".already_followed", :name => @friend.display_name
+ follow.following = @user
+ if current_user.follows?(@user)
+ flash[:warning] = t ".already_followed", :name => @user.display_name
elsif current_user.follows.where(:created_at => Time.now.utc - 1.hour..).count >= current_user.max_follows_per_hour
flash[:error] = t ".limit_exceeded"
elsif follow.save
- flash[:notice] = t ".success", :name => @friend.display_name
+ flash[:notice] = t ".success", :name => @user.display_name
UserMailer.follow_notification(follow).deliver_later
else
- follow.add_error(t(".failed", :name => @friend.display_name))
+ follow.add_error(t(".failed", :name => @user.display_name))
end
referer = safe_referer(params[:referer]) if params[:referer]
end
def destroy
- if current_user.follows?(@friend)
- Follow.where(:follower => current_user, :following => @friend).delete_all
- flash[:notice] = t ".success", :name => @friend.display_name
+ if current_user.follows?(@user)
+ Follow.where(:follower => current_user, :following => @user).delete_all
+ flash[:notice] = t ".success", :name => @user.display_name
else
- flash[:error] = t ".not_followed", :name => @friend.display_name
+ flash[:error] = t ".not_followed", :name => @user.display_name
end
referer = safe_referer(params[:referer]) if params[:referer]
redirect_to referer || user_path
end
-
- private
-
- ##
- # ensure that there is a "friend" instance variable
- def lookup_friend
- @friend = User.active.find_by!(:display_name => params[:display_name])
- rescue ActiveRecord::RecordNotFound
- render_unknown_user params[:display_name]
- end
end
maxlon = point.longitude + 0.001
maxlat = point.latitude + 0.001
bbox = "#{minlon},#{minlat},#{maxlon},#{maxlat}"
- get trackpoints_path(:bbox => bbox)
+ get api_tracepoints_path(:bbox => bbox)
assert_response :success
assert_select "gpx[version='1.0'][creator='OpenStreetMap.org']", :count => 1 do
assert_select "trk" do
maxlon = point.longitude + 0.002
maxlat = point.latitude + 0.002
bbox = "#{minlon},#{minlat},#{maxlon},#{maxlat}"
- get trackpoints_path(:bbox => bbox)
+ get api_tracepoints_path(:bbox => bbox)
assert_response :success
assert_select "gpx[version='1.0'][creator='OpenStreetMap.org']", :count => 1 do
assert_select "trk", :count => 1 do
maxlon = point.longitude + 0.002
maxlat = point.latitude + 0.002
bbox = "#{minlon},#{minlat},#{maxlon},#{maxlat}"
- get trackpoints_path(:bbox => bbox)
+ get api_tracepoints_path(:bbox => bbox)
assert_response :success
assert_select "gpx[version='1.0'][creator='OpenStreetMap.org']", :count => 1 do
assert_select "trk", :count => 1 do
end
def test_index_without_bbox
- get trackpoints_path
+ get api_tracepoints_path
assert_response :bad_request
assert_equal "The parameter bbox is required", @response.body, "A bbox param was expected"
end
def test_traces_page_less_than_zero
-10.upto(-1) do |i|
- get trackpoints_path(:page => i, :bbox => "-0.1,-0.1,0.1,0.1")
+ get api_tracepoints_path(:page => i, :bbox => "-0.1,-0.1,0.1,0.1")
assert_response :bad_request
assert_equal "Page number must be greater than or equal to 0", @response.body, "The page number was #{i}"
end
0.upto(10) do |i|
- get trackpoints_path(:page => i, :bbox => "-0.1,-0.1,0.1,0.1")
+ get api_tracepoints_path(:page => i, :bbox => "-0.1,-0.1,0.1,0.1")
assert_response :success, "The page number was #{i} and should have been accepted"
end
end
def test_bbox_too_big
@badbigbbox.each do |bbox|
- get trackpoints_path(:bbox => bbox)
+ get api_tracepoints_path(:bbox => bbox)
assert_response :bad_request, "The bbox:#{bbox} was expected to be too big"
assert_equal "The maximum bbox size is #{Settings.max_request_area}, and your request was too large. Either request a smaller area, or use planet.osm", @response.body, "bbox: #{bbox}"
end
def test_bbox_malformed
@badmalformedbbox.each do |bbox|
- get trackpoints_path(:bbox => bbox)
+ get api_tracepoints_path(:bbox => bbox)
assert_response :bad_request, "The bbox:#{bbox} was expected to be malformed"
assert_equal "The parameter bbox must be of the form min_lon,min_lat,max_lon,max_lat", @response.body, "bbox: #{bbox}"
end
def test_bbox_lon_mixedup
@badlonmixedbbox.each do |bbox|
- get trackpoints_path(:bbox => bbox)
+ get api_tracepoints_path(:bbox => bbox)
assert_response :bad_request, "The bbox:#{bbox} was expected to have the longitude mixed up"
assert_equal "The minimum longitude must be less than the maximum longitude, but it wasn't", @response.body, "bbox: #{bbox}"
end
def test_bbox_lat_mixedup
@badlatmixedbbox.each do |bbox|
- get trackpoints_path(:bbox => bbox)
+ get api_tracepoints_path(:bbox => bbox)
assert_response :bad_request, "The bbox:#{bbox} was expected to have the latitude mixed up"
assert_equal "The minimum latitude must be less than the maximum latitude, but it wasn't", @response.body, "bbox: #{bbox}"
end
def test_lat_lon_xml_format
create(:tracepoint, :latitude => (0.00004 * GeoRecord::SCALE).to_i, :longitude => (0.00008 * GeoRecord::SCALE).to_i)
- get trackpoints_path(:bbox => "0,0,0.1,0.1")
+ get api_tracepoints_path(:bbox => "0,0,0.1,0.1")
assert_match(/lat="0.0000400"/, response.body)
assert_match(/lon="0.0000800"/, response.body)
end