braze_ruby 0.3.2 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.circleci/config.yml +57 -0
- data/.circleci/gem_credentials +2 -0
- data/.circleci/setup-rubygems +6 -0
- data/.gitignore +12 -19
- data/.standard.yml +1 -0
- data/Gemfile +1 -2
- data/LICENSE.txt +17 -18
- data/README.md +49 -2
- data/Rakefile +2 -1
- data/bin/release +16 -0
- data/braze_ruby.gemspec +28 -31
- data/lib/braze_ruby.rb +4 -4
- data/lib/braze_ruby/api.rb +20 -14
- data/lib/braze_ruby/deprecated.rb +4 -4
- data/lib/braze_ruby/endpoints.rb +10 -7
- data/lib/braze_ruby/endpoints/campaigns.rb +1 -1
- data/lib/braze_ruby/endpoints/canvas.rb +2 -2
- data/lib/braze_ruby/endpoints/create_user_aliases.rb +19 -0
- data/lib/braze_ruby/endpoints/delete_users.rb +2 -2
- data/lib/braze_ruby/endpoints/email_status.rb +1 -1
- data/lib/braze_ruby/endpoints/email_sync.rb +2 -2
- data/lib/braze_ruby/endpoints/identify_users.rb +2 -2
- data/lib/braze_ruby/endpoints/remove_external_ids.rb +19 -0
- data/lib/braze_ruby/endpoints/rename_external_ids.rb +19 -0
- data/lib/braze_ruby/endpoints/schedule_messages.rb +1 -1
- data/lib/braze_ruby/endpoints/send_messages.rb +1 -1
- data/lib/braze_ruby/endpoints/subscription.rb +3 -4
- data/lib/braze_ruby/endpoints/track_users.rb +5 -5
- data/lib/braze_ruby/http.rb +21 -8
- data/lib/braze_ruby/rest.rb +20 -17
- data/lib/braze_ruby/rest/base.rb +5 -3
- data/lib/braze_ruby/rest/canvas_details.rb +4 -6
- data/lib/braze_ruby/rest/create_user_aliases.rb +13 -0
- data/lib/braze_ruby/rest/delete_users.rb +3 -4
- data/lib/braze_ruby/rest/email_hard_bounces.rb +4 -6
- data/lib/braze_ruby/rest/email_status.rb +6 -8
- data/lib/braze_ruby/rest/email_unsubscribes.rb +4 -6
- data/lib/braze_ruby/rest/export_users.rb +9 -11
- data/lib/braze_ruby/rest/identify_users.rb +3 -4
- data/lib/braze_ruby/rest/list_segments.rb +2 -4
- data/lib/braze_ruby/rest/remove_external_ids.rb +13 -0
- data/lib/braze_ruby/rest/rename_external_ids.rb +13 -0
- data/lib/braze_ruby/rest/schedule_messages.rb +9 -11
- data/lib/braze_ruby/rest/send_messages.rb +6 -8
- data/lib/braze_ruby/rest/subscription_status_get.rb +4 -6
- data/lib/braze_ruby/rest/subscription_status_set.rb +4 -6
- data/lib/braze_ruby/rest/subscription_user_status.rb +4 -6
- data/lib/braze_ruby/rest/track_users.rb +5 -6
- data/lib/braze_ruby/rest/trigger_campaign_send.rb +4 -8
- data/lib/braze_ruby/rest/trigger_canvas_send.rb +4 -6
- data/lib/braze_ruby/version.rb +1 -1
- metadata +61 -175
- data/.github/workflows/ci.yml +0 -19
- data/Gemfile.lock +0 -78
- data/spec/braze_ruby/api_spec.rb +0 -6
- data/spec/braze_ruby/endpoints/delete_users_spec.rb +0 -31
- data/spec/braze_ruby/endpoints/track_users_spec.rb +0 -74
- data/spec/braze_ruby/rest/delete_users_spec.rb +0 -22
- data/spec/braze_ruby/rest/email_status_spec.rb +0 -21
- data/spec/braze_ruby/rest/export_users_spec.rb +0 -21
- data/spec/braze_ruby/rest/identify_users_spec.rb +0 -23
- data/spec/braze_ruby/rest/schedule_messages_spec.rb +0 -38
- data/spec/braze_ruby/rest/send_messages_spec.rb +0 -35
- data/spec/braze_ruby/rest/track_users_spec.rb +0 -26
- data/spec/factories.rb +0 -38
- data/spec/fixtures/responses/campaigns/trigger_send/sends_an_email.yml +0 -69
- data/spec/fixtures/responses/canvas/details/returns_error_when_no_canvas.yml +0 -67
- data/spec/fixtures/responses/canvas/trigger_send/sends_a_canvas.yml +0 -69
- data/spec/fixtures/responses/delete_users/unauthorized/responds_with_unauthorized.yml +0 -66
- data/spec/fixtures/responses/delete_users/with_success/responds_with_created.yml +0 -69
- data/spec/fixtures/responses/delete_users/with_success/responds_with_success_message.yml +0 -69
- data/spec/fixtures/responses/email_status/existing_email/responds_with_created.yml +0 -69
- data/spec/fixtures/responses/email_status/existing_email/responds_with_success_message.yml +0 -69
- data/spec/fixtures/responses/email_status/unknown_email/responds_with_bad_request.yml +0 -69
- data/spec/fixtures/responses/email_status/unknown_email/responds_with_success_message.yml +0 -69
- data/spec/fixtures/responses/email_sync/hard_bounces/responds_with_empty_array_when_no_hard_bounces.yml +0 -73
- data/spec/fixtures/responses/email_sync/unsubscribes/responds_with_empty_array_when_no_unsubscribes.yml +0 -73
- data/spec/fixtures/responses/email_sync/unsubscribes/responds_with_unsubscribed_emails.yml +0 -74
- data/spec/fixtures/responses/export_users/by_ids/with_success/responds_with_created.yml +0 -69
- data/spec/fixtures/responses/export_users/by_segment/with_success/responds_with_created.yml +0 -69
- data/spec/fixtures/responses/identify_users/unauthorized/responds_with_unauthorized.yml +0 -66
- data/spec/fixtures/responses/identify_users/with_success/responds_with_created.yml +0 -69
- data/spec/fixtures/responses/identify_users/with_success/responds_with_success_message.yml +0 -69
- data/spec/fixtures/responses/list_segments/with_success/responds_with_a_list_of_segments.yml +0 -81
- data/spec/fixtures/responses/list_segments/with_success/responds_with_success.yml +0 -81
- data/spec/fixtures/responses/schedule_messages/unauthorized/responds_with_unauthorize.yml +0 -67
- data/spec/fixtures/responses/schedule_messages/with_success/responds_with_created.yml +0 -70
- data/spec/fixtures/responses/schedule_messages/with_success/responds_with_success_message.yml +0 -70
- data/spec/fixtures/responses/send_messages/unauthorized/responds_with_unauthorized.yml +0 -66
- data/spec/fixtures/responses/send_messages/with_success/responds_with_created.yml +0 -69
- data/spec/fixtures/responses/send_messages/with_success/responds_with_success_message.yml +0 -69
- data/spec/fixtures/responses/subscription/subscription_status_set/when_subscribing/subscribes_the_user.yml +0 -69
- data/spec/fixtures/responses/subscription/subscription_status_set/when_subscription_group_does_not_exist/returns_an_error_status.yml +0 -66
- data/spec/fixtures/responses/subscription/subscription_status_set/when_unsubscribing/unsubscribes_the_user.yml +0 -135
- data/spec/fixtures/responses/subscription/when_getting_subscription_group_statuses/subscription_status_get/when_checking_subscribed_and_unsubscribed_user_status/returns_only_users_that_were_once_subscribed.yml +0 -205
- data/spec/fixtures/responses/subscription/when_getting_subscription_group_statuses/subscription_status_get/when_group_does_not_exist/returns_an_error.yml +0 -193
- data/spec/fixtures/responses/subscription/when_getting_subscription_group_statuses/subscription_user_status/returns_subscription_groups_and_status_for_every_group.yml +0 -207
- data/spec/fixtures/responses/track_users/unauthorized/responds_with_unauthorized.yml +0 -68
- data/spec/fixtures/responses/track_users/with_success/responds_with_created.yml +0 -71
- data/spec/fixtures/responses/track_users/with_success/responds_with_success_message.yml +0 -71
- data/spec/integrations/campaigns_spec.rb +0 -17
- data/spec/integrations/canvas_spec.rb +0 -26
- data/spec/integrations/delete_users_spec.rb +0 -31
- data/spec/integrations/email_status_spec.rb +0 -38
- data/spec/integrations/email_sync_spec.rb +0 -31
- data/spec/integrations/export_users_spec.rb +0 -29
- data/spec/integrations/identify_users_spec.rb +0 -32
- data/spec/integrations/list_segments_spec.rb +0 -21
- data/spec/integrations/schedule_messages_spec.rb +0 -33
- data/spec/integrations/send_messages_spec.rb +0 -32
- data/spec/integrations/subscription_spec.rb +0 -149
- data/spec/integrations/track_users_spec.rb +0 -37
- data/spec/spec_helper.rb +0 -33
- data/spec/support/factory_bot.rb +0 -12
- data/spec/support/integrations.rb +0 -23
- data/spec/support/vcr.rb +0 -18
@@ -1,31 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
describe 'delete users' do
|
6
|
-
let(:external_ids) { [400, 401, 402] }
|
7
|
-
|
8
|
-
subject(:delete_users) do
|
9
|
-
api.delete_users(external_ids)
|
10
|
-
end
|
11
|
-
|
12
|
-
context 'with success', vcr: true do
|
13
|
-
it 'responds with created' do
|
14
|
-
expect(delete_users.status).to be 201
|
15
|
-
end
|
16
|
-
|
17
|
-
it 'responds with success message' do
|
18
|
-
expect(JSON.parse(delete_users.body)).to include(
|
19
|
-
'message' => 'success'
|
20
|
-
)
|
21
|
-
end
|
22
|
-
end
|
23
|
-
|
24
|
-
context 'unauthorized', vcr: true do
|
25
|
-
let(:api_key) { 'non-existent' }
|
26
|
-
|
27
|
-
it 'responds with unauthorized' do
|
28
|
-
expect(delete_users.status).to be 401
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
@@ -1,38 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
describe 'email status' do
|
6
|
-
let(:email) { 'john@example.com' }
|
7
|
-
let(:status) { :unsubscribed }
|
8
|
-
|
9
|
-
subject do
|
10
|
-
api.email_status(email: email, status: status)
|
11
|
-
end
|
12
|
-
|
13
|
-
context 'existing email', vcr: true do
|
14
|
-
it 'responds with created' do
|
15
|
-
expect(subject.status).to be 201
|
16
|
-
end
|
17
|
-
|
18
|
-
it 'responds with success message' do
|
19
|
-
expect(JSON.parse(subject.body)).to eq(
|
20
|
-
'message' => 'success'
|
21
|
-
)
|
22
|
-
end
|
23
|
-
end
|
24
|
-
|
25
|
-
context 'unknown email', vcr: true do
|
26
|
-
let(:email) { 'notthere@example.com' }
|
27
|
-
|
28
|
-
it 'responds with bad request' do
|
29
|
-
expect(subject.status).to be 201
|
30
|
-
end
|
31
|
-
|
32
|
-
it 'responds with success message' do
|
33
|
-
expect(JSON.parse(subject.body)).to eq(
|
34
|
-
'message' => 'success'
|
35
|
-
)
|
36
|
-
end
|
37
|
-
end
|
38
|
-
end
|
@@ -1,31 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
RSpec.describe 'email sync' do
|
6
|
-
describe 'unsubscribes' do
|
7
|
-
it 'responds with unsubscribed emails', vcr: true do
|
8
|
-
response = api.email_unsubscribes(start_date: '2019-03-20', end_date: '2019-03-25')
|
9
|
-
emails = JSON.parse(response.body)['emails']
|
10
|
-
|
11
|
-
expect(emails.size).to eq(1)
|
12
|
-
expect(emails.first['email']).to eq('wojtek@test.com')
|
13
|
-
end
|
14
|
-
|
15
|
-
it 'responds with empty array when no unsubscribes', vcr: true do
|
16
|
-
response = api.email_unsubscribes(start_date: '2019-02-20', end_date: '2019-02-25')
|
17
|
-
emails = JSON.parse(response.body)['emails']
|
18
|
-
|
19
|
-
expect(emails.size).to eq(0)
|
20
|
-
end
|
21
|
-
end
|
22
|
-
|
23
|
-
describe 'hard_bounces' do
|
24
|
-
it 'responds with empty array when no hard bounces', vcr: true do
|
25
|
-
response = api.email_hard_bounces(start_date: '2019-02-20', end_date: '2019-02-25')
|
26
|
-
emails = JSON.parse(response.body)['emails']
|
27
|
-
|
28
|
-
expect(emails.size).to eq(0)
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
@@ -1,29 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
describe 'export users' do
|
6
|
-
context 'by ids' do
|
7
|
-
subject(:export_users) { api.export_users(external_ids: [1]) }
|
8
|
-
|
9
|
-
context 'with success', :vcr do
|
10
|
-
it 'responds with created' do
|
11
|
-
expect(export_users).to be_success
|
12
|
-
end
|
13
|
-
end
|
14
|
-
end
|
15
|
-
|
16
|
-
context 'by segment' do
|
17
|
-
context 'with success', :vcr do
|
18
|
-
let(:segment_id) { braze_test_segment }
|
19
|
-
|
20
|
-
subject(:export_users) do
|
21
|
-
api.export_users(segment_id: segment_id, callback_endpoint: 'https://example.com')
|
22
|
-
end
|
23
|
-
|
24
|
-
it 'responds with created' do
|
25
|
-
expect(export_users).to be_success
|
26
|
-
end
|
27
|
-
end
|
28
|
-
end
|
29
|
-
end
|
@@ -1,32 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
describe 'identify users' do
|
6
|
-
let(:user) { { external_id: 400, user_alias: { alias_name: 'abc', alias_label: 'foo' } } }
|
7
|
-
|
8
|
-
subject(:identify_users) do
|
9
|
-
api.identify_users(aliases_to_identify: [user])
|
10
|
-
end
|
11
|
-
|
12
|
-
context 'with success', vcr: true do
|
13
|
-
it 'responds with created' do
|
14
|
-
expect(identify_users.status).to be 201
|
15
|
-
end
|
16
|
-
|
17
|
-
it 'responds with success message' do
|
18
|
-
expect(JSON.parse(identify_users.body)).to eq(
|
19
|
-
'aliases_processed' => 1,
|
20
|
-
'message' => 'success'
|
21
|
-
)
|
22
|
-
end
|
23
|
-
end
|
24
|
-
|
25
|
-
context 'unauthorized', vcr: true do
|
26
|
-
let(:api_key) { 'non-existent' }
|
27
|
-
|
28
|
-
it 'responds with unauthorized' do
|
29
|
-
expect(identify_users.status).to be 401
|
30
|
-
end
|
31
|
-
end
|
32
|
-
end
|
@@ -1,21 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
describe 'list segments' do
|
6
|
-
subject(:list_segments) { api.list_segments }
|
7
|
-
|
8
|
-
context 'with success', :vcr do
|
9
|
-
it 'responds with success' do
|
10
|
-
expect(list_segments).to be_success
|
11
|
-
end
|
12
|
-
|
13
|
-
it 'responds with a list of segments' do
|
14
|
-
expect(segments.count).to be 13
|
15
|
-
end
|
16
|
-
|
17
|
-
def segments
|
18
|
-
JSON.parse(list_segments.body)['segments']
|
19
|
-
end
|
20
|
-
end
|
21
|
-
end
|
@@ -1,33 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
describe 'schedule messages' do
|
6
|
-
let(:user_ids) { [1] }
|
7
|
-
let(:messages) { build(:messages) }
|
8
|
-
|
9
|
-
subject(:schedule_messages) do
|
10
|
-
api.schedule_messages(time: test_time,
|
11
|
-
messages: messages, external_user_ids: user_ids)
|
12
|
-
end
|
13
|
-
|
14
|
-
context 'with success', vcr: true do
|
15
|
-
it 'responds with created' do
|
16
|
-
expect(schedule_messages.status).to be 201
|
17
|
-
end
|
18
|
-
|
19
|
-
it 'responds with success message' do
|
20
|
-
expect(JSON.parse(schedule_messages.body)).to include(
|
21
|
-
'message' => 'success'
|
22
|
-
)
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
context 'unauthorized', vcr: true do
|
27
|
-
let(:api_key) { 'non-existent' }
|
28
|
-
|
29
|
-
it 'responds with unauthorize' do
|
30
|
-
expect(schedule_messages.status).to be 401
|
31
|
-
end
|
32
|
-
end
|
33
|
-
end
|
@@ -1,32 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
describe 'send messages' do
|
6
|
-
let(:user_ids) { [1] }
|
7
|
-
let(:messages) { build(:messages) }
|
8
|
-
|
9
|
-
subject(:send_messages) do
|
10
|
-
api.send_messages(messages: messages, external_user_ids: user_ids)
|
11
|
-
end
|
12
|
-
|
13
|
-
context 'with success', vcr: true do
|
14
|
-
it 'responds with created' do
|
15
|
-
expect(send_messages.status).to be 201
|
16
|
-
end
|
17
|
-
|
18
|
-
it 'responds with success message' do
|
19
|
-
expect(JSON.parse(send_messages.body)).to eq(
|
20
|
-
'message' => 'success'
|
21
|
-
)
|
22
|
-
end
|
23
|
-
end
|
24
|
-
|
25
|
-
context 'unauthorized', vcr: true do
|
26
|
-
let(:api_key) { 'non-existent' }
|
27
|
-
|
28
|
-
it 'responds with unauthorized' do
|
29
|
-
expect(send_messages.status).to be 401
|
30
|
-
end
|
31
|
-
end
|
32
|
-
end
|
@@ -1,149 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
RSpec.describe 'subscription', vcr: true do
|
6
|
-
let(:subscription_group_id) { '0201b87a-ef6e-4410-9412-a298c4c1206d' }
|
7
|
-
let(:subscribed_user) { 'test-gem-001' }
|
8
|
-
let(:unsubscribed_user) { 'test-gem-002' }
|
9
|
-
let(:never_subscribed_user) { 'test-gem-003' }
|
10
|
-
|
11
|
-
context 'when getting subscription group statuses' do
|
12
|
-
let(:json_response) { JSON.parse(response.body) }
|
13
|
-
|
14
|
-
before do
|
15
|
-
api.subscription_status_set(
|
16
|
-
external_id: subscribed_user,
|
17
|
-
subscription_group_id: subscription_group_id,
|
18
|
-
subscription_state: 'subscribed'
|
19
|
-
)
|
20
|
-
|
21
|
-
api.subscription_status_set(
|
22
|
-
external_id: unsubscribed_user,
|
23
|
-
subscription_group_id: subscription_group_id,
|
24
|
-
subscription_state: 'unsubscribed'
|
25
|
-
)
|
26
|
-
end
|
27
|
-
|
28
|
-
describe 'subscription_user_status' do
|
29
|
-
subject(:response) do
|
30
|
-
api.subscription_user_status(
|
31
|
-
external_id: external_id,
|
32
|
-
)
|
33
|
-
end
|
34
|
-
|
35
|
-
let(:external_id) { [subscribed_user, unsubscribed_user, never_subscribed_user] }
|
36
|
-
|
37
|
-
it 'returns subscription groups and status for every group' do
|
38
|
-
expect(response.status).to eq(200)
|
39
|
-
expect(json_response).to match(
|
40
|
-
'message' => 'success',
|
41
|
-
'total_count' => 3,
|
42
|
-
'users' => [
|
43
|
-
hash_including(
|
44
|
-
'external_id' => subscribed_user,
|
45
|
-
'subscription_groups' => [
|
46
|
-
hash_including(
|
47
|
-
'id' => subscription_group_id,
|
48
|
-
'status' => 'Subscribed'
|
49
|
-
)
|
50
|
-
]
|
51
|
-
),
|
52
|
-
hash_including(
|
53
|
-
'external_id' => unsubscribed_user,
|
54
|
-
'subscription_groups' => [
|
55
|
-
hash_including(
|
56
|
-
'id' => subscription_group_id,
|
57
|
-
'status' => 'Unsubscribed'
|
58
|
-
)
|
59
|
-
]
|
60
|
-
),
|
61
|
-
hash_including(
|
62
|
-
'external_id' => never_subscribed_user,
|
63
|
-
'subscription_groups' => []
|
64
|
-
)
|
65
|
-
]
|
66
|
-
)
|
67
|
-
end
|
68
|
-
end
|
69
|
-
|
70
|
-
describe 'subscription_status_get' do
|
71
|
-
subject(:response) do
|
72
|
-
api.subscription_status_get(
|
73
|
-
external_id: external_id,
|
74
|
-
subscription_group_id: subscription_group_id
|
75
|
-
)
|
76
|
-
end
|
77
|
-
|
78
|
-
context 'when checking subscribed and unsubscribed user status' do
|
79
|
-
let(:external_id) { [subscribed_user, unsubscribed_user, never_subscribed_user] }
|
80
|
-
|
81
|
-
it 'returns only users that were once subscribed' do
|
82
|
-
expect(response.status).to eq(200)
|
83
|
-
expect(json_response).to eq(
|
84
|
-
'message' => 'success',
|
85
|
-
'status' => {
|
86
|
-
'test-gem-001' => 'Subscribed',
|
87
|
-
'test-gem-002' => 'Unsubscribed',
|
88
|
-
'test-gem-003' => 'unknown'
|
89
|
-
}
|
90
|
-
)
|
91
|
-
end
|
92
|
-
end
|
93
|
-
|
94
|
-
context 'when group does not exist' do
|
95
|
-
let(:external_id) { subscribed_user }
|
96
|
-
let(:subscription_group_id) { 'non-existing-subscription-group' }
|
97
|
-
|
98
|
-
it 'returns an error' do
|
99
|
-
expect(response.status).to eq(400)
|
100
|
-
end
|
101
|
-
end
|
102
|
-
end
|
103
|
-
|
104
|
-
end
|
105
|
-
|
106
|
-
describe 'subscription_status_set' do
|
107
|
-
subject(:response) do
|
108
|
-
api.subscription_status_set(
|
109
|
-
external_id: external_id,
|
110
|
-
subscription_group_id: subscription_group_id,
|
111
|
-
subscription_state: subscription_state
|
112
|
-
)
|
113
|
-
end
|
114
|
-
|
115
|
-
let(:external_id) { subscribed_user }
|
116
|
-
let(:subscription_state) { 'subscribed' }
|
117
|
-
|
118
|
-
context 'when subscribing' do
|
119
|
-
it 'subscribes the user' do
|
120
|
-
expect(response.status).to eq(201)
|
121
|
-
end
|
122
|
-
end
|
123
|
-
|
124
|
-
context 'when unsubscribing' do
|
125
|
-
let(:external_id) { unsubscribed_user }
|
126
|
-
let(:subscription_state) { 'unsubscribed' }
|
127
|
-
|
128
|
-
before do
|
129
|
-
api.subscription_status_set(
|
130
|
-
external_id: external_id,
|
131
|
-
subscription_group_id: subscription_group_id,
|
132
|
-
subscription_state: 'subscribed'
|
133
|
-
)
|
134
|
-
end
|
135
|
-
|
136
|
-
it 'unsubscribes the user' do
|
137
|
-
expect(response.status).to eq(201)
|
138
|
-
end
|
139
|
-
end
|
140
|
-
|
141
|
-
context 'when subscription group does not exist' do
|
142
|
-
let(:subscription_group_id) { 'non-existing-subscription-group' }
|
143
|
-
|
144
|
-
it 'returns an error status' do
|
145
|
-
expect(response.status).to eq(400)
|
146
|
-
end
|
147
|
-
end
|
148
|
-
end
|
149
|
-
end
|
@@ -1,37 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
describe 'track users' do
|
6
|
-
let(:attributes) { [build(:attribute)] }
|
7
|
-
let(:events) { [build(:event, time: test_time)] }
|
8
|
-
let(:purchases) { [build(:purchase, time: test_time)] }
|
9
|
-
|
10
|
-
subject(:track_users) do
|
11
|
-
api.track_users(attributes: attributes,
|
12
|
-
events: events, purchases: purchases)
|
13
|
-
end
|
14
|
-
|
15
|
-
context 'with success', vcr: true do
|
16
|
-
it 'responds with created' do
|
17
|
-
expect(track_users.status).to be 201
|
18
|
-
end
|
19
|
-
|
20
|
-
it 'responds with success message' do
|
21
|
-
expect(JSON.parse(track_users.body)).to eq(
|
22
|
-
'attributes_processed' => 1,
|
23
|
-
'events_processed' => 1,
|
24
|
-
'purchases_processed' => 1,
|
25
|
-
'message' => 'success'
|
26
|
-
)
|
27
|
-
end
|
28
|
-
end
|
29
|
-
|
30
|
-
context 'unauthorized', vcr: true do
|
31
|
-
let(:api_key) { 'non-existent' }
|
32
|
-
|
33
|
-
it 'responds with unauthorized' do
|
34
|
-
expect(track_users.status).to be 401
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|