forked from segmentio/action-destinations
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Stackadapt (ITE-146) Update Segment Engage Destination to handle onDe…
…lete events (segmentio#2599) * Added OnDelete * Fix(ITE-146) Rethrow Error
- Loading branch information
Showing
2 changed files
with
138 additions
and
2 deletions.
There are no files selected for viewing
97 changes: 97 additions & 0 deletions
97
packages/destination-actions/src/destinations/stackadapt-audiences/__tests__/index.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
import { createTestEvent, createTestIntegration } from '@segment/actions-core' | ||
import nock from 'nock' | ||
import Definition from '../index' | ||
import { GQL_ENDPOINT } from '../functions' | ||
|
||
const testDestination = createTestIntegration(Definition) | ||
|
||
describe('StackAdapt Audiences - Destination Tests', () => { | ||
const mockSettings = { apiKey: 'test-api-key' } | ||
const gqlHostUrl = 'https://api.stackadapt.com' | ||
|
||
afterEach(() => { | ||
nock.cleanAll() | ||
}) | ||
|
||
describe('testAuthentication', () => { | ||
it('should validate authentication inputs', async () => { | ||
nock(GQL_ENDPOINT, { | ||
reqheaders: { | ||
authorization: `Bearer ${mockSettings.apiKey}`, | ||
'content-type': 'application/json' | ||
} | ||
}) | ||
.post('', { | ||
query: /tokenInfo/ | ||
}) | ||
.reply(200, { | ||
data: { | ||
tokenInfo: { | ||
scopesByAdvertiser: { | ||
nodes: [ | ||
{ | ||
advertiser: { name: 'Test Advertiser' }, | ||
scopes: ['WRITE'] | ||
} | ||
] | ||
} | ||
} | ||
} | ||
}) | ||
|
||
await expect(testDestination.testAuthentication(mockSettings)).resolves.not.toThrowError() | ||
}) | ||
|
||
it('should fail if authentication is invalid', async () => { | ||
nock(GQL_ENDPOINT).post('').reply(403, {}) | ||
|
||
await expect(testDestination.testAuthentication(mockSettings)).rejects.toThrowError('403Forbidden') | ||
}) | ||
}) | ||
|
||
describe('onDelete', () => { | ||
it('should delete a user with a given userId', async () => { | ||
const userId = '9999' | ||
const event = createTestEvent({ userId, type: 'identify' }) | ||
|
||
// Mock the GraphQL deleteProfilesWithExternalIds mutation | ||
nock(gqlHostUrl) | ||
.post('/graphql', (body) => { | ||
return body.query.includes('deleteProfilesWithExternalIds') && body.query.includes(userId) | ||
}) | ||
.reply(200, { | ||
data: { deleteProfilesWithExternalIds: { userErrors: [] } } | ||
}) | ||
|
||
const response = await testDestination.onDelete!(event, { | ||
apiKey: 'test-api-key' | ||
}) | ||
|
||
expect(response).toMatchObject({ | ||
data: { deleteProfilesWithExternalIds: { userErrors: [] } } | ||
}) | ||
}) | ||
|
||
it('should throw an error if profile deletion fails with userErrors', async () => { | ||
const userId = '9999' | ||
const event = createTestEvent({ userId, type: 'identify' }) | ||
|
||
// Mock the GraphQL deleteProfilesWithExternalIds mutation with an error | ||
nock(gqlHostUrl) | ||
.post('/graphql') | ||
.reply(200, { | ||
data: { | ||
deleteProfilesWithExternalIds: { | ||
userErrors: [{ message: 'Deletion failed' }] | ||
} | ||
} | ||
}) | ||
|
||
await expect( | ||
testDestination.onDelete!(event, { | ||
apiKey: 'test-api-key' | ||
}) | ||
).rejects.toThrowError('Profile deletion was not successful: Deletion failed') | ||
}) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters