Delete Account: started adding unit tests

This commit is contained in:
gianantoniopini
2021-05-11 15:19:05 +02:00
parent b0bd8c94f3
commit eb54a7f69d
5 changed files with 131 additions and 1 deletions

View File

@ -0,0 +1,15 @@
const deleteUserFunctionName = 'deleteUser';
const defaultDelayInMilliseconds = 2000;
class Functions {
static get deleteUserFunctionName() {
return deleteUserFunctionName;
}
static get defaultDelayInMilliseconds() {
return defaultDelayInMilliseconds;
}
}
export default Functions;

View File

@ -0,0 +1,54 @@
/* eslint-disable no-underscore-dangle */
import { v4 as uuidv4 } from 'uuid';
import FunctionsConstants from '../constants/functions';
import HttpsCallableResult from './httpsCallableResult';
import { delay } from '../../../src/utils/index';
const singleton = Symbol('');
const singletonEnforcer = Symbol('');
const deleteUser = async () => {
await delay(FunctionsConstants.defaultDelayInMilliseconds);
return new HttpsCallableResult(true);
};
class Functions {
constructor(enforcer) {
if (enforcer !== singletonEnforcer) {
throw new Error('Cannot construct singleton');
}
this._uuid = uuidv4();
this._httpsCallables = {};
this._httpsCallables[
FunctionsConstants.deleteUserFunctionName
] = deleteUser;
}
static get instance() {
if (!this[singleton]) {
this[singleton] = new Functions(singletonEnforcer);
}
return this[singleton];
}
get uuid() {
return this._uuid;
}
httpsCallable(name) {
if (!name) {
throw new Error('name must be provided.');
} else if (typeof name !== 'string') {
throw new Error('name should be a string.');
}
return this._httpsCallables[name];
}
}
export default Functions;

View File

@ -0,0 +1,19 @@
/* eslint-disable no-underscore-dangle */
import { v4 as uuidv4 } from 'uuid';
class HttpsCallableResult {
constructor(data) {
this._uuid = uuidv4();
this._data = data;
}
get data() {
return this._data;
}
get uuid() {
return this._uuid;
}
}
export default HttpsCallableResult;