Add policy param to POST /api/v1/push/subscriptions (#16040)
		
	With possible values `all`, `followed`, `follower`, and `none`, control from whom notifications will generate a Web Push alert
This commit is contained in:
		
					parent
					
						
							
								c968d22ee9
							
						
					
				
			
			
				commit
				
					
						ce2148c571
					
				
			
		
					 6 changed files with 170 additions and 51 deletions
				
			
		|  | @ -22,11 +22,16 @@ describe Api::Web::PushSubscriptionsController do | |||
|   let(:alerts_payload) do | ||||
|     { | ||||
|       data: { | ||||
|         policy: 'all', | ||||
| 
 | ||||
|         alerts: { | ||||
|           follow: true, | ||||
|           follow_request: false, | ||||
|           favourite: false, | ||||
|           reblog: true, | ||||
|           mention: false, | ||||
|           poll: true, | ||||
|           status: false, | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | @ -59,10 +64,11 @@ describe Api::Web::PushSubscriptionsController do | |||
| 
 | ||||
|         push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint]) | ||||
| 
 | ||||
|         expect(push_subscription.data['alerts']['follow']).to eq(alerts_payload[:data][:alerts][:follow].to_s) | ||||
|         expect(push_subscription.data['alerts']['favourite']).to eq(alerts_payload[:data][:alerts][:favourite].to_s) | ||||
|         expect(push_subscription.data['alerts']['reblog']).to eq(alerts_payload[:data][:alerts][:reblog].to_s) | ||||
|         expect(push_subscription.data['alerts']['mention']).to eq(alerts_payload[:data][:alerts][:mention].to_s) | ||||
|         expect(push_subscription.data['policy']).to eq 'all' | ||||
| 
 | ||||
|         %w(follow follow_request favourite reblog mention poll status).each do |type| | ||||
|           expect(push_subscription.data['alerts'][type]).to eq(alerts_payload[:data][:alerts][type.to_sym].to_s) | ||||
|         end | ||||
|       end | ||||
|     end | ||||
|   end | ||||
|  | @ -81,10 +87,11 @@ describe Api::Web::PushSubscriptionsController do | |||
| 
 | ||||
|       push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint]) | ||||
| 
 | ||||
|       expect(push_subscription.data['alerts']['follow']).to eq(alerts_payload[:data][:alerts][:follow].to_s) | ||||
|       expect(push_subscription.data['alerts']['favourite']).to eq(alerts_payload[:data][:alerts][:favourite].to_s) | ||||
|       expect(push_subscription.data['alerts']['reblog']).to eq(alerts_payload[:data][:alerts][:reblog].to_s) | ||||
|       expect(push_subscription.data['alerts']['mention']).to eq(alerts_payload[:data][:alerts][:mention].to_s) | ||||
|       expect(push_subscription.data['policy']).to eq 'all' | ||||
| 
 | ||||
|       %w(follow follow_request favourite reblog mention poll status).each do |type| | ||||
|         expect(push_subscription.data['alerts'][type]).to eq(alerts_payload[:data][:alerts][type.to_sym].to_s) | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue