feat: Add DataAccessorBasedStore integration

This commit is contained in:
Joachim Van Herwegen
2020-09-30 12:07:31 +02:00
parent 9a857b7581
commit 9b26bbef2d
8 changed files with 218 additions and 45 deletions

View File

@@ -1,39 +1,45 @@
import { copyFileSync, mkdirSync } from 'fs';
import { join } from 'path';
import * as rimraf from 'rimraf';
import type { HttpHandler, ResourceStore } from '../../index';
import { ensureTrailingSlash } from '../../src/util/Util';
import { AuthenticatedFileBasedDataAccessorConfig } from '../configs/AuthenticatedFileBasedDataAccessorConfig';
import { AuthenticatedFileResourceStoreConfig } from '../configs/AuthenticatedFileResourceStoreConfig';
import type { ServerConfig } from '../configs/ServerConfig';
import { BASE, getRootFilePath } from '../configs/Util';
import { AclTestHelper, FileTestHelper } from '../util/TestHelpers';
describe('A server using a AuthenticatedFileResourceStore', (): void => {
let config: AuthenticatedFileResourceStoreConfig;
let handler: HttpHandler;
let store: ResourceStore;
let aclHelper: AclTestHelper;
let fileHelper: FileTestHelper;
let rootFilePath: string;
beforeAll(async(): Promise<void> => {
rootFilePath = getRootFilePath('AuthenticatedFileResourceStore');
mkdirSync(rootFilePath, { recursive: true });
config = new AuthenticatedFileResourceStoreConfig(BASE, rootFilePath);
handler = config.getHttpHandler();
({ store } = config);
aclHelper = new AclTestHelper(store, ensureTrailingSlash(BASE));
fileHelper = new FileTestHelper(handler, new URL(ensureTrailingSlash(BASE)));
// Make sure the root directory exists
mkdirSync(rootFilePath, { recursive: true });
copyFileSync(join(__dirname, '../assets/permanent.txt'), `${rootFilePath}/permanent.txt`);
});
afterAll(async(): Promise<void> => {
rimraf.sync(rootFilePath, { glob: false });
});
const fileResourceStore: [string, (rootFilePath: string) => ServerConfig] = [
'FileResourceStore',
(rootFilePath: string): ServerConfig => new AuthenticatedFileResourceStoreConfig(BASE, rootFilePath),
];
const dataAccessorStore: [string, (rootFilePath: string) => ServerConfig] = [
'FileDataAccessorBasedStore',
(rootFilePath: string): ServerConfig => new AuthenticatedFileBasedDataAccessorConfig(BASE, rootFilePath),
];
describe.each([ fileResourceStore, dataAccessorStore ])('A server using a %s', (name, configFn): void => {
describe('with acl', (): void => {
let config: ServerConfig;
let aclHelper: AclTestHelper;
let fileHelper: FileTestHelper;
let rootFilePath: string;
beforeAll(async(): Promise<void> => {
rootFilePath = getRootFilePath(name);
mkdirSync(rootFilePath, { recursive: true });
config = configFn(rootFilePath);
aclHelper = new AclTestHelper(config.store, ensureTrailingSlash(BASE));
fileHelper = new FileTestHelper(config.getHttpHandler(), new URL(ensureTrailingSlash(BASE)));
// Make sure the root directory exists
mkdirSync(rootFilePath, { recursive: true });
copyFileSync(join(__dirname, '../assets/permanent.txt'), `${rootFilePath}/permanent.txt`);
});
afterAll(async(): Promise<void> => {
rimraf.sync(rootFilePath, { glob: false });
});
it('can add a file to the store, read it and delete it if allowed.', async(): Promise<
void
> => {
@@ -41,7 +47,7 @@ describe('A server using a AuthenticatedFileResourceStore', (): void => {
await aclHelper.setSimpleAcl({ read: true, write: true, append: true }, 'agent');
// Create file
let response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt');
let response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt', 'text/plain');
const id = response._getHeaders().location;
// Get file
@@ -61,7 +67,7 @@ describe('A server using a AuthenticatedFileResourceStore', (): void => {
await aclHelper.setSimpleAcl({ read: true, write: true, append: true }, 'authenticated');
// Try to create file
const response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt', true);
const response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt', 'text/plain', true);
expect(response.statusCode).toBe(401);
});
@@ -71,7 +77,7 @@ describe('A server using a AuthenticatedFileResourceStore', (): void => {
await aclHelper.setSimpleAcl({ read: true, write: false, append: false }, 'agent');
// Try to create file
let response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt', true);
let response = await fileHelper.createFile('../assets/testfile2.txt', 'testfile2.txt', 'text/plain', true);
expect(response.statusCode).toBe(401);
// GET permanent file

View File

@@ -1,21 +1,32 @@
import { mkdirSync } from 'fs';
import * as rimraf from 'rimraf';
import type { HttpHandler } from '../../src/server/HttpHandler';
import { FileBasedDataAccessorConfig } from '../configs/FileBasedDataAccessorConfig';
import { FileResourceStoreConfig } from '../configs/FileResourceStoreConfig';
import type { ServerConfig } from '../configs/ServerConfig';
import { BASE, getRootFilePath } from '../configs/Util';
import { FileTestHelper } from '../util/TestHelpers';
describe('A server using a FileResourceStore', (): void => {
const fileResourceStore: [string, (rootFilePath: string) => ServerConfig] = [
'FileResourceStore',
(rootFilePath: string): ServerConfig => new FileResourceStoreConfig(BASE, rootFilePath),
];
const dataAccessorStore: [string, (rootFilePath: string) => ServerConfig] = [
'FileDataAccessorBasedStore',
(rootFilePath: string): ServerConfig => new FileBasedDataAccessorConfig(BASE, rootFilePath),
];
describe.each([ fileResourceStore, dataAccessorStore ])('A server using a %s', (name, configFn): void => {
describe('without acl', (): void => {
let rootFilePath: string;
let config: FileResourceStoreConfig;
let config: ServerConfig;
let handler: HttpHandler;
let fileHelper: FileTestHelper;
beforeAll(async(): Promise<void> => {
rootFilePath = getRootFilePath('FileResourceStore');
rootFilePath = getRootFilePath(name);
mkdirSync(rootFilePath, { recursive: true });
config = new FileResourceStoreConfig(BASE, rootFilePath);
config = configFn(rootFilePath);
handler = config.getHttpHandler();
fileHelper = new FileTestHelper(handler, new URL(BASE));
});
@@ -27,7 +38,7 @@ describe('A server using a FileResourceStore', (): void => {
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');
let response = await fileHelper.createFile('../assets/testfile0.txt', 'testfile0.txt', 'text/plain');
const id = response._getHeaders().location;
// GET
@@ -42,7 +53,7 @@ describe('A server using a FileResourceStore', (): void => {
});
it('can add and overwrite a file.', async(): Promise<void> => {
let response = await fileHelper.createFile('../assets/testfile0.txt', 'file.txt');
let response = await fileHelper.createFile('../assets/testfile0.txt', 'file.txt', 'text/plain');
const id = response._getHeaders().location;
// GET
@@ -52,7 +63,7 @@ describe('A server using a FileResourceStore', (): void => {
expect(response._getBuffer().toString()).toContain('TESTFILE0');
// PUT
response = await fileHelper.overwriteFile('../assets/testfile1.txt', id);
response = await fileHelper.overwriteFile('../assets/testfile1.txt', id, 'text/plain');
// GET
response = await fileHelper.getFile(id);
@@ -85,7 +96,7 @@ describe('A server using a FileResourceStore', (): void => {
await fileHelper.createFolder('testfolder0/');
// Create file
let response = await fileHelper.createFile('../assets/testfile0.txt', 'testfolder0/testfile0.txt');
let response = await fileHelper.createFile('../assets/testfile0.txt', 'testfolder0/testfile0.txt', 'text/plain');
const id = response._getHeaders().location;
// GET File
@@ -106,7 +117,7 @@ describe('A server using a FileResourceStore', (): void => {
const folderId = response._getHeaders().location;
// Create file
await fileHelper.createFile('../assets/testfile0.txt', 'testfolder1/testfile0.txt');
await fileHelper.createFile('../assets/testfile0.txt', 'testfolder1/testfile0.txt', 'text/plain');
// Try DELETE folder
response = await fileHelper.simpleCall(new URL(folderId), 'DELETE', {});
@@ -151,7 +162,7 @@ describe('A server using a FileResourceStore', (): void => {
const subFolderId = response._getHeaders().location;
// Create file
response = await fileHelper.createFile('../assets/testfile0.txt', 'testfolder3/testfile0.txt');
response = await fileHelper.createFile('../assets/testfile0.txt', 'testfolder3/testfile0.txt', 'text/plain');
const fileId = response._getHeaders().location;
response = await fileHelper.getFolder(folderId);
@@ -170,7 +181,7 @@ describe('A server using a FileResourceStore', (): void => {
});
it('can upload and delete a image.', async(): Promise<void> => {
let response = await fileHelper.createFile('../assets/testimage.png', 'image.png');
let response = await fileHelper.createFile('../assets/testimage.png', 'image.png', 'image/png');
const fileId = response._getHeaders().location;
// GET