mirror of
https://github.com/CommunitySolidServer/CommunitySolidServer.git
synced 2024-10-03 14:55:10 +00:00
84 lines
3.9 KiB
TypeScript
84 lines
3.9 KiB
TypeScript
import { BasicRepresentation } from '../../../../src/ldp/representation/BasicRepresentation';
|
|
import type { Representation } from '../../../../src/ldp/representation/Representation';
|
|
import type { ResourceIdentifier } from '../../../../src/ldp/representation/ResourceIdentifier';
|
|
import { JsonResourceStorage } from '../../../../src/storage/keyvalue/JsonResourceStorage';
|
|
import type { ResourceStore } from '../../../../src/storage/ResourceStore';
|
|
import { NotFoundHttpError } from '../../../../src/util/errors/NotFoundHttpError';
|
|
import { NotImplementedHttpError } from '../../../../src/util/errors/NotImplementedHttpError';
|
|
import { readableToString } from '../../../../src/util/StreamUtil';
|
|
|
|
describe('A JsonResourceStorage', (): void => {
|
|
const identifier1: ResourceIdentifier = { path: 'http://test.com/foo' };
|
|
const identifier2: ResourceIdentifier = { path: 'http://test.com/bar' };
|
|
let store: ResourceStore;
|
|
let storage: JsonResourceStorage;
|
|
|
|
beforeEach(async(): Promise<void> => {
|
|
const data: Record<string, string> = { };
|
|
store = {
|
|
async getRepresentation(identifier: ResourceIdentifier): Promise<Representation> {
|
|
if (!data[identifier.path]) {
|
|
throw new NotFoundHttpError();
|
|
} else {
|
|
return new BasicRepresentation(data[identifier.path], identifier);
|
|
}
|
|
},
|
|
async setRepresentation(identifier: ResourceIdentifier, representation: Representation): Promise<void> {
|
|
data[identifier.path] = await readableToString(representation.data);
|
|
},
|
|
async deleteResource(identifier: ResourceIdentifier): Promise<void> {
|
|
if (!data[identifier.path]) {
|
|
throw new NotFoundHttpError();
|
|
}
|
|
// eslint-disable-next-line @typescript-eslint/no-dynamic-delete
|
|
delete data[identifier.path];
|
|
},
|
|
} as any;
|
|
|
|
storage = new JsonResourceStorage(store);
|
|
});
|
|
|
|
it('returns undefined if there is no matching data.', async(): Promise<void> => {
|
|
await expect(storage.get(identifier1)).resolves.toBeUndefined();
|
|
});
|
|
|
|
it('returns data if it was set beforehand.', async(): Promise<void> => {
|
|
await expect(storage.set(identifier1, 'apple')).resolves.toBe(storage);
|
|
await expect(storage.get(identifier1)).resolves.toBe('apple');
|
|
expect(storage.entries).toThrow(NotImplementedHttpError);
|
|
});
|
|
|
|
it('can check if data is present.', async(): Promise<void> => {
|
|
await expect(storage.has(identifier1)).resolves.toBe(false);
|
|
await expect(storage.set(identifier1, 'apple')).resolves.toBe(storage);
|
|
await expect(storage.has(identifier1)).resolves.toBe(true);
|
|
});
|
|
|
|
it('can delete data.', async(): Promise<void> => {
|
|
await expect(storage.has(identifier1)).resolves.toBe(false);
|
|
await expect(storage.delete(identifier1)).resolves.toBe(false);
|
|
await expect(storage.has(identifier1)).resolves.toBe(false);
|
|
await expect(storage.set(identifier1, 'apple')).resolves.toBe(storage);
|
|
await expect(storage.has(identifier1)).resolves.toBe(true);
|
|
await expect(storage.delete(identifier1)).resolves.toBe(true);
|
|
await expect(storage.has(identifier1)).resolves.toBe(false);
|
|
});
|
|
|
|
it('can handle multiple identifiers.', async(): Promise<void> => {
|
|
await expect(storage.set(identifier1, 'apple')).resolves.toBe(storage);
|
|
await expect(storage.has(identifier1)).resolves.toBe(true);
|
|
await expect(storage.has(identifier2)).resolves.toBe(false);
|
|
await expect(storage.set(identifier2, 'pear')).resolves.toBe(storage);
|
|
await expect(storage.get(identifier1)).resolves.toBe('apple');
|
|
});
|
|
|
|
it('re-throws errors thrown by the store.', async(): Promise<void> => {
|
|
store.getRepresentation = jest.fn().mockRejectedValue(new Error('bad GET'));
|
|
await expect(storage.get(identifier1)).rejects.toThrow('bad GET');
|
|
await expect(storage.has(identifier1)).rejects.toThrow('bad GET');
|
|
|
|
store.deleteResource = jest.fn().mockRejectedValue(new Error('bad DELETE'));
|
|
await expect(storage.delete(identifier1)).rejects.toThrow('bad DELETE');
|
|
});
|
|
});
|