Skip to content

Commit

Permalink
chore: add unit tests
Browse files Browse the repository at this point in the history
  • Loading branch information
HuiSF committed Aug 28, 2024
1 parent 2fe22d9 commit ff83a83
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -412,6 +412,41 @@ describe('createCookieStorageAdapterFromNextServerContext', () => {
'key3=;Expires=Thu, 01 Jan 1970 00:00:00 GMT',
]);
});

it('does not add duplicate cookies when the cookies are defined in the response Set-Cookie headers', () => {
const mockExistingSetCookieValues = [
'CognitoIdentityServiceProvider.1234.accessToken=1234;Path=/',
'CognitoIdentityServiceProvider.1234.refreshToken=1234;Path=/',
'CognitoIdentityServiceProvider.1234.identityId=;Expires=Thu, 01 Jan 1970 00:00:00 GMT',
];

const request = new IncomingMessage(new Socket());
const response = new ServerResponse(request);
const appendHeaderSpy = jest.spyOn(response, 'appendHeader');
const getHeaderSpy = jest.spyOn(response, 'getHeader');

Object.defineProperty(request, 'cookies', {
get() {
return {};
},
});

getHeaderSpy.mockReturnValue(mockExistingSetCookieValues);

const result = createCookieStorageAdapterFromNextServerContext({
request: request as any,
response,
});

result.set('CognitoIdentityServiceProvider.1234.accessToken', '5678');
expect(appendHeaderSpy).not.toHaveBeenCalled();

result.set('CognitoIdentityServiceProvider.1234.refreshToken', '5678');
expect(appendHeaderSpy).not.toHaveBeenCalled();

result.delete('CognitoIdentityServiceProvider.1234.identityId');
expect(appendHeaderSpy).not.toHaveBeenCalled();
});
});

it('should throw error when no cookie storage adapter is created from the context', () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -173,12 +173,13 @@ const createCookieStorageAdapterFromGetServerSidePropsContext = (
set(name, value, options) {
const encodedName = ensureEncodedForJSCookie(name);

const existingSetCookieValues = response.getHeader('Set-Cookie');
const existingValues = getExistingSetCookieValues(
response.getHeader('Set-Cookie'),
);

// if the cookies have already been set, we don't need to set them again.
if (
Array.isArray(existingSetCookieValues) &&
existingSetCookieValues.findIndex(
existingValues.findIndex(
cookieValue =>
cookieValue.startsWith(`${encodedName}=`) &&
!cookieValue.startsWith(`${encodedName}=;`),
Expand All @@ -187,25 +188,23 @@ const createCookieStorageAdapterFromGetServerSidePropsContext = (
return;
}

const setCookieValue = `${encodedName}=${value};${
options ? serializeSetCookieOptions(options) : ''
}`;

response.appendHeader('Set-Cookie', setCookieValue);
response.appendHeader(
'Set-Cookie',
`${encodedName}=${value};${
options ? serializeSetCookieOptions(options) : ''
}`,
);
},
delete(name) {
const encodedName = ensureEncodedForJSCookie(name);
const setCookieValue = `${encodedName}=;Expires=${DATE_IN_THE_PAST.toUTCString()}`;
const existingSetCookieValues = response.getHeader('Set-Cookie');
const existingValues = getExistingSetCookieValues(
response.getHeader('Set-Cookie'),
);

// if the value for cookie deletion is already in the Set-Cookie header, we
// don't need to add the deletion value again.
if (
(typeof existingSetCookieValues === 'string' &&
existingSetCookieValues === setCookieValue) ||
(Array.isArray(existingSetCookieValues) &&
existingSetCookieValues.includes(setCookieValue))
) {
if (existingValues.includes(setCookieValue)) {
return;
}

Expand Down Expand Up @@ -275,3 +274,8 @@ const serializeSetCookieOptions = (
// we are not using those chars in the auth keys.
const ensureEncodedForJSCookie = (name: string): string =>
encodeURIComponent(name).replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent);

const getExistingSetCookieValues = (
values: number | string | string[] | undefined,
): string[] =>
values === undefined ? [] : Array.isArray(values) ? values : [String(values)];

0 comments on commit ff83a83

Please sign in to comment.