mirror of
https://github.com/CommunitySolidServer/CommunitySolidServer.git
synced 2024-10-03 14:55:10 +00:00
213 lines
8.7 KiB
TypeScript
213 lines
8.7 KiB
TypeScript
import { mkdirSync } from 'fs';
|
|
import * as rimraf from 'rimraf';
|
|
import { RootContainerInitializer } from '../../src/init/RootContainerInitializer';
|
|
import type { HttpHandler } from '../../src/server/HttpHandler';
|
|
import { FileDataAccessor } from '../../src/storage/accessors/FileDataAccessor';
|
|
import { InMemoryDataAccessor } from '../../src/storage/accessors/InMemoryDataAccessor';
|
|
import { ExtensionBasedMapper } from '../../src/storage/mapping/ExtensionBasedMapper';
|
|
import { LDP } from '../../src/util/UriConstants';
|
|
import { DataAccessorBasedConfig } from '../configs/DataAccessorBasedConfig';
|
|
import type { ServerConfig } from '../configs/ServerConfig';
|
|
import { BASE, getRootFilePath } from '../configs/Util';
|
|
import { FileTestHelper } from '../util/TestHelpers';
|
|
|
|
const fileDataAccessorStore: [string, (rootFilePath: string) => ServerConfig] = [
|
|
'FileDataAccessorBasedStore',
|
|
(rootFilePath: string): ServerConfig => new DataAccessorBasedConfig(BASE,
|
|
new FileDataAccessor(new ExtensionBasedMapper(BASE, rootFilePath))),
|
|
];
|
|
const inMemoryDataAccessorStore: [string, (rootFilePath: string) => ServerConfig] = [
|
|
'InMemoryDataAccessorBasedStore',
|
|
(): ServerConfig => new DataAccessorBasedConfig(BASE, new InMemoryDataAccessor(BASE)),
|
|
];
|
|
|
|
const configs = [ fileDataAccessorStore, inMemoryDataAccessorStore ];
|
|
|
|
describe.each(configs)('A server using a %s', (name, configFn): void => {
|
|
describe('without acl', (): void => {
|
|
let rootFilePath: string;
|
|
let config: ServerConfig;
|
|
let handler: HttpHandler;
|
|
let fileHelper: FileTestHelper;
|
|
|
|
beforeAll(async(): Promise<void> => {
|
|
rootFilePath = getRootFilePath(name);
|
|
mkdirSync(rootFilePath, { recursive: true });
|
|
config = configFn(rootFilePath);
|
|
handler = config.getHttpHandler();
|
|
fileHelper = new FileTestHelper(handler, new URL(BASE));
|
|
|
|
// Initialize store
|
|
const initializer = new RootContainerInitializer(BASE, config.store);
|
|
await initializer.handleSafe();
|
|
});
|
|
|
|
afterAll(async(): Promise<void> => {
|
|
rimraf.sync(rootFilePath, { glob: false });
|
|
});
|
|
|
|
it('can add a file to the store, read it and delete it.', async():
|
|
Promise<void> => {
|
|
// POST
|
|
let response = await fileHelper.createFile('../assets/testfile0.txt', 'testfile0.txt', 'text/plain');
|
|
const id = response._getHeaders().location;
|
|
|
|
// GET
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getBuffer().toString()).toContain('TESTFILE0');
|
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
|
|
|
// DELETE
|
|
await fileHelper.deleteResource(id);
|
|
await fileHelper.shouldNotExist(id);
|
|
});
|
|
|
|
it('can add and overwrite a file.', async(): Promise<void> => {
|
|
let response = await fileHelper.createFile('../assets/testfile0.txt', 'file.txt', 'text/plain');
|
|
const id = response._getHeaders().location;
|
|
|
|
// GET
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getBuffer().toString()).toContain('TESTFILE0');
|
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
|
|
|
// PUT
|
|
response = await fileHelper.overwriteFile('../assets/testfile1.txt', id, 'text/plain');
|
|
|
|
// GET
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getBuffer().toString()).toContain('TESTFILE1');
|
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
|
|
|
// DELETE
|
|
await fileHelper.deleteResource(id);
|
|
await fileHelper.shouldNotExist(id);
|
|
});
|
|
|
|
it('can create a folder and delete it.', async(): Promise<void> => {
|
|
// POST
|
|
let response = await fileHelper.createFolder('secondfolder/');
|
|
const id = response._getHeaders().location;
|
|
|
|
// GET
|
|
response = await fileHelper.getFolder(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response.getHeaders().link).toEqual(
|
|
[ `<${LDP.Container}>; rel="type"`, `<${LDP.BasicContainer}>; rel="type"`, `<${LDP.Resource}>; rel="type"` ],
|
|
);
|
|
|
|
// DELETE
|
|
await fileHelper.deleteResource(id);
|
|
await fileHelper.shouldNotExist(id);
|
|
});
|
|
|
|
it('can make a folder and put a file in it.', async(): Promise<void> => {
|
|
// Create folder
|
|
await fileHelper.createFolder('testfolder0/');
|
|
|
|
// Create file
|
|
let response = await fileHelper.createFile('../assets/testfile0.txt', 'testfolder0/testfile0.txt', 'text/plain');
|
|
const id = response._getHeaders().location;
|
|
|
|
// GET File
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response.getHeaders().link).toBe(`<${LDP.Resource}>; rel="type"`);
|
|
|
|
// DELETE
|
|
await fileHelper.deleteResource(id);
|
|
await fileHelper.shouldNotExist(id);
|
|
await fileHelper.deleteResource('http://test.com/testfolder0/');
|
|
await fileHelper.shouldNotExist('http://test.com/testfolder0/');
|
|
});
|
|
|
|
it('cannot remove a folder when the folder contains a file.', async(): Promise<void> => {
|
|
// Create folder
|
|
let response = await fileHelper.createFolder('testfolder1/');
|
|
const folderId = response._getHeaders().location;
|
|
|
|
// Create file
|
|
await fileHelper.createFile('../assets/testfile0.txt', 'testfolder1/testfile0.txt', 'text/plain');
|
|
|
|
// Try DELETE folder
|
|
response = await fileHelper.simpleCall(new URL(folderId), 'DELETE', {});
|
|
expect(response.statusCode).toBe(409);
|
|
expect(response._getData()).toContain('ConflictHttpError: Can only delete empty containers.');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteResource('http://test.com/testfolder1/testfile0.txt');
|
|
await fileHelper.shouldNotExist('http://test.com/testfolder1/testfile0.txt');
|
|
await fileHelper.deleteResource(folderId);
|
|
await fileHelper.shouldNotExist(folderId);
|
|
});
|
|
|
|
it('cannot remove a folder when the folder contains a subfolder.', async(): Promise<void> => {
|
|
// Create folder
|
|
let response = await fileHelper.createFolder('testfolder2/');
|
|
const folderId = response._getHeaders().location;
|
|
|
|
// Create subfolder
|
|
response = await fileHelper.createFolder('testfolder2/subfolder0');
|
|
const subFolderId = response._getHeaders().location;
|
|
|
|
// Try DELETE folder
|
|
response = await fileHelper.simpleCall(new URL(folderId), 'DELETE', {});
|
|
expect(response.statusCode).toBe(409);
|
|
expect(response._getData()).toContain('ConflictHttpError: Can only delete empty containers.');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteResource(subFolderId);
|
|
await fileHelper.shouldNotExist(subFolderId);
|
|
await fileHelper.deleteResource(folderId);
|
|
await fileHelper.shouldNotExist(folderId);
|
|
});
|
|
|
|
it('can read the contents of a folder.', async(): Promise<void> => {
|
|
// Create folder
|
|
let response = await fileHelper.createFolder('testfolder3/');
|
|
const folderId = response._getHeaders().location;
|
|
|
|
// Create subfolder
|
|
response = await fileHelper.createFolder('testfolder3/subfolder0/');
|
|
const subFolderId = response._getHeaders().location;
|
|
|
|
// Create file
|
|
response = await fileHelper.createFile('../assets/testfile0.txt', 'testfolder3/testfile0.txt', 'text/plain');
|
|
const fileId = response._getHeaders().location;
|
|
|
|
response = await fileHelper.getFolder(folderId);
|
|
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/testfile0.txt> .');
|
|
expect(response.getHeaders().link).toEqual(
|
|
[ `<${LDP.Container}>; rel="type"`, `<${LDP.BasicContainer}>; rel="type"`, `<${LDP.Resource}>; rel="type"` ],
|
|
);
|
|
|
|
// DELETE
|
|
await fileHelper.deleteResource(fileId);
|
|
await fileHelper.shouldNotExist(fileId);
|
|
await fileHelper.deleteResource(subFolderId);
|
|
await fileHelper.shouldNotExist(subFolderId);
|
|
await fileHelper.deleteResource(folderId);
|
|
await fileHelper.shouldNotExist(folderId);
|
|
});
|
|
|
|
it('can upload and delete a image.', async(): Promise<void> => {
|
|
let response = await fileHelper.createFile('../assets/testimage.png', 'image.png', 'image/png');
|
|
const fileId = response._getHeaders().location;
|
|
|
|
// GET
|
|
response = await fileHelper.getFile(fileId);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getHeaders()['content-type']).toBe('image/png');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteResource(fileId);
|
|
await fileHelper.shouldNotExist(fileId);
|
|
});
|
|
});
|
|
});
|