mirror of
				https://github.com/mastodon/mastodon.git
				synced 2025-10-26 10:41:27 +00:00 
			
		
		
		
	Fix notifications from limited users being outright dropped (#30559)
	
		
			
	
		
	
	
		
	
		
			Some checks are pending
		
		
	
	
		
			
				
	
				Bundler Audit / security (push) Waiting to run
				
			
		
			
				
	
				Check i18n / check-i18n (push) Waiting to run
				
			
		
			
				
	
				CodeQL / Analyze (javascript) (push) Waiting to run
				
			
		
			
				
	
				CodeQL / Analyze (ruby) (push) Waiting to run
				
			
		
			
				
	
				Check formatting / lint (push) Waiting to run
				
			
		
			
				
	
				CSS Linting / lint (push) Waiting to run
				
			
		
			
				
	
				Haml Linting / lint (push) Waiting to run
				
			
		
			
				
	
				JavaScript Linting / lint (push) Waiting to run
				
			
		
			
				
	
				Ruby Linting / lint (push) Waiting to run
				
			
		
			
				
	
				JavaScript Testing / test (push) Waiting to run
				
			
		
			
				
	
				Historical data migration test / pre_job (push) Waiting to run
				
			
		
			
				
	
				Historical data migration test / test (14-alpine) (push) Blocked by required conditions
				
			
		
			
				
	
				Historical data migration test / test (15-alpine) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / build (production) (push) Waiting to run
				
			
		
			
				
	
				Ruby Testing / build (test) (push) Waiting to run
				
			
		
			
				
	
				Ruby Testing / test (.ruby-version) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / test (3.1) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / test (3.2) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / Libvips tests (.ruby-version) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / Libvips tests (3.1) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / Libvips tests (3.2) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / End to End testing (.ruby-version) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / End to End testing (3.1) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / End to End testing (3.2) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:8.10.2) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / Elastic Search integration testing (.ruby-version, opensearchproject/opensearch:2) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / Elastic Search integration testing (3.1, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			
		
			
				
	
				Ruby Testing / Elastic Search integration testing (3.2, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			
		
		
	
	
				
					
				
			
		
			Some checks are pending
		
		
	
	Bundler Audit / security (push) Waiting to run
				
			Check i18n / check-i18n (push) Waiting to run
				
			CodeQL / Analyze (javascript) (push) Waiting to run
				
			CodeQL / Analyze (ruby) (push) Waiting to run
				
			Check formatting / lint (push) Waiting to run
				
			CSS Linting / lint (push) Waiting to run
				
			Haml Linting / lint (push) Waiting to run
				
			JavaScript Linting / lint (push) Waiting to run
				
			Ruby Linting / lint (push) Waiting to run
				
			JavaScript Testing / test (push) Waiting to run
				
			Historical data migration test / pre_job (push) Waiting to run
				
			Historical data migration test / test (14-alpine) (push) Blocked by required conditions
				
			Historical data migration test / test (15-alpine) (push) Blocked by required conditions
				
			Ruby Testing / build (production) (push) Waiting to run
				
			Ruby Testing / build (test) (push) Waiting to run
				
			Ruby Testing / test (.ruby-version) (push) Blocked by required conditions
				
			Ruby Testing / test (3.1) (push) Blocked by required conditions
				
			Ruby Testing / test (3.2) (push) Blocked by required conditions
				
			Ruby Testing / Libvips tests (.ruby-version) (push) Blocked by required conditions
				
			Ruby Testing / Libvips tests (3.1) (push) Blocked by required conditions
				
			Ruby Testing / Libvips tests (3.2) (push) Blocked by required conditions
				
			Ruby Testing / End to End testing (.ruby-version) (push) Blocked by required conditions
				
			Ruby Testing / End to End testing (3.1) (push) Blocked by required conditions
				
			Ruby Testing / End to End testing (3.2) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:8.10.2) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (.ruby-version, opensearchproject/opensearch:2) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (3.1, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (3.2, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			This commit is contained in:
		
							parent
							
								
									a5a1584675
								
							
						
					
					
						commit
						bf56e982a9
					
				|  | @ -420,10 +420,7 @@ class FeedManager | ||||||
|     check_for_blocks = status.active_mentions.pluck(:account_id) |     check_for_blocks = status.active_mentions.pluck(:account_id) | ||||||
|     check_for_blocks.push(status.in_reply_to_account) if status.reply? && !status.in_reply_to_account_id.nil? |     check_for_blocks.push(status.in_reply_to_account) if status.reply? && !status.in_reply_to_account_id.nil? | ||||||
| 
 | 
 | ||||||
|     should_filter   = blocks_or_mutes?(receiver_id, check_for_blocks, :mentions) # Filter if it's from someone I blocked, in reply to someone I blocked, or mentioning someone I blocked (or muted) |     blocks_or_mutes?(receiver_id, check_for_blocks, :mentions) # Filter if it's from someone I blocked, in reply to someone I blocked, or mentioning someone I blocked (or muted) | ||||||
|     should_filter ||= status.account.silenced? && !Follow.exists?(account_id: receiver_id, target_account_id: status.account_id) # Filter if the account is silenced and I'm not following them |  | ||||||
| 
 |  | ||||||
|     should_filter |  | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   # Check if status should not be added to the list feed |   # Check if status should not be added to the list feed | ||||||
|  |  | ||||||
|  | @ -206,13 +206,13 @@ RSpec.describe FeedManager do | ||||||
|         expect(described_class.instance.filter?(:mentions, reply, bob)).to be true |         expect(described_class.instance.filter?(:mentions, reply, bob)).to be true | ||||||
|       end |       end | ||||||
| 
 | 
 | ||||||
|       it 'returns true for status by silenced account who recipient is not following' do |       it 'returns false for status by limited account who recipient is not following' do | ||||||
|         status = Fabricate(:status, text: 'Hello world', account: alice) |         status = Fabricate(:status, text: 'Hello world', account: alice) | ||||||
|         alice.silence! |         alice.silence! | ||||||
|         expect(described_class.instance.filter?(:mentions, status, bob)).to be true |         expect(described_class.instance.filter?(:mentions, status, bob)).to be false | ||||||
|       end |       end | ||||||
| 
 | 
 | ||||||
|       it 'returns false for status by followed silenced account' do |       it 'returns false for status by followed limited account' do | ||||||
|         status = Fabricate(:status, text: 'Hello world', account: alice) |         status = Fabricate(:status, text: 'Hello world', account: alice) | ||||||
|         alice.silence! |         alice.silence! | ||||||
|         bob.follow!(alice) |         bob.follow!(alice) | ||||||
|  |  | ||||||
|  | @ -129,6 +129,35 @@ RSpec.describe NotifyService do | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |   describe NotifyService::DismissCondition do | ||||||
|  |     subject { described_class.new(notification) } | ||||||
|  | 
 | ||||||
|  |     let(:activity) { Fabricate(:mention, status: Fabricate(:status)) } | ||||||
|  |     let(:notification) { Fabricate(:notification, type: :mention, activity: activity, from_account: activity.status.account, account: activity.account) } | ||||||
|  | 
 | ||||||
|  |     describe '#dismiss?' do | ||||||
|  |       context 'when sender is silenced' do | ||||||
|  |         before do | ||||||
|  |           notification.from_account.silence! | ||||||
|  |         end | ||||||
|  | 
 | ||||||
|  |         it 'returns false' do | ||||||
|  |           expect(subject.dismiss?).to be false | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  | 
 | ||||||
|  |       context 'when recipient has blocked sender' do | ||||||
|  |         before do | ||||||
|  |           notification.account.block!(notification.from_account) | ||||||
|  |         end | ||||||
|  | 
 | ||||||
|  |         it 'returns true' do | ||||||
|  |           expect(subject.dismiss?).to be true | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   describe NotifyService::FilterCondition do |   describe NotifyService::FilterCondition do | ||||||
|     subject { described_class.new(notification) } |     subject { described_class.new(notification) } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Claire
						Claire