import { PassThrough } from 'stream'; import { DataFactory } from 'n3'; import type { Quad } from 'rdf-js'; import streamifyArray from 'streamify-array'; import { decodeUriPathComponents, encodeUriPathComponents, ensureTrailingSlash, matchingMediaType, pipeStreamsAndErrors, pushQuad, readableToString, toCanonicalUriPath, } from '../../../src/util/Util'; describe('Util function', (): void => { describe('ensureTrailingSlash', (): void => { it('makes sure there is always exactly 1 slash.', async(): Promise => { expect(ensureTrailingSlash('http://test.com')).toEqual('http://test.com/'); expect(ensureTrailingSlash('http://test.com/')).toEqual('http://test.com/'); expect(ensureTrailingSlash('http://test.com//')).toEqual('http://test.com/'); expect(ensureTrailingSlash('http://test.com///')).toEqual('http://test.com/'); }); }); describe('readableToString', (): void => { it('concatenates all elements of a Readable.', async(): Promise => { const stream = streamifyArray([ 'a', 'b', 'c' ]); await expect(readableToString(stream)).resolves.toEqual('abc'); }); }); describe('matchingMediaType', (): void => { it('matches all possible media types.', async(): Promise => { expect(matchingMediaType('*/*', 'text/turtle')).toBeTruthy(); expect(matchingMediaType('text/*', '*/*')).toBeTruthy(); expect(matchingMediaType('text/*', 'text/turtle')).toBeTruthy(); expect(matchingMediaType('text/plain', 'text/*')).toBeTruthy(); expect(matchingMediaType('text/turtle', 'text/turtle')).toBeTruthy(); expect(matchingMediaType('text/*', 'application/*')).toBeFalsy(); expect(matchingMediaType('text/plain', 'application/*')).toBeFalsy(); expect(matchingMediaType('text/plain', 'text/turtle')).toBeFalsy(); }); }); describe('pipeStreamsAndErrors', (): void => { it('pipes data from one stream to the other.', async(): Promise => { const input = streamifyArray([ 'data' ]); const output = new PassThrough(); pipeStreamsAndErrors(input, output); await expect(readableToString(output)).resolves.toEqual('data'); }); it('pipes errors from one stream to the other.', async(): Promise => { const input = streamifyArray([ 'data' ]); input.read = (): any => { input.emit('error', new Error('error')); return null; }; const output = new PassThrough(); pipeStreamsAndErrors(input, output); await expect(readableToString(output)).rejects.toThrow(new Error('error')); }); it('supports mapping errors to something else.', async(): Promise => { const input = streamifyArray([ 'data' ]); input.read = (): any => { input.emit('error', new Error('error')); return null; }; const output = new PassThrough(); pipeStreamsAndErrors(input, output, (): any => new Error('other error')); await expect(readableToString(output)).rejects.toThrow(new Error('other error')); }); }); describe('UriPath functions', (): void => { it('makes sure only the necessary parts are encoded with toCanonicalUriPath.', async(): Promise => { expect(toCanonicalUriPath('/a%20path&/name')).toEqual('/a%20path%26/name'); }); it('decodes all parts of a path with decodeUriPathComponents.', async(): Promise => { expect(decodeUriPathComponents('/a%20path&/name')).toEqual('/a path&/name'); }); it('encodes all parts of a path with encodeUriPathComponents.', async(): Promise => { expect(encodeUriPathComponents('/a%20path&/name')).toEqual('/a%2520path%26/name'); }); }); describe('pushQuad', (): void => { it('creates a quad and adds it to the given array.', async(): Promise => { const quads: Quad[] = []; pushQuad(quads, DataFactory.namedNode('sub'), DataFactory.namedNode('pred'), DataFactory.literal('obj')); expect(quads).toEqualRdfQuadArray([ DataFactory.quad(DataFactory.namedNode('sub'), DataFactory.namedNode('pred'), DataFactory.literal('obj')), ]); }); }); });