WIP pass the failed tests.

This commit is contained in:
Ahmed Bouhuolia
2020-05-17 07:08:12 +02:00
parent 00de156c9f
commit 10f636d2bc
77 changed files with 2164 additions and 1403 deletions

View File

@@ -1,12 +0,0 @@
import { expect } from '~/testInit';
import { Lexer } from '@/lib/LogicEvaluation/Lexer';
describe('Lexer', () => {
it('Should retrieve tokens of the expression.', () => {
const lexer = new Lexer('(1 && 2) || (2 || 3)');
const tokens = lexer.getTokens();
expect(tokens.length).equals(11);
});
});

View File

@@ -1,5 +0,0 @@
describe('MetableModel', () => {
});

View File

@@ -1,159 +0,0 @@
import Option from '@/models/Option';
import MetadataCollection from '@/lib/Metable/MetableCollection';
import ResourceFieldMetadata from '@/models/ResourceFieldMetadata';
import { create, expect } from '~/testInit';
describe('MetableCollection', () => {
describe('findMeta', () => {
it('Should retrieve the found meta object.', async () => {
const option = await create('option');
const metadataCollection = await Option.query();
const foundMeta = metadataCollection.findMeta(option.key);
expect(foundMeta).to.be.an('object');
});
it('Should retrieve the found meta with extra columns.', async () => {
const option = await create('option');
const metadataCollection = await Option.query();
const foundMeta = metadataCollection.findMeta({
key: option.key,
group: option.group,
});
expect(foundMeta).to.be.an('object');
});
});
describe('allMetadata', () => {
it('Should retrieve all exists metadata entries.', async () => {
const option = await create('option');
const metadataCollection = await Option.query();
const foundMetadata = metadataCollection.allMetadata();
expect(foundMetadata.length).equals(1);
});
});
describe('getMeta', () => {
it('Should retrieve the found meta value.', async () => {
const option = await create('option');
const metadataCollection = await Option.query();
const foundMeta = metadataCollection.getMeta(option.key);
expect(foundMeta).equals(option.value);
});
it('Should retrieve the default meta value in case the meta key was not exist.', async () => {
const option = await create('option');
const metadataCollection = await Option.query();
const foundMeta = metadataCollection.getMeta('not-found', true);
expect(foundMeta).equals(true);
});
});
describe('setMeta', () => {
it('Should sets the meta value to the stack.', async () => {
const metadataCollection = new MetadataCollection();
metadataCollection.setMeta('key', 'value');
expect(metadataCollection.metadata.length).equals(1);
});
it('Should sets the meta value with extra columns', async () => {
const metadataCollection = new MetadataCollection();
metadataCollection.setMeta({
key: 'key',
value: 'value',
group: 'group-1',
});
expect(metadataCollection.metadata.length).equals(1);
expect(metadataCollection.metadata[0].key).equals('key');
expect(metadataCollection.metadata[0].value).equals('value');
expect(metadataCollection.metadata[0].group).equals('group-1');
});
});
describe('removeAllMeta()', () => {
it('Should remove all metadata from the stack.', async () => {
const metadataCollection = new MetadataCollection();
metadataCollection.setModel(Option);
metadataCollection.setMeta('key', 'value');
metadataCollection.setMeta('key2', 'value2');
metadataCollection.removeAllMeta();
expect(metadataCollection.metadata.length).equals(2);
expect(metadataCollection.allMetadata().length).equals(0);
});
});
describe('saveMeta', () => {
it('Should save inserted new metadata.', async () => {
const metadataCollection = new MetadataCollection();
metadataCollection.setModel(Option);
metadataCollection.setMeta('key', 'value');
metadataCollection.setModel(Option);
await metadataCollection.saveMeta();
const storedMetadata = await Option.query();
expect(storedMetadata.metadata.length).equals(1);
});
it('Should save updated the exist metadata.', async () => {
const option = await create('option');
const metadataCollection = await Option.query();
metadataCollection.setModel(Option);
metadataCollection.setMeta(option.key, 'value');
metadataCollection.setModel(Option);
await metadataCollection.saveMeta();
const storedMetadata = await Option.query().where('key', option.key);
expect(storedMetadata.metadata[0].value).equals('value');
expect(storedMetadata.metadata[0].key).equals(option.key);
expect(storedMetadata.metadata[0].group).equals(option.group);
});
it('Should delete the removed metadata from storage.', async () => {
const option = await create('option');
const metadataCollection = await Option.query();
metadataCollection.removeMeta(option.key);
expect(metadataCollection.metadata.length).equals(1);
await metadataCollection.saveMeta();
const storedMetadata = await Option.query();
expect(storedMetadata.metadata.length).equals(0);
});
it('Should save instered new metadata with extra columns.', async () => {
const resource = await create('resource');
const metadataCollection = new MetadataCollection();
metadataCollection.extraColumns = ['resource_id'];
metadataCollection.setModel(ResourceFieldMetadata);
metadataCollection.setMeta({
key: 'key',
value: 'value',
resource_id: resource.id,
});
await metadataCollection.saveMeta();
const storedMetadata = await ResourceFieldMetadata.query().first();
expect(storedMetadata.metadata.length).equals(1);
expect(storedMetadata.metadata[0].resourceId).equals(resource.id);
});
});
});

View File

@@ -1,50 +0,0 @@
import { expect } from '~/testInit';
import { Lexer } from '@/lib/LogicEvaluation/Lexer';
import Parser from '@/lib/LogicEvaluation/Parser';
import QueryParser from '@/lib/LogicEvaluation/QueryParser';
import Expense from '@/models/Expense';
import knex from '@/database/knex';
describe('LoginEvaluation: Parser', () => {
it('Should parse the logic', async () => {
const lexer = new Lexer('(1 OR 2) AND (1 AND 3)');
const tokens = lexer.getTokens();
const parser = new Parser(tokens);
const parsedTree = parser.parse();
const queries = {
1: (query) => {
query.where('expense_account_id', 1);
},
2: (query) => {
query.where('payment_account_id', 2);
},
3: (query) => {
query.where('amount', '<', 100);
},
};
const queryParser = new QueryParser(parsedTree, queries);
const parsedQuery = queryParser.parse();
const parsedQueryWrapper = (builder) => {
parsedQuery(builder);
console.log(builder.toString());
};
const query = await knex.select('*').from('expenses')
.modify(parsedQueryWrapper);
// console.log(query);
// });
// console.log(a);
});
});

View File

@@ -1,125 +0,0 @@
import {
expect,
create,
login,
} from '~/testInit';
import Expense from '@/models/Expense';
import ResourceCustomFieldRepository from '@/services/CustomFields/ResourceCustomFieldRepository';
import ResourceFieldMetadata from '@/models/ResourceFieldMetadata';
let loginRes;
describe('ResourceCustomFieldRepository', () => {
beforeEach(async () => {
loginRes = await login();
});
afterEach(() => {
loginRes = null;
});
describe('constructor()', () => {
it('Should take the resource name from model class name', () => {
const customFieldsRepo = new ResourceCustomFieldRepository(Expense);
expect(customFieldsRepo.resourceName).equals('Expense');
});
});
describe('loadResource()', () => {
it('Should fetches the resource name.', async () => {
const resource = await create('resource', { name: 'Expense' });
const customFieldsRepo = new ResourceCustomFieldRepository(Expense);
await customFieldsRepo.loadResource();
expect(customFieldsRepo.resource.name).equals('Expense');
});
});
describe('loadResourceCustomFields()', () => {
it('Should fetches all custom fields that associated with the resource.', async () => {
const resource = await create('resource', { name: 'Expense' });
const resourceField = await create('resource_field', { resource_id: resource.id });
const resourceField2 = await create('resource_field', { resource_id: resource.id });
const customFieldsRepo = new ResourceCustomFieldRepository(Expense);
await customFieldsRepo.loadResource();
await customFieldsRepo.loadResourceCustomFields();
expect(customFieldsRepo.customFields.length).equals(2);
});
});
describe('fetchCustomFieldsMetadata', () => {
it('Should fetches all custom fields metadata that associated to the resource and resource item.', async () => {
const resource = await create('resource', { name: 'Expense' });
const resourceField = await create('resource_field', { resource_id: resource.id });
const resourceField2 = await create('resource_field', { resource_id: resource.id });
const expense = await create('expense');
const fieldMetadata = await create('resource_custom_field_metadata', {
resource_id: resource.id, resource_item_id: expense.id,
});
const customFieldsRepo = new ResourceCustomFieldRepository(Expense);
await customFieldsRepo.load();
await customFieldsRepo.fetchCustomFieldsMetadata(expense.id);
expect(customFieldsRepo.metadata[expense.id].metadata.length).equals(1);
expect(customFieldsRepo.metadata[expense.id].metadata[0].key).equals(fieldMetadata.key);
expect(customFieldsRepo.metadata[expense.id].metadata[0].value).equals(fieldMetadata.value);
});
});
describe('fillCustomFields', () => {
it('Should fill custom fields metadata attributes to metadata object.', async () => {
const resource = await create('resource', { name: 'Expense' });
const resourceField = await create('resource_field', { resource_id: resource.id });
const expense = await create('expense');
const customFieldsRepo = new ResourceCustomFieldRepository(Expense);
await customFieldsRepo.load();
await customFieldsRepo.fetchCustomFieldsMetadata(expense.id);
customFieldsRepo.fillCustomFields(expense.id, [
{
key: resourceField.key,
value: 'Hello World',
},
]);
expect(customFieldsRepo.fieldsMetadata[expense.id].metadata.length).equals(1);
expect(customFieldsRepo.filledCustomFields[expense.id].length).equals(1);
});
});
describe('saveCustomFields', () => {
it('Should save the given custom fields metadata to the resource item.', async () => {
const resource = await create('resource', { name: 'Expense' });
const resourceField = await create('resource_field', { resource_id: resource.id });
const expense = await create('expense');
const fieldMetadata = await create('resource_custom_field_metadata', {
key: resourceField.slug,
resource_id: resource.id,
resource_item_id: expense.id,
});
const customFieldsRepo = new ResourceCustomFieldRepository(Expense);
await customFieldsRepo.load();
await customFieldsRepo.fetchCustomFieldsMetadata(expense.id);
customFieldsRepo.fillCustomFields(expense.id, [
{ key: resourceField.slug, value: 'Hello World' },
]);
await customFieldsRepo.saveCustomFields(expense.id);
const updateResourceFieldData = await ResourceFieldMetadata.query();
expect(updateResourceFieldData.metadata[0].value).equals('Hello World');
});
});
describe('validateExistCustomFields', () => {
});
});

View File

@@ -1,89 +0,0 @@
import {
create,
expect,
request,
login,
} from '~/testInit';
let loginRes;
describe('ViewRolesBuilder', () => {
beforeEach(async () => {
loginRes = await login();
});
afterEach(() => {
loginRes = null;
});
it('Should not retrieve results when there is no match query from view roles.', async () => {
const expenseResource = await create('resource', { name: 'expenses' });
const expenseField = await create('resource_field', {
label_name: 'Expense Account',
column_key: 'expense_account',
data_type: 'integer',
resource_id: expenseResource.id,
active: true,
predefined: true,
});
const expenseView = await create('view', {
name: 'Expense View',
resource_id: expenseResource.id,
roles_logic_expression: '1',
});
const expenseViewRole = await create('view_role', {
view_id: expenseView.id,
index: 1,
field_id: expenseField.id,
value: '12',
comparator: 'equals',
});
const expenseAccount = await create('account', { id: 10 });
const expense = await create('expense', { expense_account_id: expenseAccount.id });
const res = await request()
.get('/api/expenses')
.set('x-access-token', loginRes.body.token)
.query({ custom_view_id: expenseView.id })
.send();
expect(res.status).equals(200);
expect(res.body.expenses.results.length).equals(0);
});
it('Should retrieve results that match custom view conditionals roles.', async () => {
const expenseResource = await create('resource', { name: 'expenses' });
const expenseField = await create('resource_field', {
label_name: 'Expense Account',
column_key: 'expense_account',
data_type: 'integer',
resource_id: expenseResource.id,
active: true,
predefined: true,
});
const expenseView = await create('view', {
name: 'Expense View',
resource_id: expenseResource.id,
roles_logic_expression: '1',
});
const expenseViewRole = await create('view_role', {
view_id: expenseView.id,
index: 1,
field_id: expenseField.id,
value: '10',
comparator: 'equals',
});
const expenseAccount = await create('account', { id: 10 });
const expense = await create('expense', { expense_account_id: expenseAccount.id });
const res = await request()
.get('/api/expenses')
.set('x-access-token', loginRes.body.token)
.query({ custom_view_id: expenseView.id })
.send();
expect(res.status).equals(200);
expect(res.body.expenses.results.length).equals(1);
});
});