]> git.openstreetmap.org Git - rails.git/commitdiff
Merge remote-tracking branch 'openstreetmap/pull/1367'
authorTom Hughes <tom@compton.nu>
Sun, 18 Dec 2016 16:29:33 +0000 (16:29 +0000)
committerTom Hughes <tom@compton.nu>
Sun, 18 Dec 2016 16:29:33 +0000 (16:29 +0000)
1  2 
.rubocop_todo.yml
test/controllers/changeset_controller_test.rb
test/test_helper.rb

diff --combined .rubocop_todo.yml
index f1e93f25bfb4cca9988b86bdde67827752574757,b5834b8ce4ad2f968579b137f07bcfe8d23108e0..a7b456aec43f5031f88cfa8d28b508aaaeeb61f9
@@@ -64,7 -64,7 +64,7 @@@ Metrics/BlockNesting
  # Offense count: 62
  # Configuration parameters: CountComments.
  Metrics/ClassLength:
-   Max: 1659
 -  Max: 1653
++  Max: 1660
  
  # Offense count: 69
  Metrics/CyclomaticComplexity:
index efdf22e54f8b25ad7d2c5613098054dc342fdc26,9c77040fe564b9b1205e9793d795bfe6e69136d1..ca2ff8e159ee1339bd48d3b0a0a43e1cac86c24b
@@@ -3,6 -3,7 +3,6 @@@ require "changeset_controller
  
  class ChangesetControllerTest < ActionController::TestCase
    api_fixtures
 -  fixtures :changesets_subscribers
  
    ##
    # test all routes which lead to this controller
    end
  
    def test_changeset_download
+     tag = create(:old_node_tag, :old_node => nodes(:used_node_2))
      get :download, :id => changesets(:normal_user_first_change).id
      assert_response :success
      assert_template nil
      # print @response.body
      assert_select "osmChange[version='#{API_VERSION}'][generator='#{GENERATOR}']" do
        assert_select "create", :count => 5
        assert_select "create>node[id='#{nodes(:used_node_2).node_id}'][visible='#{nodes(:used_node_2).visible?}'][version='#{nodes(:used_node_2).version}']" do
-         assert_select "tag[k='#{node_tags(:t3).k}'][v='#{node_tags(:t3).v}']"
+         assert_select "tag[k='#{tag.k}'][v='#{tag.v}']"
        end
        assert_select "create>node[id='#{nodes(:visible_node).node_id}']"
      end
  
      ## Now try with the public user
      changeset = changesets(:public_user_first_change)
 +    create(:changeset_tag, :changeset => changeset)
      new_changeset = changeset.to_xml
      new_tag = XML::Node.new "tag"
      new_tag["k"] = "tagtesting"
      end
      assert_response :success
  
 +    changeset = changesets(:normal_user_subscribed_change)
 +    changeset.subscribers.push(users(:normal_user))
 +    changeset.subscribers.push(users(:public_user))
 +    changeset.subscribers.push(users(:suspended_user))
 +    changeset.subscribers.push(users(:deleted_user))
 +
      assert_difference "ChangesetComment.count", 1 do
        assert_difference "ActionMailer::Base.deliveries.size", 1 do
 -        post :comment, :id => changesets(:normal_user_subscribed_change).id, :text => "This is a comment"
 +        post :comment, :id => changeset.id, :text => "This is a comment"
        end
      end
      assert_response :success
  
      assert_difference "ChangesetComment.count", 1 do
        assert_difference "ActionMailer::Base.deliveries.size", 2 do
 -        post :comment, :id => changesets(:normal_user_subscribed_change).id, :text => "This is a comment"
 +        post :comment, :id => changeset.id, :text => "This is a comment"
        end
      end
      assert_response :success
  
      # trying to subscribe when already subscribed
      changeset = changesets(:normal_user_subscribed_change)
 +    changeset.subscribers.push(users(:public_user))
      assert_no_difference "changeset.subscribers.count" do
        post :subscribe, :id => changeset.id
      end
    def test_unsubscribe_success
      basic_authorization(users(:public_user).email, "test")
      changeset = changesets(:normal_user_subscribed_change)
 +    changeset.subscribers.push(users(:public_user))
  
      assert_difference "changeset.subscribers.count", -1 do
        post :unsubscribe, :id => changeset.id
diff --combined test/test_helper.rb
index 3eafdd55cbbf62f040b65e21c17f79e379c0070b,e3d1d7a864b4b05c04c0601e69535a6f48a44bb4..9633989cda4d109278d828b049688545b832159b
@@@ -4,7 -4,6 +4,7 @@@ Coveralls.wear!("rails"
  ENV["RAILS_ENV"] = "test"
  require File.expand_path("../../config/environment", __FILE__)
  require "rails/test_help"
 +require "webmock/minitest"
  load "composite_primary_keys/fixtures.rb"
  
  module ActiveSupport
      def self.api_fixtures
        # print "setting up the api_fixtures"
        fixtures :users, :user_roles
 -      fixtures :changesets, :changeset_tags
 +      fixtures :changesets
  
        fixtures :current_nodes, :nodes
        set_fixture_class :current_nodes => Node
        set_fixture_class :nodes => OldNode
  
-       fixtures :current_node_tags, :node_tags
-       set_fixture_class :current_node_tags => NodeTag
-       set_fixture_class :node_tags => OldNodeTag
        fixtures :current_ways
        set_fixture_class :current_ways => Way
  
-       fixtures :current_way_nodes, :current_way_tags
+       fixtures :current_way_nodes
        set_fixture_class :current_way_nodes => WayNode
-       set_fixture_class :current_way_tags => WayTag
  
        fixtures :ways
        set_fixture_class :ways => OldWay
  
-       fixtures :way_nodes, :way_tags
+       fixtures :way_nodes
        set_fixture_class :way_nodes => OldWayNode
-       set_fixture_class :way_tags => OldWayTag
  
        fixtures :current_relations
        set_fixture_class :current_relations => Relation
  
-       fixtures :current_relation_members, :current_relation_tags
+       fixtures :current_relation_members
        set_fixture_class :current_relation_members => RelationMember
-       set_fixture_class :current_relation_tags => RelationTag
  
        fixtures :relations
        set_fixture_class :relations => OldRelation
  
-       fixtures :relation_members, :relation_tags
+       fixtures :relation_members
        set_fixture_class :relation_members => OldRelationMember
-       set_fixture_class :relation_tags => OldRelationTag
  
        fixtures :gpx_files, :gps_points, :gpx_file_tags
        set_fixture_class :gpx_files => Trace
        end
      end
  
 +    ##
 +    # work round minitest insanity that causes it to tell you
 +    # to use assert_nil to test for nil, which is fine if you're
 +    # comparing to a nil constant but not if you're comparing
 +    # an expression that might be nil sometimes
 +    def assert_equal_allowing_nil(exp, act, msg = nil)
 +      if exp.nil?
 +        assert_nil act, msg
 +      else
 +        assert_equal exp, act, msg
 +      end
 +    end
 +
      ##
      # for some reason assert_equal a, b fails when the relations are
      # actually equal, so this method manually checks the fields...
      ##
      # execute a block with a given set of HTTP responses stubbed
      def with_http_stubs(stubs_file)
 -      http_client_save = OSM.http_client
 +      stubs = YAML.load_file(File.expand_path("../http/#{stubs_file}.yml", __FILE__))
 +      stubs.each do |url, response|
 +        stub_request(:get, Regexp.new(Regexp.quote(url))).to_return(:status => response["code"], :body => response["body"])
 +      end
  
 -      begin
 -        stubs = YAML.load_file(File.expand_path("../http/#{stubs_file}.yml", __FILE__))
 +      yield
 +    end
  
 -        OSM.http_client = Faraday.new do |builder|
 -          builder.adapter :test do |stub|
 -            stubs.each do |url, response|
 -              stub.get(url) { |_env| [response["code"], {}, response["body"]] }
 -            end
 -          end
 -        end
 +    def stub_gravatar_request(email, status = 200, body = nil)
 +      hash = Digest::MD5.hexdigest(email.downcase)
 +      url = "https://www.gravatar.com/avatar/#{hash}?d=404"
 +      stub_request(:get, url).and_return(:status => status, :body => body)
 +    end
  
 -        yield
 -      ensure
 -        OSM.http_client = http_client_save
 -      end
 +    def stub_hostip_requests
 +      # Controller tests and integration tests use different IPs
 +      stub_request(:get, "http://api.hostip.info/country.php?ip=0.0.0.0")
 +      stub_request(:get, "http://api.hostip.info/country.php?ip=127.0.0.1")
      end
    end
  end