123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- # frozen_string_literal: true
- require 'rails_helper'
- describe Api::V1::Push::SubscriptionsController do
- render_views
- let(:user) { Fabricate(:user) }
- let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'push') }
- before do
- allow(controller).to receive(:doorkeeper_token) { token }
- end
- let(:create_payload) do
- {
- subscription: {
- endpoint: 'https://fcm.googleapis.com/fcm/send/fiuH06a27qE:APA91bHnSiGcLwdaxdyqVXNDR9w1NlztsHb6lyt5WDKOC_Z_Q8BlFxQoR8tWFSXUIDdkyw0EdvxTu63iqamSaqVSevW5LfoFwojws8XYDXv_NRRLH6vo2CdgiN4jgHv5VLt2A8ah6lUX',
- keys: {
- p256dh: 'BEm_a0bdPDhf0SOsrnB2-ategf1hHoCnpXgQsFj5JCkcoMrMt2WHoPfEYOYPzOIs9mZE8ZUaD7VA5vouy0kEkr8=',
- auth: 'eH_C8rq2raXqlcBVDa1gLg==',
- },
- }
- }.with_indifferent_access
- end
- let(:alerts_payload) do
- {
- data: {
- policy: 'all',
- alerts: {
- follow: true,
- follow_request: true,
- favourite: false,
- reblog: true,
- mention: false,
- poll: true,
- status: false,
- }
- }
- }.with_indifferent_access
- end
- describe 'POST #create' do
- before do
- post :create, params: create_payload
- end
- it 'saves push subscriptions' do
- push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint])
- expect(push_subscription.endpoint).to eq(create_payload[:subscription][:endpoint])
- expect(push_subscription.key_p256dh).to eq(create_payload[:subscription][:keys][:p256dh])
- expect(push_subscription.key_auth).to eq(create_payload[:subscription][:keys][:auth])
- expect(push_subscription.user_id).to eq user.id
- expect(push_subscription.access_token_id).to eq token.id
- end
- it 'replaces old subscription on repeat calls' do
- post :create, params: create_payload
- expect(Web::PushSubscription.where(endpoint: create_payload[:subscription][:endpoint]).count).to eq 1
- end
- it 'returns the expected JSON' do
- expect(body_as_json.with_indifferent_access).to include({ endpoint: create_payload[:subscription][:endpoint], alerts: {}, policy: 'all' })
- end
- end
- describe 'PUT #update' do
- before do
- post :create, params: create_payload
- put :update, params: alerts_payload
- end
- it 'changes alert settings' do
- push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint])
- expect(push_subscription.data['policy']).to eq(alerts_payload[:data][:policy])
- %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
- it 'returns the expected JSON' do
- expect(body_as_json.with_indifferent_access).to include({ endpoint: create_payload[:subscription][:endpoint], alerts: alerts_payload[:data][:alerts], policy: alerts_payload[:data][:policy] })
- end
- end
- describe 'DELETE #destroy' do
- before do
- post :create, params: create_payload
- delete :destroy
- end
- it 'removes the subscription' do
- expect(Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint])).to be_nil
- end
- end
- end
|