|
|
|
|
@@ -265,7 +265,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
representation.metadata.add(RDF.terms.type, LDP.terms.Container);
|
|
|
|
|
const result = await store.addResource(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
|
|
|
|
|
const generatedID = [ ...result.keys() ].find((id): boolean => id.path !== resourceID.path)!;
|
|
|
|
|
expect(generatedID).toBeDefined();
|
|
|
|
|
@@ -278,7 +278,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
const result = await store.addResource(resourceID, representation);
|
|
|
|
|
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
|
|
|
|
|
const generatedID = [ ...result.keys() ].find((id): boolean => id.path !== resourceID.path)!;
|
|
|
|
|
expect(generatedID).toBeDefined();
|
|
|
|
|
@@ -287,7 +287,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
expect(accessor.data[generatedID.path]).toBeDefined();
|
|
|
|
|
await expect(arrayifyStream(accessor.data[generatedID.path].data)).resolves.toEqual([ resourceData ]);
|
|
|
|
|
expect(accessor.data[generatedID.path].metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
expect(result.get(generatedID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(generatedID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('can write containers.', async(): Promise<void> => {
|
|
|
|
|
@@ -296,7 +296,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
const result = await store.addResource(resourceID, representation);
|
|
|
|
|
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
|
|
|
|
|
const generatedID = [ ...result.keys() ].find((id): boolean => id.path !== resourceID.path)!;
|
|
|
|
|
expect(generatedID).toBeDefined();
|
|
|
|
|
@@ -304,7 +304,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
|
|
|
|
|
expect(accessor.data[generatedID.path]).toBeDefined();
|
|
|
|
|
expect(accessor.data[generatedID.path].metadata.contentType).toBeUndefined();
|
|
|
|
|
expect(result.get(generatedID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(generatedID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
|
|
|
|
|
const { metadata } = await store.getRepresentation(generatedID);
|
|
|
|
|
expect(metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
@@ -317,8 +317,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
|
|
|
|
|
const result = await store.addResource(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get({ path: `${root}newName` })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get({ path: `${root}newName` })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('errors on a slug ending on / without Link rel:type Container header.', async(): Promise<void> => {
|
|
|
|
|
@@ -342,8 +342,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
|
|
|
|
|
const result = await store.addResource(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get({ path: `${root}newContainer/` })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get({ path: `${root}newContainer/` })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('generates a new URI if adding the slug would create an existing URI.', async(): Promise<void> => {
|
|
|
|
|
@@ -366,8 +366,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
|
|
|
|
|
const result = await store.addResource(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get({ path: `${root}%26%26` })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get({ path: `${root}%26%26` })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('errors if the slug contains a slash.', async(): Promise<void> => {
|
|
|
|
|
@@ -434,7 +434,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
|
|
|
|
|
const result = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(1);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(mock).toHaveBeenCalledTimes(1);
|
|
|
|
|
expect(mock).toHaveBeenLastCalledWith(resourceID);
|
|
|
|
|
|
|
|
|
|
@@ -459,8 +459,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
const resourceID = { path: `${root}resource` };
|
|
|
|
|
const result = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
await expect(arrayifyStream(accessor.data[resourceID.path].data)).resolves.toEqual([ resourceData ]);
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
expect(accessor.data[root].metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
@@ -476,8 +476,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
representation.data = guardedStreamFrom([ `<${root}resource/> a <coolContainer>.` ]);
|
|
|
|
|
const result = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(accessor.data[resourceID.path]).toBeTruthy();
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.contentType).toBeUndefined();
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
@@ -489,8 +489,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
const resourceID = { path: `${root}resource` };
|
|
|
|
|
const result = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
await expect(arrayifyStream(accessor.data[resourceID.path].data)).resolves.toEqual([ resourceData ]);
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
expect(accessor.data[root].metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
@@ -500,7 +500,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
mockDate.mockReturnValue(later);
|
|
|
|
|
const result2 = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result2.size).toBe(1);
|
|
|
|
|
expect(result2.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result2.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
await expect(arrayifyStream(accessor.data[resourceID.path].data)).resolves.toEqual([ 'updatedText' ]);
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.get(DC.terms.modified)?.value).toBe(later.toISOString());
|
|
|
|
|
expect(accessor.data[root].metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
@@ -513,8 +513,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
representation.metadata.add(namedNode('gen'), 'value', SOLID_META.terms.ResponseMetadata);
|
|
|
|
|
const result = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
await expect(arrayifyStream(accessor.data[resourceID.path].data)).resolves.toEqual([ resourceData ]);
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.get(namedNode('notGen'))?.value).toBe('value');
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.get(namedNode('gen'))).toBeUndefined();
|
|
|
|
|
@@ -526,8 +526,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
const resourceID = { path: `${root}resource` };
|
|
|
|
|
const result = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
await expect(arrayifyStream(accessor.data[resourceID.path].data)).resolves.toEqual([ resourceData ]);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
@@ -535,10 +535,10 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
const resourceID = { path: `${root}a/b/resource` };
|
|
|
|
|
const result = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(4);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get({ path: `${root}a/` })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: `${root}a/b/` })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: `${root}a/b/resource` })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get({ path: `${root}a/` })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: `${root}a/b/` })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get({ path: `${root}a/b/resource` })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
await expect(arrayifyStream(accessor.data[resourceID.path].data)).resolves.toEqual([ resourceData ]);
|
|
|
|
|
expect(accessor.data[`${root}a/`].metadata.getAll(RDF.terms.type).map((type): string => type.value))
|
|
|
|
|
.toContain(LDP.Container);
|
|
|
|
|
@@ -565,7 +565,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
representation.data = guardedStreamFrom([]);
|
|
|
|
|
const result = await store.setRepresentation(resourceID, representation);
|
|
|
|
|
expect(result.size).toBe(1);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Create);
|
|
|
|
|
expect(accessor.data[resourceID.path]).toBeTruthy();
|
|
|
|
|
expect(Object.keys(accessor.data)).toHaveLength(1);
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.contentType).toBeUndefined();
|
|
|
|
|
@@ -583,7 +583,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
) ], resourceID);
|
|
|
|
|
|
|
|
|
|
const result = await store.setRepresentation(metaResourceID, metaRepresentation);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.quads()).toBeRdfIsomorphic([
|
|
|
|
|
quad(
|
|
|
|
|
namedNode(resourceID.path),
|
|
|
|
|
@@ -606,7 +606,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
const metaRepresentation = new BasicRepresentation(guardedStreamFrom(quads), resourceID, INTERNAL_QUADS);
|
|
|
|
|
|
|
|
|
|
const result = await store.setRepresentation(metaResourceID, metaRepresentation);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(accessor.data[resourceID.path].metadata.quads()).toBeRdfIsomorphic(quads);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
@@ -770,8 +770,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
accessor.data[resourceID.path] = representation;
|
|
|
|
|
const result = await store.deleteResource(resourceID);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(accessor.data[resourceID.path]).toBeUndefined();
|
|
|
|
|
expect(accessor.data[root].metadata.get(DC.terms.modified)?.value).toBe(now.toISOString());
|
|
|
|
|
expect(accessor.data[root].metadata.get(GENERATED_PREDICATE)).toBeUndefined();
|
|
|
|
|
@@ -781,7 +781,7 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
accessor.data[root] = new BasicRepresentation(representation.data, containerMetadata);
|
|
|
|
|
const result = await store.deleteResource({ path: root });
|
|
|
|
|
expect(result.size).toBe(1);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(accessor.data[root]).toBeUndefined();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
@@ -794,8 +794,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
auxiliaryStrategy.isRequiredInRoot = jest.fn().mockReturnValue(true);
|
|
|
|
|
const result = await store.deleteResource(auxResourceID);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(auxResourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(auxResourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(accessor.data[auxResourceID.path]).toBeUndefined();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
@@ -807,9 +807,9 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
|
|
|
|
|
const result = await store.deleteResource(resourceID);
|
|
|
|
|
expect(result.size).toBe(3);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(result.get(auxResourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(result.get(auxResourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(accessor.data[resourceID.path]).toBeUndefined();
|
|
|
|
|
expect(accessor.data[auxResourceID.path]).toBeUndefined();
|
|
|
|
|
});
|
|
|
|
|
@@ -830,8 +830,8 @@ describe('A DataAccessorBasedStore', (): void => {
|
|
|
|
|
logger.error = jest.fn();
|
|
|
|
|
const result = await store.deleteResource(resourceID);
|
|
|
|
|
expect(result.size).toBe(2);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.Activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(result.get({ path: root })?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Update);
|
|
|
|
|
expect(result.get(resourceID)?.get(SOLID_AS.terms.activity)).toEqual(AS.terms.Delete);
|
|
|
|
|
expect(accessor.data[resourceID.path]).toBeUndefined();
|
|
|
|
|
expect(accessor.data[auxResourceID.path]).toBeDefined();
|
|
|
|
|
expect(logger.error).toHaveBeenCalledTimes(1);
|
|
|
|
|
|