feat: Update Credentials typings to support client/issuer

This commit is contained in:
Joachim Van Herwegen
2022-08-19 14:11:20 +02:00
parent 40f2c8ea42
commit f3e7a20800
48 changed files with 286 additions and 249 deletions

View File

@@ -1,12 +1,11 @@
import { CredentialGroup } from '../../../src/authentication/Credentials';
import type { CredentialSet } from '../../../src/authentication/Credentials';
import type { Credentials } from '../../../src/authentication/Credentials';
import type { CredentialsExtractor } from '../../../src/authentication/CredentialsExtractor';
import { UnionCredentialsExtractor } from '../../../src/authentication/UnionCredentialsExtractor';
import type { HttpRequest } from '../../../src/server/HttpRequest';
describe('A UnionCredentialsExtractor', (): void => {
const agent: CredentialSet = { [CredentialGroup.agent]: { webId: 'http://test.com/#me' }};
const everyone: CredentialSet = { [CredentialGroup.public]: {}};
const agent: Credentials = { agent: { webId: 'http://user.example.com/#me' }};
const client: Credentials = { client: { clientId: 'http://client.example.com/#me' }};
const request: HttpRequest = {} as any;
let extractors: jest.Mocked<CredentialsExtractor>[];
let extractor: UnionCredentialsExtractor;
@@ -19,7 +18,7 @@ describe('A UnionCredentialsExtractor', (): void => {
} as any,
{
canHandle: jest.fn(),
handle: jest.fn().mockResolvedValue(everyone),
handle: jest.fn().mockResolvedValue(client),
} as any,
];
@@ -28,26 +27,26 @@ describe('A UnionCredentialsExtractor', (): void => {
it('combines the results of the extractors.', async(): Promise<void> => {
await expect(extractor.handle(request)).resolves.toEqual({
[CredentialGroup.agent]: agent.agent,
[CredentialGroup.public]: {},
agent: agent.agent,
client: client.client,
});
});
it('ignores undefined values.', async(): Promise<void> => {
extractors[1].handle.mockResolvedValueOnce({
[CredentialGroup.public]: {},
[CredentialGroup.agent]: undefined,
client: client.client,
agent: undefined,
});
await expect(extractor.handle(request)).resolves.toEqual({
[CredentialGroup.agent]: agent.agent,
[CredentialGroup.public]: {},
agent: agent.agent,
client: client.client,
});
});
it('skips erroring handlers.', async(): Promise<void> => {
extractors[0].handle.mockRejectedValueOnce(new Error('error'));
await expect(extractor.handle(request)).resolves.toEqual({
[CredentialGroup.public]: {},
client: client.client,
});
});
});