diff --git a/test/options-pipe.test.js b/test/options-pipe.test.js index ff65106f..4977e95d 100644 --- a/test/options-pipe.test.js +++ b/test/options-pipe.test.js @@ -26,14 +26,14 @@ const HELIX_CONFIG_JSON = JSON.stringify({ }, }); -describe('Preflight OPTIONS Requests', () => { - function createRequest(headers) { - return new PipelineRequest('https://helix-pipeline.com/', { - method: 'options', - headers, - }); - } +function createRequest(headers, url = '/') { + return new PipelineRequest(`https://helix-pipeline.com${url}`, { + method: 'options', + headers, + }); +} +describe('Preflight OPTIONS Requests', () => { const defaultState = () => ({ owner: 'owner', repo: 'repo', @@ -182,3 +182,213 @@ describe('Preflight OPTIONS Requests', () => { }); }); }); + +describe('RUM Challenge OPTIONS Request', () => { + it('sends 204 without x-rum-challenge header for normal requests', async () => { + const state = new PipelineState({ + owner: 'owner', + repo: 'repo', + ref: 'ref', + partition: 'live', + path: '/somepath/workbook', + log: console, + s3Loader: new StaticS3Loader() + .reply( + 'helix-code-bus', + 'owner/repo/ref/helix-config.json', + new PipelineResponse(HELIX_CONFIG_JSON), + ), + }); + + const response = await optionsPipe( + state, + createRequest({ + 'x-forwarded-host': 'localhost', + }), + ); + assert.strictEqual(response.status, 204); + const challenge = response.headers.get('x-rum-challenge'); + // assert that the challenge is not set + assert.strictEqual(challenge, undefined); + }); + + it('sends 204 without x-rum-challenge header when hostnames do not match', async () => { + const state = new PipelineState({ + owner: 'owner', + repo: 'repo', + ref: 'ref', + partition: 'live', + path: '/somepath/workbook', + log: console, + s3Loader: new StaticS3Loader() + .reply( + 'helix-code-bus', + 'owner/repo/ref/helix-config.json', + new PipelineResponse(HELIX_CONFIG_JSON), + ) + .reply('helix-content-bus', 'foobus/live/.helix/config-all.json', { + status: 200, + body: JSON.stringify({ + config: { + data: { + domainkey: 'foo/bar/baz', + cdn: { + prod: { + host: 'adobe.com', + }, + }, + }, + }, + }), + headers: new Map(), + }), + }); + + const response = await optionsPipe( + state, + createRequest({ + 'x-forwarded-host': 'example.com', + }, '/_rum-challenge'), + ); + + assert.strictEqual(response.status, 204); + const challenge = response.headers.get('x-rum-challenge'); + // assert that the challenge is unsetset + assert.strictEqual(challenge, undefined); + }); + + it('sends 204 with x-rum-challenge header for rum-challenge requests', async () => { + const state = new PipelineState({ + owner: 'owner', + repo: 'repo', + ref: 'ref', + partition: 'live', + path: '/somepath/workbook', + log: console, + s3Loader: new StaticS3Loader() + .reply( + 'helix-code-bus', + 'owner/repo/ref/helix-config.json', + new PipelineResponse(HELIX_CONFIG_JSON), + ) + .reply('helix-content-bus', 'foobus/live/.helix/config-all.json', { + status: 200, + body: JSON.stringify({ + config: { + data: { + domainkey: 'foo/bar/baz', + cdn: { + prod: { + host: 'example.com', + }, + }, + }, + }, + }), + headers: new Map(), + }), + }); + + const response = await optionsPipe( + state, + createRequest({ + 'x-forwarded-host': 'example.com', + }, '/_rum-challenge'), + ); + + assert.strictEqual(response.status, 204); + const challenge = response.headers.get('x-rum-challenge'); + // assert that the challenge is set + assert.strictEqual(challenge, '7263bf25ef81b7a406a1bea7f367d553441c420678fc74726a7a8f9f63b8d5a7'); + }); + + it('sends 204 with x-rum-challenge header for rum-challenge requests wit array of domainkeys', async () => { + const state = new PipelineState({ + owner: 'owner', + repo: 'repo', + ref: 'ref', + partition: 'live', + path: '/somepath/workbook', + log: console, + s3Loader: new StaticS3Loader() + .reply( + 'helix-code-bus', + 'owner/repo/ref/helix-config.json', + new PipelineResponse(HELIX_CONFIG_JSON), + ) + .reply('helix-content-bus', 'foobus/live/.helix/config-all.json', { + status: 200, + body: JSON.stringify({ + config: { + data: { + domainkey: ['foo/bar/baz', 'bar/baz/foo'], + cdn: { + prod: { + host: 'example.com', + }, + }, + }, + }, + }), + headers: new Map(), + }), + }); + + const response = await optionsPipe( + state, + createRequest({ + 'x-forwarded-host': 'example.com', + }, '/_rum-challenge'), + ); + + assert.strictEqual(response.status, 204); + const challenge = response.headers.get('x-rum-challenge'); + // assert that the challenge is set + assert.strictEqual(challenge, '7263bf25ef81b7a406a1bea7f367d553441c420678fc74726a7a8f9f63b8d5a7 de6b5c08a3d9257e699400a1de13958364a34b2ccd4dd9ea204926e9740327c4'); + }); + + it('sends 204 with x-rum-challenge header for rum-challenge requests, falling back to Slack if unset', async () => { + const state = new PipelineState({ + owner: 'owner', + repo: 'repo', + ref: 'ref', + partition: 'live', + path: '/somepath/workbook', + log: console, + s3Loader: new StaticS3Loader() + .reply( + 'helix-code-bus', + 'owner/repo/ref/helix-config.json', + new PipelineResponse(HELIX_CONFIG_JSON), + ) + .reply('helix-content-bus', 'foobus/live/.helix/config-all.json', { + status: 200, + body: JSON.stringify({ + config: { + data: { + slack: 'foo/bar/baz', + cdn: { + prod: { + host: 'example.com', + }, + }, + }, + }, + }), + headers: new Map(), + }), + }); + + const response = await optionsPipe( + state, + createRequest({ + 'x-forwarded-host': 'example.com', + }, '/_rum-challenge'), + ); + + assert.strictEqual(response.status, 204); + const challenge = response.headers.get('x-rum-challenge'); + // assert that the challenge is set + assert.strictEqual(challenge, '7263bf25ef81b7a406a1bea7f367d553441c420678fc74726a7a8f9f63b8d5a7'); + }); +});