Skip to content

Commit

Permalink
test(braze): testing the ins and out of digest
Browse files Browse the repository at this point in the history
  • Loading branch information
bassrock committed Aug 29, 2024
1 parent 4bf252e commit 96b779f
Show file tree
Hide file tree
Showing 7 changed files with 154 additions and 7 deletions.
31 changes: 30 additions & 1 deletion infrastructure/braze-content-proxy/src/main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -159,6 +159,7 @@ class BrazeContentProxy extends TerraformStack {
}): PocketALBApplication {
const { region, caller, secretsManagerKmsAlias, snsTopic, wafAcl } =
dependencies;
const intMaskSecretArn = `arn:aws:secretsmanager:${region.name}:${caller.accountId}:secret:Shared/IntMask`;

return new PocketALBApplication(this, 'application', {
internal: false,
Expand Down Expand Up @@ -200,7 +201,35 @@ class BrazeContentProxy extends TerraformStack {
},
{
name: 'BRAZE_PRIVATE_KEY',
valueFrom: `arn:aws:secretsmanager:${region.name}:${caller.accountId}:secret:${config.name}/${config.environment}/BRAZE_PRIVATE_KEY:`,
valueFrom: `arn:aws:secretsmanager:${region.name}:${caller.accountId}:secret:${config.name}/${config.environment}/PRIVATE_KEY:::`,
},
{
name: 'CONTACT_HASH',
valueFrom: `${intMaskSecretArn}:contactHash::`,
},
{
name: 'CHARACTER_MAP',
valueFrom: `${intMaskSecretArn}:characterMap::`,
},
{
name: 'POSITION_MAP',
valueFrom: `${intMaskSecretArn}:positionMap::`,
},
{
name: 'MD5_RANDOMIZER',
valueFrom: `${intMaskSecretArn}:md5Randomizer::`,
},
{
name: 'LETTER_INDEX',
valueFrom: `${intMaskSecretArn}:letterIndex::`,
},
{
name: 'SALT_1',
valueFrom: `${intMaskSecretArn}:salt1::`,
},
{
name: 'SALT_2',
valueFrom: `${intMaskSecretArn}:salt2::`,
},
],
},
Expand Down
4 changes: 2 additions & 2 deletions packages/jwt-utils/README.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
# Image Utils
# JWT Utils

We use this repository as a place to keep code we use across our backend services that implement anything to do with image urls
We use this repository as a place to keep code we use across our backend services that implement anything to do with JWTs
1 change: 1 addition & 0 deletions servers/braze-content-proxy/jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,6 @@ module.exports = {
testPathIgnorePatterns: ['/dist/', '/lambda/'],
testTimeout: 10000,
displayName: 'braze-content-proxy',
setupFiles: ['./jest.setup.js'],
setupFilesAfterEnv: ['jest-extended/all'],
};
10 changes: 10 additions & 0 deletions servers/braze-content-proxy/jest.setup.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
process.env.CHARACTER_MAP =
'[["A",0],["B",0],["C",0],["D",0],["E",0],["y",0],["F",1],["G",1],["H",1],["I",1],["J",1],["z",1],["K",2],["L",2],["M",2],["N",2],["O",2],["P",3],["Q",3],["R",3],["S",3],["T",3],["U",4],["V",4],["W",4],["X",4],["Y",4],["Z",5],["a",5],["b",5],["c",5],["d",5],["e",6],["f",6],["g",6],["h",6],["i",6],["j",7],["k",7],["l",7],["m",7],["n",7],["o",8],["p",8],["q",8],["r",8],["s",8],["t",9],["u",9],["v",9],["w",9],["x",9]]';
process.env.POSITION_MAP =
'[[9,0],[12,1],[26,2],[59,3],[45,4],[56,5],[23,6],[42,7],[48,8],[18,9],[40,10],[10,11],[37,12],[32,13],[21,14],[16,15]]';
process.env.MD5_RANDOMIZER =
'[["0",["g"]],["1",["g"]],["2",["h"]],["3",["a"]],["4",["a"]],["5",["3"]],["6",["1"]],["7",["1"]],["8",["7"]],["9",["k"]],["a",["v"]],["b",["X"]],["c",["i"]],["d",["f","T","q"]],["e",["o"]],["f",["O","h","b"]]]';
process.env.LETTER_INDEX =
'[["a",0],["b",1],["c",2],["d",3],["e",4],["f",5],["0",6]]';
process.env.SALT_1 = '123asdf';
process.env.SALT_2 = 'asdaa47';
104 changes: 104 additions & 0 deletions servers/braze-content-proxy/src/routes/digest.integration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,16 +3,96 @@ import request from 'supertest';
import { Server } from 'http';
import { Application } from 'express';
import { startServer } from '../server';
import nock, { cleanAll, restore } from 'nock';
import { UserDigestQuery } from '../generated/graphql/types';
import { ApolloQueryResult } from '@apollo/client/core';

describe(`get digest`, () => {
let app: Application;
let server: Server;

const testEncodedUserId =
'fb792e6e9DE6E3ecI3Ca1CaE49A08497Bc36eA3eD5AacCd0Ba3b1056DbaB89d5';
const validUrl = `/digest/${testEncodedUserId}?apikey=${config.aws.brazeApiKey}`;

const fakeResponse: Omit<
ApolloQueryResult<UserDigestQuery>,
'loading' | 'networkStatus'
> = {
data: {
user: {
savedItems: {
edges: [
{
node: {
item: {
__typename: 'Item',
preview: {
title: 'Cool Item 1',
url: 'https://www.item1.com',
image: {
cachedImages: [
{
id: 'thumbnail',
url: 'https://image1.com',
},
],
},
},
},
},
},
{
node: {
item: {
__typename: 'Item',
preview: {
title: '',
url: 'https://item2.com',
image: null,
},
},
},
},
{
node: {
item: {
__typename: 'Item',
preview: {
title: 'Super Secret',
url: 'https://item3.com',
image: {
cachedImages: [
{
id: 'thumbnail',
url: 'image2.com',
},
],
},
},
},
},
},
{
node: {
item: {
__typename: 'PendingItem',
},
},
},
],
},
},
},
};

beforeAll(async () => {
({ app, server } = await startServer(0));
});
afterAll(async () => {
server.close();
cleanAll();
restore();
});
beforeEach(() => {
jest.clearAllMocks();
Expand All @@ -26,4 +106,28 @@ describe(`get digest`, () => {
expect(response.body.error).not.toBeUndefined();
expect(response.body.error).toBe(config.app.INVALID_API_KEY_ERROR_MESSAGE);
});

it('should return correct data when valid query params are provided', async () => {
nock(config.clientApi.uri).post('/').reply(200, fakeResponse);

const response = await request(app).get(validUrl);

expect(response.statusCode).toBe(200);
expect(response.body).toEqual([
{
imageUrl: 'https://image1.com',
title: 'Cool Item 1',
url: 'https://www.item1.com',
},
{
title: '',
url: 'https://item2.com',
},
{
imageUrl: 'image2.com',
title: 'Super Secret',
url: 'https://item3.com',
},
]);
});
});
5 changes: 4 additions & 1 deletion servers/braze-content-proxy/src/routes/digest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,10 @@ export async function getUserDigest(userId: string) {
function transformToBrazePayload(
response: ApolloQueryResult<UserDigestQuery>,
): BrazeSavedItem[] {
const edges = response.data.user.savedItems.edges;
const edges = response.data.user?.savedItems?.edges;
if (!edges) {
return [];
}
const savedItems: BrazeSavedItem[] = edges
.filter((edge) => edge.node.item.__typename == 'Item')
.map((edge) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,12 +65,12 @@ describe('/scheduled-items/:scheduledSurfaceID?date=date&apikey=apikey', () => {
expect(response.body).toEqual(testStories);
});

it('should return 403 for non-existent url', async () => {
it('should return 500 for non-existent url', async () => {
const response = await request(app).get('/not-found');
expect(response.statusCode).toBe(500);
});

it('should return 400 if incorrect date format is provided ', async () => {
it('should return 500 if incorrect date format is provided ', async () => {
const response = await request(app).get(
`/scheduled-items/${testNewTab}?date=20220524&apikey=${config.aws.brazeApiKey}`,
);
Expand All @@ -82,7 +82,7 @@ describe('/scheduled-items/:scheduledSurfaceID?date=date&apikey=apikey', () => {
);
});

it('should return 403 if invalid api key is provided ', async () => {
it('should return 500 if invalid api key is provided ', async () => {
const response = await request(app).get(
`/scheduled-items/${testNewTab}?date=${testDate}&apikey=invalid-key`,
);
Expand Down

0 comments on commit 96b779f

Please sign in to comment.