Fix `Performance/MapMethodChain` cop (#27744)
This commit is contained in:
		
							parent
							
								
									bbad5b6456
								
							
						
					
					
						commit
						45770c9306
					
				| 
						 | 
				
			
			@ -50,13 +50,6 @@ Metrics/CyclomaticComplexity:
 | 
			
		|||
Metrics/PerceivedComplexity:
 | 
			
		||||
  Max: 27
 | 
			
		||||
 | 
			
		||||
Performance/MapMethodChain:
 | 
			
		||||
  Exclude:
 | 
			
		||||
    - 'app/models/feed.rb'
 | 
			
		||||
    - 'lib/mastodon/cli/maintenance.rb'
 | 
			
		||||
    - 'spec/services/bulk_import_service_spec.rb'
 | 
			
		||||
    - 'spec/services/import_service_spec.rb'
 | 
			
		||||
 | 
			
		||||
RSpec/AnyInstance:
 | 
			
		||||
  Exclude:
 | 
			
		||||
    - 'spec/controllers/activitypub/inboxes_controller_spec.rb'
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -23,9 +23,9 @@ class Feed
 | 
			
		|||
    max_id = '+inf' if max_id.blank?
 | 
			
		||||
    if min_id.blank?
 | 
			
		||||
      since_id   = '-inf' if since_id.blank?
 | 
			
		||||
      unhydrated = redis.zrevrangebyscore(key, "(#{max_id}", "(#{since_id}", limit: [0, limit], with_scores: true).map(&:first).map(&:to_i)
 | 
			
		||||
      unhydrated = redis.zrevrangebyscore(key, "(#{max_id}", "(#{since_id}", limit: [0, limit], with_scores: true).map { |id| id.first.to_i }
 | 
			
		||||
    else
 | 
			
		||||
      unhydrated = redis.zrangebyscore(key, "(#{min_id}", "(#{max_id}", limit: [0, limit], with_scores: true).map(&:first).map(&:to_i)
 | 
			
		||||
      unhydrated = redis.zrangebyscore(key, "(#{min_id}", "(#{max_id}", limit: [0, limit], with_scores: true).map { |id| id.first.to_i }
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    Status.where(id: unhydrated).cache_ids
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -224,7 +224,7 @@ module Mastodon::CLI
 | 
			
		|||
        users = User.where(id: row['ids'].split(',')).sort_by(&:updated_at).reverse
 | 
			
		||||
        ref_user = users.shift
 | 
			
		||||
        say "Multiple users registered with e-mail address #{ref_user.email}.", :yellow
 | 
			
		||||
        say "e-mail will be disabled for the following accounts: #{user.map(&:account).map(&:acct).join(', ')}", :yellow
 | 
			
		||||
        say "e-mail will be disabled for the following accounts: #{user.map { |user| user.account.acct }.join(', ')}", :yellow
 | 
			
		||||
        say 'Please reach out to them and set another address with `tootctl account modify` or delete them.', :yellow
 | 
			
		||||
 | 
			
		||||
        users.each_with_index do |user, index|
 | 
			
		||||
| 
						 | 
				
			
			@ -253,7 +253,7 @@ module Mastodon::CLI
 | 
			
		|||
    def deduplicate_users_process_confirmation_token
 | 
			
		||||
      ActiveRecord::Base.connection.select_all("SELECT string_agg(id::text, ',') AS ids FROM users WHERE confirmation_token IS NOT NULL GROUP BY confirmation_token HAVING count(*) > 1").each do |row|
 | 
			
		||||
        users = User.where(id: row['ids'].split(',')).sort_by(&:created_at).reverse.drop(1)
 | 
			
		||||
        say "Unsetting confirmation token for those accounts: #{users.map(&:account).map(&:acct).join(', ')}", :yellow
 | 
			
		||||
        say "Unsetting confirmation token for those accounts: #{users.map { |user| user.account.acct }.join(', ')}", :yellow
 | 
			
		||||
 | 
			
		||||
        users.each do |user|
 | 
			
		||||
          user.update!(confirmation_token: nil)
 | 
			
		||||
| 
						 | 
				
			
			@ -265,7 +265,7 @@ module Mastodon::CLI
 | 
			
		|||
      if ActiveRecord::Migrator.current_version < 2022_01_18_183010
 | 
			
		||||
        ActiveRecord::Base.connection.select_all("SELECT string_agg(id::text, ',') AS ids FROM users WHERE remember_token IS NOT NULL GROUP BY remember_token HAVING count(*) > 1").each do |row|
 | 
			
		||||
          users = User.where(id: row['ids'].split(',')).sort_by(&:updated_at).reverse.drop(1)
 | 
			
		||||
          say "Unsetting remember token for those accounts: #{users.map(&:account).map(&:acct).join(', ')}", :yellow
 | 
			
		||||
          say "Unsetting remember token for those accounts: #{users.map { |user| user.account.acct }.join(', ')}", :yellow
 | 
			
		||||
 | 
			
		||||
          users.each do |user|
 | 
			
		||||
            user.update!(remember_token: nil)
 | 
			
		||||
| 
						 | 
				
			
			@ -277,7 +277,7 @@ module Mastodon::CLI
 | 
			
		|||
    def deduplicate_users_process_password_token
 | 
			
		||||
      ActiveRecord::Base.connection.select_all("SELECT string_agg(id::text, ',') AS ids FROM users WHERE reset_password_token IS NOT NULL GROUP BY reset_password_token HAVING count(*) > 1").each do |row|
 | 
			
		||||
        users = User.where(id: row['ids'].split(',')).sort_by(&:updated_at).reverse.drop(1)
 | 
			
		||||
        say "Unsetting password reset token for those accounts: #{users.map(&:account).map(&:acct).join(', ')}", :yellow
 | 
			
		||||
        say "Unsetting password reset token for those accounts: #{users.map { |user| user.account.acct }.join(', ')}", :yellow
 | 
			
		||||
 | 
			
		||||
        users.each do |user|
 | 
			
		||||
          user.update!(reset_password_token: nil)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -54,7 +54,7 @@ RSpec.describe BulkImportService do
 | 
			
		|||
 | 
			
		||||
        Import::RowWorker.drain
 | 
			
		||||
 | 
			
		||||
        expect(FollowRequest.includes(:target_account).where(account: account).map(&:target_account).map(&:acct)).to contain_exactly('user@foo.bar', 'unknown@unknown.bar')
 | 
			
		||||
        expect(FollowRequest.includes(:target_account).where(account: account).map { |follow_request| follow_request.target_account.acct }).to contain_exactly('user@foo.bar', 'unknown@unknown.bar')
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -102,7 +102,7 @@ RSpec.describe BulkImportService do
 | 
			
		|||
 | 
			
		||||
        Import::RowWorker.drain
 | 
			
		||||
 | 
			
		||||
        expect(FollowRequest.includes(:target_account).where(account: account).map(&:target_account).map(&:acct)).to contain_exactly('user@foo.bar', 'unknown@unknown.bar')
 | 
			
		||||
        expect(FollowRequest.includes(:target_account).where(account: account).map { |follow_request| follow_request.target_account.acct }).to contain_exactly('user@foo.bar', 'unknown@unknown.bar')
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -367,7 +367,7 @@ RSpec.describe BulkImportService do
 | 
			
		|||
 | 
			
		||||
        Import::RowWorker.drain
 | 
			
		||||
 | 
			
		||||
        expect(account.bookmarks.map(&:status).map(&:uri)).to contain_exactly(already_bookmarked.uri, status.uri, bookmarked.uri, 'https://domain.unknown/foo')
 | 
			
		||||
        expect(account.bookmarks.map { |bookmark| bookmark.status.uri }).to contain_exactly(already_bookmarked.uri, status.uri, bookmarked.uri, 'https://domain.unknown/foo')
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -410,7 +410,7 @@ RSpec.describe BulkImportService do
 | 
			
		|||
 | 
			
		||||
        Import::RowWorker.drain
 | 
			
		||||
 | 
			
		||||
        expect(account.bookmarks.map(&:status).map(&:uri)).to contain_exactly(status.uri, bookmarked.uri, 'https://domain.unknown/foo')
 | 
			
		||||
        expect(account.bookmarks.map { |bookmark| bookmark.status.uri }).to contain_exactly(status.uri, bookmarked.uri, 'https://domain.unknown/foo')
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -232,9 +232,9 @@ RSpec.describe ImportService, type: :service do
 | 
			
		|||
      it 'adds the toots the user has access to to bookmarks' do
 | 
			
		||||
        local_status = Fabricate(:status, account: local_account, uri: 'https://local.com/users/foo/statuses/42', id: 42, local: true)
 | 
			
		||||
        subject.call(import)
 | 
			
		||||
        expect(account.bookmarks.map(&:status).map(&:id)).to include(local_status.id)
 | 
			
		||||
        expect(account.bookmarks.map(&:status).map(&:id)).to include(remote_status.id)
 | 
			
		||||
        expect(account.bookmarks.map(&:status).map(&:id)).to_not include(direct_status.id)
 | 
			
		||||
        expect(account.bookmarks.map { |bookmark| bookmark.status.id }).to include(local_status.id)
 | 
			
		||||
        expect(account.bookmarks.map { |bookmark| bookmark.status.id }).to include(remote_status.id)
 | 
			
		||||
        expect(account.bookmarks.map { |bookmark| bookmark.status.id }).to_not include(direct_status.id)
 | 
			
		||||
        expect(account.bookmarks.count).to eq 3
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue