CommunitySolidServer/test/integration/FileResourceStore.test.ts
Joachim Van Herwegen b1991cb08a
feat: More integration tests and test configs (#154)
* 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>
2020-09-14 16:06:27 +02:00

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);
});
});
});