1
0

Better org of tests

This commit is contained in:
2020-03-06 13:08:13 -05:00
parent 6c101bb7b2
commit 62ab887ada
4 changed files with 40 additions and 36 deletions

View File

@@ -0,0 +1,22 @@
import 'reflect-metadata';
import { Serde } from "src/serde";
import { Exclude } from 'src/decorators';
class ExcludeTestModel extends Serde<ExcludeTestModel> {
name: string;
date: Date;
description: string;
@Exclude() frontendField: string;
}
describe('@Exclude() Decorator', () => {
it('should remove properties marked during serialize', () => {
const testModel = new ExcludeTestModel().deserialize({
name: 'test model',
description: 'this is a test model',
frontendField: 'test field'
});
const serializedModel = testModel.serialize();
expect(serializedModel).toEqual({ name: 'test model', description: 'this is a test model' });
});
});

View File

@@ -0,0 +1,71 @@
import 'reflect-metadata';
import { Serde } from "src/serde";
import { Pluck } from 'src/decorators';
class PluckArrayTestModel extends Serde<PluckArrayTestModel> {
name: string;
@Pluck(['id']) nestedProperties: { id: number, name: string }[];
}
class PluckArrayTestTwoModel extends Serde<PluckArrayTestTwoModel> {
name: string;
@Pluck('id') nestedProperties: { id: number, name: string }[];
}
class PluckObjectTestModel extends Serde<PluckObjectTestModel> {
name: string;
@Pluck(['id']) nestedProperty: { id: number, name: string };
}
class PluckObjectTestTwoModel extends Serde<PluckObjectTestTwoModel> {
name: string;
@Pluck('id') nestedProperty: { id: number, name: string };
}
describe('@Pluck() Decorator', () => {
it('should pluck \'id\' (property: T[]) from marked property during serialize', () => {
const testModel = new PluckArrayTestModel().deserialize({
name: 'test model',
nestedProperties: [
{ id: 1, name: 'one' },
{ id: 2, name: 'two' }
]
});
const serializedModel = testModel.serialize();
expect(serializedModel).toEqual({ name: 'test model', nestedProperties: [{ id: 1 }, { id: 2 }] });
});
it('should pluck \'ids\' (property: number[]) from marked property during serialize', () => {
const testModel = new PluckArrayTestTwoModel().deserialize({
name: 'test model',
nestedProperties: [
{ id: 1, name: 'one' },
{ id: 2, name: 'two' }
]
});
const serializedModel = testModel.serialize();
expect(serializedModel).toEqual({ name: 'test model', nestedProperties: [1, 2] });
});
it('should pluck \'id\' (property: {k: v}) from marked property during serialize', () => {
const testModel = new PluckObjectTestModel().deserialize({
name: 'test model',
nestedProperty: { id: 2, name: 'two' }
});
const serializedModel = testModel.serialize();
expect(serializedModel).toEqual({ name: 'test model', nestedProperty: { id: 2 } });
});
it('should pluck \'id\' property: value from marked property during serialize', () => {
const testModel = new PluckObjectTestTwoModel().deserialize({
name: 'test model',
nestedProperty: { id: 2, name: 'two' }
});
const serializedModel = testModel.serialize();
expect(serializedModel).toEqual({ name: 'test model', nestedProperty: 2 });
});
});