mirror of
https://github.com/CommunitySolidServer/CommunitySolidServer.git
synced 2024-10-03 14:55:10 +00:00

* add todo * Added configurations folder * Added config to index * changed /bin/server to use configfiles * initiate acl with Setup component * add last changes * reset serverconfig * move authenticatedLdpHandler configs to config files * failed to read testss * failed to read testss * removed import part * Fix merge conflicts * add first FileResTests * fix: fix fileresourcestore metadata error * fix unit tests * remove test files * Added test and changed callFile * Fix: metadata file error in FileResourceStore * fix: ensure full test coverage * added tests * Fix get tests * added testfiles * changed config to use PasstrueStore * to continue work on * refactor fileresourcestore config * refactor tests * fix content-types, update tests * replace sync methods with async methods * move acl function to util * added testfiles for Fileserver with acl * update tests * add first acl filestore test * refactor * add resource mapper * refactor config files * add more fileresourcestore acl tests * add locking resource store test files * move file mapping logic to resourcemapper * added beforeAll for a permanent file in Auht tests * make filestore dependent of resource mapper * moved configs to test/configs * set default contenttype * refactor fileresourcemapper * fix map function * refactor * fixed foldercreationtest * changed some tests so the files are cleaned up when done testing * add normalized parser * Auhtenticationtests clean up acl file * refactor unit test * lost changes added again * fix metadata problem * refactor names * reverse change * add getters * configs and start util * add comments * add comments, move code * added acl helper and changed tests * linter 7.7.0 -> 7.0.0 * moved test/tesfiles -> test/assets * removed configs/**/*.ts from tsconfig.json * Temporary changed threshold so cli test is ignored and commiting goes easier, will revert later * added FileResourceStore to index * Changed imports * Changed imports for all configs * Removed comment * Changed names of configs * added 'Config' to name and removed comment * removed unused testfile and added testfile 0 * changed beforeAll to just copy permanent file * change text/turtle to constant * fix converter issue * getHandler -> getHttpHandler, and updates to config * removed ',' * removed trailing / * changed imports for index.d.js problem * removed duplicate file and added line that got removed in mergeconflicts * add jest global teardown * add ignore for CliRunner * add changes * fix copyfile error * remove unused testfiles * adding test with image * add first util functions * relative paths to absolute paths * added 3 FileStoreTests * more refactoring * more absolute paths * fix mkdir path * added test * add util for easy configs * add comments * added some testhelpers and refactor first test * fix converter test error * refactor FileResTests * solved failing test because new converters * removed afterAll() * removed setAcl from util * removed config from Authorization.test.ts * changed strange linting * refactored AuthenticatedFileResourceStore tests * fixed unclear root variable * fix: Use absolute test paths * Mock fs correctly and remove teardown * Clean up after tests Co-authored-by: freyavs <freyavanspeybroeck@outlook.com> Co-authored-by: thdossch <dossche.thor@gmail.com> Co-authored-by: Freya <56410697+freyavs@users.noreply.github.com> Co-authored-by: thdossch <49074469+thdossch@users.noreply.github.com> Co-authored-by: Ruben Verborgh <ruben@verborgh.org>
187 lines
7.2 KiB
TypeScript
187 lines
7.2 KiB
TypeScript
import * as rimraf from 'rimraf';
|
|
import { RuntimeConfig } from '../../src/init/RuntimeConfig';
|
|
import { HttpHandler } from '../../src/server/HttpHandler';
|
|
import { FileResourceStoreConfig } from '../configs/FileResourceStoreConfig';
|
|
import { getRuntimeConfig } from '../configs/Util';
|
|
import { FileTestHelper } from '../util/TestHelpers';
|
|
|
|
describe('A server using a FileResourceStore', (): void => {
|
|
describe('without acl', (): void => {
|
|
let config: FileResourceStoreConfig;
|
|
let handler: HttpHandler;
|
|
let fileHelper: FileTestHelper;
|
|
let runtimeConfig: RuntimeConfig;
|
|
|
|
beforeAll(async(): Promise<void> => {
|
|
runtimeConfig = getRuntimeConfig('FileResourceStore');
|
|
config = new FileResourceStoreConfig(runtimeConfig);
|
|
handler = config.getHttpHandler();
|
|
fileHelper = new FileTestHelper(handler, new URL(runtimeConfig.base));
|
|
});
|
|
|
|
afterAll(async(): Promise<void> => {
|
|
rimraf.sync(runtimeConfig.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');
|
|
const id = response._getHeaders().location;
|
|
|
|
// GET
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getHeaders().location).toBe(id);
|
|
expect(response._getBuffer().toString()).toContain('TESTFILE0');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteFile(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');
|
|
const id = response._getHeaders().location;
|
|
|
|
// GET
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getHeaders().location).toBe(id);
|
|
expect(response._getBuffer().toString()).toContain('TESTFILE0');
|
|
|
|
// PUT
|
|
response = await fileHelper.overwriteFile('../assets/testfile1.txt', id);
|
|
|
|
// GET
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getHeaders().location).toBe(id);
|
|
expect(response._getBuffer().toString()).toContain('TESTFILE1');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteFile(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().location).toBe(id);
|
|
|
|
// DELETE
|
|
await fileHelper.deleteFolder(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');
|
|
const id = response._getHeaders().location;
|
|
|
|
// GET File
|
|
response = await fileHelper.getFile(id);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getHeaders().location).toBe(id);
|
|
|
|
// DELETE
|
|
await fileHelper.deleteFile(id);
|
|
await fileHelper.shouldNotExist(id);
|
|
await fileHelper.deleteFolder('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');
|
|
|
|
// Try DELETE folder
|
|
response = await fileHelper.simpleCall(new URL(folderId), 'DELETE', {});
|
|
expect(response.statusCode).toBe(409);
|
|
expect(response._getData()).toContain('ConflictHttpError: Container is not empty.');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteFile('http://test.com/testfolder1/testfile0.txt');
|
|
await fileHelper.shouldNotExist('http://test.com/testfolder1/testfile0.txt');
|
|
await fileHelper.deleteFolder(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: Container is not empty.');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteFolder(subFolderId);
|
|
await fileHelper.shouldNotExist(subFolderId);
|
|
await fileHelper.deleteFolder(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');
|
|
const fileId = response._getHeaders().location;
|
|
|
|
response = await fileHelper.getFolder(folderId);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getHeaders().location).toBe(folderId);
|
|
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>.');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteFile(fileId);
|
|
await fileHelper.shouldNotExist(fileId);
|
|
await fileHelper.deleteFolder(subFolderId);
|
|
await fileHelper.shouldNotExist(subFolderId);
|
|
await fileHelper.deleteFolder(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');
|
|
const fileId = response._getHeaders().location;
|
|
|
|
// GET
|
|
response = await fileHelper.getFile(fileId);
|
|
expect(response.statusCode).toBe(200);
|
|
expect(response._getHeaders().location).toBe(fileId);
|
|
expect(response._getHeaders()['content-type']).toBe('image/png');
|
|
|
|
// DELETE
|
|
await fileHelper.deleteFile(fileId);
|
|
await fileHelper.shouldNotExist(fileId);
|
|
});
|
|
});
|
|
});
|