|
@ -9,7 +9,7 @@ describe Api::Web::PushSubscriptionsController do |
|
|
|
|
|
|
|
|
let(:create_payload) do |
|
|
let(:create_payload) do |
|
|
{ |
|
|
{ |
|
|
data: { |
|
|
|
|
|
|
|
|
subscription: { |
|
|
endpoint: 'https://fcm.googleapis.com/fcm/send/fiuH06a27qE:APA91bHnSiGcLwdaxdyqVXNDR9w1NlztsHb6lyt5WDKOC_Z_Q8BlFxQoR8tWFSXUIDdkyw0EdvxTu63iqamSaqVSevW5LfoFwojws8XYDXv_NRRLH6vo2CdgiN4jgHv5VLt2A8ah6lUX', |
|
|
endpoint: 'https://fcm.googleapis.com/fcm/send/fiuH06a27qE:APA91bHnSiGcLwdaxdyqVXNDR9w1NlztsHb6lyt5WDKOC_Z_Q8BlFxQoR8tWFSXUIDdkyw0EdvxTu63iqamSaqVSevW5LfoFwojws8XYDXv_NRRLH6vo2CdgiN4jgHv5VLt2A8ah6lUX', |
|
|
keys: { |
|
|
keys: { |
|
|
p256dh: 'BEm_a0bdPDhf0SOsrnB2-ategf1hHoCnpXgQsFj5JCkcoMrMt2WHoPfEYOYPzOIs9mZE8ZUaD7VA5vouy0kEkr8=', |
|
|
p256dh: 'BEm_a0bdPDhf0SOsrnB2-ategf1hHoCnpXgQsFj5JCkcoMrMt2WHoPfEYOYPzOIs9mZE8ZUaD7VA5vouy0kEkr8=', |
|
@ -36,25 +36,17 @@ describe Api::Web::PushSubscriptionsController do |
|
|
it 'saves push subscriptions' do |
|
|
it 'saves push subscriptions' do |
|
|
sign_in(user) |
|
|
sign_in(user) |
|
|
|
|
|
|
|
|
stub_request(:post, create_payload[:data][:endpoint]).to_return(status: 200) |
|
|
|
|
|
|
|
|
stub_request(:post, create_payload[:subscription][:endpoint]).to_return(status: 200) |
|
|
|
|
|
|
|
|
post :create, format: :json, params: create_payload |
|
|
post :create, format: :json, params: create_payload |
|
|
|
|
|
|
|
|
user.reload |
|
|
user.reload |
|
|
|
|
|
|
|
|
push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:data][:endpoint]) |
|
|
|
|
|
|
|
|
|
|
|
expect(push_subscription['endpoint']).to eq(create_payload[:data][:endpoint]) |
|
|
|
|
|
expect(push_subscription['key_p256dh']).to eq(create_payload[:data][:keys][:p256dh]) |
|
|
|
|
|
expect(push_subscription['key_auth']).to eq(create_payload[:data][:keys][:auth]) |
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint]) |
|
|
|
|
|
|
|
|
it 'sends welcome notification' do |
|
|
|
|
|
sign_in(user) |
|
|
|
|
|
|
|
|
|
|
|
stub_request(:post, create_payload[:data][:endpoint]).to_return(status: 200) |
|
|
|
|
|
|
|
|
|
|
|
post :create, format: :json, params: create_payload |
|
|
|
|
|
|
|
|
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]) |
|
|
end |
|
|
end |
|
|
end |
|
|
end |
|
|
|
|
|
|
|
@ -62,15 +54,15 @@ describe Api::Web::PushSubscriptionsController do |
|
|
it 'changes alert settings' do |
|
|
it 'changes alert settings' do |
|
|
sign_in(user) |
|
|
sign_in(user) |
|
|
|
|
|
|
|
|
stub_request(:post, create_payload[:data][:endpoint]).to_return(status: 200) |
|
|
|
|
|
|
|
|
stub_request(:post, create_payload[:subscription][:endpoint]).to_return(status: 200) |
|
|
|
|
|
|
|
|
post :create, format: :json, params: create_payload |
|
|
post :create, format: :json, params: create_payload |
|
|
|
|
|
|
|
|
alerts_payload[:id] = Web::PushSubscription.find_by(endpoint: create_payload[:data][:endpoint]).id |
|
|
|
|
|
|
|
|
alerts_payload[:id] = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint]).id |
|
|
|
|
|
|
|
|
put :update, format: :json, params: alerts_payload |
|
|
put :update, format: :json, params: alerts_payload |
|
|
|
|
|
|
|
|
push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:data][:endpoint]) |
|
|
|
|
|
|
|
|
push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint]) |
|
|
|
|
|
|
|
|
expect(push_subscription.data['follow']).to eq(alerts_payload[:data][:follow]) |
|
|
expect(push_subscription.data['follow']).to eq(alerts_payload[:data][:follow]) |
|
|
expect(push_subscription.data['favourite']).to eq(alerts_payload[:data][:favourite]) |
|
|
expect(push_subscription.data['favourite']).to eq(alerts_payload[:data][:favourite]) |
|
|