mirror of
https://github.com/CommunitySolidServer/CommunitySolidServer.git
synced 2024-10-03 14:55:10 +00:00

The previous package was outdated, preventing us from updating TS. This one also lints YAML and JSON, and applies many more rules to the test files, explaining all the changes in this PR.
98 lines
4.3 KiB
TypeScript
98 lines
4.3 KiB
TypeScript
import {
|
|
CreateClientCredentialsHandler,
|
|
} from '../../../../../src/identity/interaction/client-credentials/CreateClientCredentialsHandler';
|
|
import type {
|
|
ClientCredentialsIdRoute,
|
|
} from '../../../../../src/identity/interaction/client-credentials/util/ClientCredentialsIdRoute';
|
|
import type {
|
|
ClientCredentials,
|
|
ClientCredentialsStore,
|
|
} from '../../../../../src/identity/interaction/client-credentials/util/ClientCredentialsStore';
|
|
import type { WebIdStore } from '../../../../../src/identity/interaction/webid/util/WebIdStore';
|
|
import { BadRequestHttpError } from '../../../../../src/util/errors/BadRequestHttpError';
|
|
|
|
const uuid = '4c9b88c1-7502-4107-bb79-2a3a590c7aa3';
|
|
jest.mock('uuid', (): any => ({ v4: (): string => uuid }));
|
|
|
|
describe('A CreateClientCredentialsHandler', (): void => {
|
|
const webId = 'http://example.com/card#me';
|
|
const id = 'id';
|
|
const accountId = 'accountId;';
|
|
const label = 'token_123';
|
|
const secret = 'secret!';
|
|
const token: ClientCredentials = { id, label, secret, accountId, webId };
|
|
const resource = 'http://example.com/token';
|
|
const json = { webId, name: 'token' };
|
|
let route: jest.Mocked<ClientCredentialsIdRoute>;
|
|
let webIdStore: jest.Mocked<WebIdStore>;
|
|
let clientCredentialsStore: jest.Mocked<ClientCredentialsStore>;
|
|
let handler: CreateClientCredentialsHandler;
|
|
|
|
beforeEach(async(): Promise<void> => {
|
|
route = {
|
|
getPath: jest.fn().mockReturnValue(resource),
|
|
matchPath: jest.fn().mockReturnValue({ accountId, clientCredentialsId: id }),
|
|
};
|
|
|
|
webIdStore = {
|
|
isLinked: jest.fn().mockResolvedValue(true),
|
|
} satisfies Partial<WebIdStore> as any;
|
|
|
|
clientCredentialsStore = {
|
|
create: jest.fn().mockResolvedValue({ id, secret }),
|
|
findByAccount: jest.fn().mockResolvedValue([ token ]),
|
|
} satisfies Partial<ClientCredentialsStore> as any;
|
|
|
|
handler = new CreateClientCredentialsHandler(webIdStore, clientCredentialsStore, route);
|
|
});
|
|
|
|
it('shows the required fields and known tokens.', async(): Promise<void> => {
|
|
await expect(handler.getView({ accountId } as any)).resolves.toEqual({
|
|
json: {
|
|
clientCredentials: {
|
|
[label]: resource,
|
|
},
|
|
fields: {
|
|
name: { required: false, type: 'string' },
|
|
webId: { required: true, type: 'string' },
|
|
},
|
|
},
|
|
});
|
|
expect(clientCredentialsStore.findByAccount).toHaveBeenCalledTimes(1);
|
|
expect(clientCredentialsStore.findByAccount).toHaveBeenLastCalledWith(accountId);
|
|
});
|
|
|
|
it('creates a new token based on the provided settings.', async(): Promise<void> => {
|
|
await expect(handler.handle({ accountId, json } as any)).resolves.toEqual({
|
|
json: { id: 'token_4c9b88c1-7502-4107-bb79-2a3a590c7aa3', secret, resource },
|
|
});
|
|
expect(webIdStore.isLinked).toHaveBeenCalledTimes(1);
|
|
expect(webIdStore.isLinked).toHaveBeenLastCalledWith(webId, accountId);
|
|
expect(clientCredentialsStore.create).toHaveBeenCalledTimes(1);
|
|
expect(clientCredentialsStore.create).toHaveBeenLastCalledWith(`${json.name}_${uuid}`, webId, accountId);
|
|
expect(route.getPath).toHaveBeenCalledTimes(1);
|
|
expect(route.getPath).toHaveBeenLastCalledWith({ accountId, clientCredentialsId: id });
|
|
});
|
|
|
|
it('allows token names to be empty.', async(): Promise<void> => {
|
|
await expect(handler.handle({ accountId, json: { webId }} as any))
|
|
.resolves.toEqual({
|
|
json: { id: '_4c9b88c1-7502-4107-bb79-2a3a590c7aa3', secret, resource },
|
|
});
|
|
expect(webIdStore.isLinked).toHaveBeenCalledTimes(1);
|
|
expect(webIdStore.isLinked).toHaveBeenLastCalledWith(webId, accountId);
|
|
expect(clientCredentialsStore.create).toHaveBeenCalledTimes(1);
|
|
expect(clientCredentialsStore.create).toHaveBeenLastCalledWith(`_${uuid}`, webId, accountId);
|
|
expect(route.getPath).toHaveBeenCalledTimes(1);
|
|
expect(route.getPath).toHaveBeenLastCalledWith({ accountId, clientCredentialsId: id });
|
|
});
|
|
|
|
it('errors if the account is not the owner of the WebID.', async(): Promise<void> => {
|
|
webIdStore.isLinked.mockResolvedValueOnce(false);
|
|
await expect(handler.handle({ accountId, json } as any)).rejects.toThrow(BadRequestHttpError);
|
|
expect(webIdStore.isLinked).toHaveBeenCalledTimes(1);
|
|
expect(webIdStore.isLinked).toHaveBeenLastCalledWith(webId, accountId);
|
|
expect(clientCredentialsStore.create).toHaveBeenCalledTimes(0);
|
|
});
|
|
});
|