mirror of
https://github.com/CommunitySolidServer/CommunitySolidServer.git
synced 2024-10-03 14:55:10 +00:00
feat: Integrate MetadataSerializer
This commit is contained in:
parent
aebccd45c0
commit
4e4d7a7a39
@ -1,6 +1,34 @@
|
|||||||
{
|
{
|
||||||
"@context": "https://linkedsoftwaredependencies.org/bundles/npm/@solid/community-server/^1.0.0/components/context.jsonld",
|
"@context": "https://linkedsoftwaredependencies.org/bundles/npm/@solid/community-server/^1.0.0/components/context.jsonld",
|
||||||
"@graph": [
|
"@graph": [
|
||||||
|
{
|
||||||
|
"@id": "urn:solid-server:default:MetadataSerializer",
|
||||||
|
"@type": "AllVoidCompositeHandler",
|
||||||
|
"AllVoidCompositeHandler:_handlers": [
|
||||||
|
{
|
||||||
|
"@type": "MappedMetadataWriter",
|
||||||
|
"MappedMetadataWriter:_headerMap": [
|
||||||
|
{
|
||||||
|
"MappedMetadataWriter:_headerMap_key": "http://www.w3.org/ns/ma-ont#format",
|
||||||
|
"MappedMetadataWriter:_headerMap_value": "content-type"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"MappedMetadataWriter:_headerMap_key": "urn:solid:http:location",
|
||||||
|
"MappedMetadataWriter:_headerMap_value": "location"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"@type": "LinkRelMetadataWriter",
|
||||||
|
"LinkRelMetadataWriter:_headerMap": [
|
||||||
|
{
|
||||||
|
"LinkRelMetadataWriter:_headerMap_key": "http://www.w3.org/1999/02/22-rdf-syntax-ns#type",
|
||||||
|
"LinkRelMetadataWriter:_headerMap_value": "type"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"@id": "urn:solid-server:default:ResponseWriter",
|
"@id": "urn:solid-server:default:ResponseWriter",
|
||||||
"@type": "FirstCompositeHandler",
|
"@type": "FirstCompositeHandler",
|
||||||
@ -9,7 +37,10 @@
|
|||||||
"@type": "ErrorResponseWriter"
|
"@type": "ErrorResponseWriter"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"@type": "BasicResponseWriter"
|
"@type": "BasicResponseWriter",
|
||||||
|
"BasicResponseWriter:_metadataWriter": {
|
||||||
|
"@id": "urn:solid-server:default:MetadataSerializer"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
3
index.ts
3
index.ts
@ -17,9 +17,12 @@ export * from './src/init/Setup';
|
|||||||
// LDP/HTTP/Metadata
|
// LDP/HTTP/Metadata
|
||||||
export * from './src/ldp/http/metadata/BasicMetadataExtractor';
|
export * from './src/ldp/http/metadata/BasicMetadataExtractor';
|
||||||
export * from './src/ldp/http/metadata/ContentTypeParser';
|
export * from './src/ldp/http/metadata/ContentTypeParser';
|
||||||
|
export * from './src/ldp/http/metadata/LinkRelMetadataWriter';
|
||||||
export * from './src/ldp/http/metadata/LinkTypeParser';
|
export * from './src/ldp/http/metadata/LinkTypeParser';
|
||||||
|
export * from './src/ldp/http/metadata/MappedMetadataWriter';
|
||||||
export * from './src/ldp/http/metadata/MetadataExtractor';
|
export * from './src/ldp/http/metadata/MetadataExtractor';
|
||||||
export * from './src/ldp/http/metadata/MetadataParser';
|
export * from './src/ldp/http/metadata/MetadataParser';
|
||||||
|
export * from './src/ldp/http/metadata/MetadataWriter';
|
||||||
export * from './src/ldp/http/metadata/SlugParser';
|
export * from './src/ldp/http/metadata/SlugParser';
|
||||||
|
|
||||||
// LDP/HTTP/Response
|
// LDP/HTTP/Response
|
||||||
|
@ -2,7 +2,7 @@ import { getLoggerFor } from '../../logging/LogUtil';
|
|||||||
import type { HttpResponse } from '../../server/HttpResponse';
|
import type { HttpResponse } from '../../server/HttpResponse';
|
||||||
import { INTERNAL_QUADS } from '../../util/ContentTypes';
|
import { INTERNAL_QUADS } from '../../util/ContentTypes';
|
||||||
import { UnsupportedHttpError } from '../../util/errors/UnsupportedHttpError';
|
import { UnsupportedHttpError } from '../../util/errors/UnsupportedHttpError';
|
||||||
import { HTTP } from '../../util/UriConstants';
|
import type { MetadataWriter } from './metadata/MetadataWriter';
|
||||||
import type { ResponseDescription } from './response/ResponseDescription';
|
import type { ResponseDescription } from './response/ResponseDescription';
|
||||||
import { ResponseWriter } from './ResponseWriter';
|
import { ResponseWriter } from './ResponseWriter';
|
||||||
|
|
||||||
@ -11,6 +11,12 @@ import { ResponseWriter } from './ResponseWriter';
|
|||||||
*/
|
*/
|
||||||
export class BasicResponseWriter extends ResponseWriter {
|
export class BasicResponseWriter extends ResponseWriter {
|
||||||
protected readonly logger = getLoggerFor(this);
|
protected readonly logger = getLoggerFor(this);
|
||||||
|
private readonly metadataWriter: MetadataWriter;
|
||||||
|
|
||||||
|
public constructor(metadataWriter: MetadataWriter) {
|
||||||
|
super();
|
||||||
|
this.metadataWriter = metadataWriter;
|
||||||
|
}
|
||||||
|
|
||||||
public async canHandle(input: { response: HttpResponse; result: ResponseDescription | Error }): Promise<void> {
|
public async canHandle(input: { response: HttpResponse; result: ResponseDescription | Error }): Promise<void> {
|
||||||
if (input.result instanceof Error || input.result.metadata?.contentType === INTERNAL_QUADS) {
|
if (input.result instanceof Error || input.result.metadata?.contentType === INTERNAL_QUADS) {
|
||||||
@ -20,13 +26,8 @@ export class BasicResponseWriter extends ResponseWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public async handle(input: { response: HttpResponse; result: ResponseDescription }): Promise<void> {
|
public async handle(input: { response: HttpResponse; result: ResponseDescription }): Promise<void> {
|
||||||
const location = input.result.metadata?.get(HTTP.location);
|
if (input.result.metadata) {
|
||||||
if (location) {
|
await this.metadataWriter.handleSafe({ response: input.response, metadata: input.result.metadata });
|
||||||
input.response.setHeader('location', location.value);
|
|
||||||
}
|
|
||||||
if (input.result.data) {
|
|
||||||
const contentType = input.result.metadata?.contentType ?? 'text/plain';
|
|
||||||
input.response.setHeader('content-type', contentType);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
input.response.writeHead(input.result.statusCode);
|
input.response.writeHead(input.result.statusCode);
|
||||||
|
@ -11,20 +11,22 @@ import type {
|
|||||||
OperationHandler,
|
OperationHandler,
|
||||||
} from '../../index';
|
} from '../../index';
|
||||||
import {
|
import {
|
||||||
AcceptPreferenceParser,
|
AcceptPreferenceParser, AllVoidCompositeHandler,
|
||||||
BasicMetadataExtractor,
|
BasicMetadataExtractor,
|
||||||
BasicRequestParser,
|
BasicRequestParser,
|
||||||
BasicResponseWriter,
|
BasicResponseWriter,
|
||||||
BasicTargetExtractor,
|
BasicTargetExtractor,
|
||||||
FirstCompositeHandler,
|
|
||||||
ContentTypeParser,
|
ContentTypeParser,
|
||||||
DataAccessorBasedStore,
|
DataAccessorBasedStore,
|
||||||
DeleteOperationHandler,
|
DeleteOperationHandler,
|
||||||
ErrorResponseWriter,
|
ErrorResponseWriter,
|
||||||
|
FirstCompositeHandler,
|
||||||
GetOperationHandler,
|
GetOperationHandler,
|
||||||
HeadOperationHandler,
|
HeadOperationHandler,
|
||||||
InMemoryDataAccessor,
|
InMemoryDataAccessor,
|
||||||
|
LinkRelMetadataWriter,
|
||||||
LinkTypeParser,
|
LinkTypeParser,
|
||||||
|
MappedMetadataWriter,
|
||||||
MetadataController,
|
MetadataController,
|
||||||
PatchingStore,
|
PatchingStore,
|
||||||
PatchOperationHandler,
|
PatchOperationHandler,
|
||||||
@ -39,6 +41,7 @@ import {
|
|||||||
UrlContainerManager,
|
UrlContainerManager,
|
||||||
WebAclAuthorizer,
|
WebAclAuthorizer,
|
||||||
} from '../../index';
|
} from '../../index';
|
||||||
|
import { CONTENT_TYPE, HTTP, RDF } from '../../src/util/UriConstants';
|
||||||
|
|
||||||
export const BASE = 'http://test.com';
|
export const BASE = 'http://test.com';
|
||||||
|
|
||||||
@ -118,12 +121,23 @@ export const getOperationHandler = (store: ResourceStore): OperationHandler => {
|
|||||||
return new FirstCompositeHandler<Operation, ResponseDescription>(handlers);
|
return new FirstCompositeHandler<Operation, ResponseDescription>(handlers);
|
||||||
};
|
};
|
||||||
|
|
||||||
export const getResponseWriter = (): ResponseWriter =>
|
export const getResponseWriter = (): ResponseWriter => {
|
||||||
new FirstCompositeHandler<{ response: HttpResponse; result: ResponseDescription | Error }, void>([
|
const serializer = new AllVoidCompositeHandler([
|
||||||
new ErrorResponseWriter(),
|
new MappedMetadataWriter({
|
||||||
new BasicResponseWriter(),
|
[CONTENT_TYPE]: 'content-type',
|
||||||
|
[HTTP.location]: 'location',
|
||||||
|
}),
|
||||||
|
new LinkRelMetadataWriter({
|
||||||
|
[RDF.type]: 'type',
|
||||||
|
}),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
return new FirstCompositeHandler<{ response: HttpResponse; result: ResponseDescription | Error }, void>([
|
||||||
|
new ErrorResponseWriter(),
|
||||||
|
new BasicResponseWriter(serializer),
|
||||||
|
]);
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a BasicMetadataExtractor with parsers for content-type, slugs and link types.
|
* Creates a BasicMetadataExtractor with parsers for content-type, slugs and link types.
|
||||||
*/
|
*/
|
||||||
|
@ -2,6 +2,7 @@ import * as url from 'url';
|
|||||||
import { namedNode, quad } from '@rdfjs/data-model';
|
import { namedNode, quad } from '@rdfjs/data-model';
|
||||||
import { Parser } from 'n3';
|
import { Parser } from 'n3';
|
||||||
import type { MockResponse } from 'node-mocks-http';
|
import type { MockResponse } from 'node-mocks-http';
|
||||||
|
import { LDP } from '../../src/util/UriConstants';
|
||||||
import { BasicConfig } from '../configs/BasicConfig';
|
import { BasicConfig } from '../configs/BasicConfig';
|
||||||
import { BasicHandlersConfig } from '../configs/BasicHandlersConfig';
|
import { BasicHandlersConfig } from '../configs/BasicHandlersConfig';
|
||||||
import { call } from '../util/Util';
|
import { call } from '../util/Util';
|
||||||
@ -38,6 +39,7 @@ describe('An integrated AuthenticatedLdpHandler', (): void => {
|
|||||||
expect(response._getData()).toContain(
|
expect(response._getData()).toContain(
|
||||||
'<http://test.com/s> <http://test.com/p> <http://test.com/o>.',
|
'<http://test.com/s> <http://test.com/p> <http://test.com/o>.',
|
||||||
);
|
);
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
|
|
||||||
// DELETE
|
// DELETE
|
||||||
response = await call(handler, requestUrl, 'DELETE', {}, []);
|
response = await call(handler, requestUrl, 'DELETE', {}, []);
|
||||||
@ -104,6 +106,7 @@ describe('An integrated AuthenticatedLdpHandler', (): void => {
|
|||||||
expect(response._getBuffer().toString()).toContain(
|
expect(response._getBuffer().toString()).toContain(
|
||||||
'<http://test.com/s2> <http://test.com/p2> <http://test.com/o2>.',
|
'<http://test.com/s2> <http://test.com/p2> <http://test.com/o2>.',
|
||||||
);
|
);
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
const parser = new Parser();
|
const parser = new Parser();
|
||||||
const triples = parser.parse(response._getBuffer().toString());
|
const triples = parser.parse(response._getBuffer().toString());
|
||||||
expect(triples).toBeRdfIsomorphic([
|
expect(triples).toBeRdfIsomorphic([
|
||||||
@ -164,6 +167,7 @@ describe('An integrated AuthenticatedLdpHandler', (): void => {
|
|||||||
[],
|
[],
|
||||||
);
|
);
|
||||||
expect(response.statusCode).toBe(200);
|
expect(response.statusCode).toBe(200);
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
const parser = new Parser();
|
const parser = new Parser();
|
||||||
const triples = parser.parse(response._getData());
|
const triples = parser.parse(response._getData());
|
||||||
expect(triples).toBeRdfIsomorphic([
|
expect(triples).toBeRdfIsomorphic([
|
||||||
|
@ -6,7 +6,7 @@ import { FileDataAccessor } from '../../src/storage/accessors/FileDataAccessor';
|
|||||||
import { InMemoryDataAccessor } from '../../src/storage/accessors/InMemoryDataAccessor';
|
import { InMemoryDataAccessor } from '../../src/storage/accessors/InMemoryDataAccessor';
|
||||||
import { ExtensionBasedMapper } from '../../src/storage/ExtensionBasedMapper';
|
import { ExtensionBasedMapper } from '../../src/storage/ExtensionBasedMapper';
|
||||||
import { MetadataController } from '../../src/util/MetadataController';
|
import { MetadataController } from '../../src/util/MetadataController';
|
||||||
import { CONTENT_TYPE } from '../../src/util/UriConstants';
|
import { CONTENT_TYPE, LDP } from '../../src/util/UriConstants';
|
||||||
import { ensureTrailingSlash } from '../../src/util/Util';
|
import { ensureTrailingSlash } from '../../src/util/Util';
|
||||||
import { AuthenticatedDataAccessorBasedConfig } from '../configs/AuthenticatedDataAccessorBasedConfig';
|
import { AuthenticatedDataAccessorBasedConfig } from '../configs/AuthenticatedDataAccessorBasedConfig';
|
||||||
import type { ServerConfig } from '../configs/ServerConfig';
|
import type { ServerConfig } from '../configs/ServerConfig';
|
||||||
@ -67,6 +67,7 @@ describe.each([ dataAccessorStore, inMemoryDataAccessorStore ])('A server using
|
|||||||
response = await fileHelper.getFile(id);
|
response = await fileHelper.getFile(id);
|
||||||
expect(response.statusCode).toBe(200);
|
expect(response.statusCode).toBe(200);
|
||||||
expect(response._getBuffer().toString()).toContain('TESTFILE2');
|
expect(response._getBuffer().toString()).toContain('TESTFILE2');
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
|
|
||||||
// DELETE file
|
// DELETE file
|
||||||
await fileHelper.deleteResource(id);
|
await fileHelper.deleteResource(id);
|
||||||
@ -95,6 +96,7 @@ describe.each([ dataAccessorStore, inMemoryDataAccessorStore ])('A server using
|
|||||||
// GET permanent file
|
// GET permanent file
|
||||||
response = await fileHelper.getFile('http://test.com/permanent.txt');
|
response = await fileHelper.getFile('http://test.com/permanent.txt');
|
||||||
expect(response._getBuffer().toString()).toContain('TEST');
|
expect(response._getBuffer().toString()).toContain('TEST');
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
|
|
||||||
// Try to delete permanent file
|
// Try to delete permanent file
|
||||||
response = await fileHelper.deleteResource('http://test.com/permanent.txt', true);
|
response = await fileHelper.deleteResource('http://test.com/permanent.txt', true);
|
||||||
|
@ -5,6 +5,7 @@ import { FileDataAccessor } from '../../src/storage/accessors/FileDataAccessor';
|
|||||||
import { InMemoryDataAccessor } from '../../src/storage/accessors/InMemoryDataAccessor';
|
import { InMemoryDataAccessor } from '../../src/storage/accessors/InMemoryDataAccessor';
|
||||||
import { ExtensionBasedMapper } from '../../src/storage/ExtensionBasedMapper';
|
import { ExtensionBasedMapper } from '../../src/storage/ExtensionBasedMapper';
|
||||||
import { MetadataController } from '../../src/util/MetadataController';
|
import { MetadataController } from '../../src/util/MetadataController';
|
||||||
|
import { LDP } from '../../src/util/UriConstants';
|
||||||
import { DataAccessorBasedConfig } from '../configs/DataAccessorBasedConfig';
|
import { DataAccessorBasedConfig } from '../configs/DataAccessorBasedConfig';
|
||||||
import type { ServerConfig } from '../configs/ServerConfig';
|
import type { ServerConfig } from '../configs/ServerConfig';
|
||||||
import { BASE, getRootFilePath } from '../configs/Util';
|
import { BASE, getRootFilePath } from '../configs/Util';
|
||||||
@ -52,6 +53,7 @@ describe.each(configs)('A server using a %s', (name, configFn): void => {
|
|||||||
response = await fileHelper.getFile(id);
|
response = await fileHelper.getFile(id);
|
||||||
expect(response.statusCode).toBe(200);
|
expect(response.statusCode).toBe(200);
|
||||||
expect(response._getBuffer().toString()).toContain('TESTFILE0');
|
expect(response._getBuffer().toString()).toContain('TESTFILE0');
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
|
|
||||||
// DELETE
|
// DELETE
|
||||||
await fileHelper.deleteResource(id);
|
await fileHelper.deleteResource(id);
|
||||||
@ -66,6 +68,7 @@ describe.each(configs)('A server using a %s', (name, configFn): void => {
|
|||||||
response = await fileHelper.getFile(id);
|
response = await fileHelper.getFile(id);
|
||||||
expect(response.statusCode).toBe(200);
|
expect(response.statusCode).toBe(200);
|
||||||
expect(response._getBuffer().toString()).toContain('TESTFILE0');
|
expect(response._getBuffer().toString()).toContain('TESTFILE0');
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
|
|
||||||
// PUT
|
// PUT
|
||||||
response = await fileHelper.overwriteFile('../assets/testfile1.txt', id, 'text/plain');
|
response = await fileHelper.overwriteFile('../assets/testfile1.txt', id, 'text/plain');
|
||||||
@ -74,6 +77,7 @@ describe.each(configs)('A server using a %s', (name, configFn): void => {
|
|||||||
response = await fileHelper.getFile(id);
|
response = await fileHelper.getFile(id);
|
||||||
expect(response.statusCode).toBe(200);
|
expect(response.statusCode).toBe(200);
|
||||||
expect(response._getBuffer().toString()).toContain('TESTFILE1');
|
expect(response._getBuffer().toString()).toContain('TESTFILE1');
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
|
|
||||||
// DELETE
|
// DELETE
|
||||||
await fileHelper.deleteResource(id);
|
await fileHelper.deleteResource(id);
|
||||||
@ -88,6 +92,9 @@ describe.each(configs)('A server using a %s', (name, configFn): void => {
|
|||||||
// GET
|
// GET
|
||||||
response = await fileHelper.getFolder(id);
|
response = await fileHelper.getFolder(id);
|
||||||
expect(response.statusCode).toBe(200);
|
expect(response.statusCode).toBe(200);
|
||||||
|
expect(response.getHeaders().link).toEqual(
|
||||||
|
[ `<${LDP.Container}>; rel="type"`, `<${LDP.BasicContainer}>; rel="type"`, `<${LDP.Resource}>; rel="type"` ],
|
||||||
|
);
|
||||||
|
|
||||||
// DELETE
|
// DELETE
|
||||||
await fileHelper.deleteResource(id);
|
await fileHelper.deleteResource(id);
|
||||||
@ -105,6 +112,7 @@ describe.each(configs)('A server using a %s', (name, configFn): void => {
|
|||||||
// GET File
|
// GET File
|
||||||
response = await fileHelper.getFile(id);
|
response = await fileHelper.getFile(id);
|
||||||
expect(response.statusCode).toBe(200);
|
expect(response.statusCode).toBe(200);
|
||||||
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
||||||
|
|
||||||
// DELETE
|
// DELETE
|
||||||
await fileHelper.deleteResource(id);
|
await fileHelper.deleteResource(id);
|
||||||
@ -171,6 +179,9 @@ describe.each(configs)('A server using a %s', (name, configFn): void => {
|
|||||||
expect(response.statusCode).toBe(200);
|
expect(response.statusCode).toBe(200);
|
||||||
expect(response._getBuffer().toString()).toContain('<http://www.w3.org/ns/ldp#contains> <http://test.com/testfolder3/subfolder0/> .');
|
expect(response._getBuffer().toString()).toContain('<http://www.w3.org/ns/ldp#contains> <http://test.com/testfolder3/subfolder0/> .');
|
||||||
expect(response._getBuffer().toString()).toContain('<http://www.w3.org/ns/ldp#contains> <http://test.com/testfolder3/testfile0.txt> .');
|
expect(response._getBuffer().toString()).toContain('<http://www.w3.org/ns/ldp#contains> <http://test.com/testfolder3/testfile0.txt> .');
|
||||||
|
expect(response.getHeaders().link).toEqual(
|
||||||
|
[ `<${LDP.Container}>; rel="type"`, `<${LDP.BasicContainer}>; rel="type"`, `<${LDP.Resource}>; rel="type"` ],
|
||||||
|
);
|
||||||
|
|
||||||
// DELETE
|
// DELETE
|
||||||
await fileHelper.deleteResource(fileId);
|
await fileHelper.deleteResource(fileId);
|
||||||
|
@ -3,22 +3,33 @@ import type { MockResponse } from 'node-mocks-http';
|
|||||||
import { createResponse } from 'node-mocks-http';
|
import { createResponse } from 'node-mocks-http';
|
||||||
import streamifyArray from 'streamify-array';
|
import streamifyArray from 'streamify-array';
|
||||||
import { BasicResponseWriter } from '../../../../src/ldp/http/BasicResponseWriter';
|
import { BasicResponseWriter } from '../../../../src/ldp/http/BasicResponseWriter';
|
||||||
|
import type { MetadataWriter } from '../../../../src/ldp/http/metadata/MetadataWriter';
|
||||||
import type { ResponseDescription } from '../../../../src/ldp/http/response/ResponseDescription';
|
import type { ResponseDescription } from '../../../../src/ldp/http/response/ResponseDescription';
|
||||||
|
import { RepresentationMetadata } from '../../../../src/ldp/representation/RepresentationMetadata';
|
||||||
|
import { INTERNAL_QUADS } from '../../../../src/util/ContentTypes';
|
||||||
import { UnsupportedHttpError } from '../../../../src/util/errors/UnsupportedHttpError';
|
import { UnsupportedHttpError } from '../../../../src/util/errors/UnsupportedHttpError';
|
||||||
|
import { CONTENT_TYPE } from '../../../../src/util/UriConstants';
|
||||||
|
import { StaticAsyncHandler } from '../../../util/StaticAsyncHandler';
|
||||||
|
|
||||||
describe('A BasicResponseWriter', (): void => {
|
describe('A BasicResponseWriter', (): void => {
|
||||||
const writer = new BasicResponseWriter();
|
let metadataWriter: MetadataWriter;
|
||||||
|
let writer: BasicResponseWriter;
|
||||||
let response: MockResponse<any>;
|
let response: MockResponse<any>;
|
||||||
let result: ResponseDescription;
|
let result: ResponseDescription;
|
||||||
|
|
||||||
beforeEach(async(): Promise<void> => {
|
beforeEach(async(): Promise<void> => {
|
||||||
|
metadataWriter = new StaticAsyncHandler(true, undefined);
|
||||||
|
writer = new BasicResponseWriter(metadataWriter);
|
||||||
response = createResponse({ eventEmitter: EventEmitter });
|
response = createResponse({ eventEmitter: EventEmitter });
|
||||||
result = { statusCode: 201 };
|
result = { statusCode: 201 };
|
||||||
});
|
});
|
||||||
|
|
||||||
it('requires the input to be a ResponseDescription.', async(): Promise<void> => {
|
it('requires the input to be a binary ResponseDescription.', async(): Promise<void> => {
|
||||||
await expect(writer.canHandle({ response, result: new Error('error') }))
|
await expect(writer.canHandle({ response, result: new Error('error') }))
|
||||||
.rejects.toThrow(UnsupportedHttpError);
|
.rejects.toThrow(UnsupportedHttpError);
|
||||||
|
const metadata = new RepresentationMetadata({ [CONTENT_TYPE]: INTERNAL_QUADS });
|
||||||
|
await expect(writer.canHandle({ response, result: { statusCode: 201, metadata }}))
|
||||||
|
.rejects.toThrow(UnsupportedHttpError);
|
||||||
await expect(writer.canHandle({ response, result }))
|
await expect(writer.canHandle({ response, result }))
|
||||||
.resolves.toBeUndefined();
|
.resolves.toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -45,4 +56,14 @@ describe('A BasicResponseWriter', (): void => {
|
|||||||
await writer.handle({ response, result });
|
await writer.handle({ response, result });
|
||||||
await end;
|
await end;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('serializes metadata if there is metadata.', async(): Promise<void> => {
|
||||||
|
result = { statusCode: 201, metadata: new RepresentationMetadata() };
|
||||||
|
metadataWriter.handle = jest.fn();
|
||||||
|
await writer.handle({ response, result });
|
||||||
|
expect(metadataWriter.handle).toHaveBeenCalledTimes(1);
|
||||||
|
expect(metadataWriter.handle).toHaveBeenLastCalledWith({ response, metadata: result.metadata });
|
||||||
|
expect(response._isEndCalled()).toBeTruthy();
|
||||||
|
expect(response._getStatusCode()).toBe(201);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user