mirror of https://github.com/Squidex/squidex.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
128 lines
3.4 KiB
128 lines
3.4 KiB
/*
|
|
* Squidex Headless CMS
|
|
*
|
|
* @license
|
|
* Copyright (c) Squidex UG (haftungsbeschränkt). All rights reserved.
|
|
*/
|
|
|
|
import { FormArray, FormControl } from '@angular/forms';
|
|
import { ExtendedFormArray, UndefinableFormArray } from './extended-form-array';
|
|
|
|
describe('ExtendedFormArray', () => {
|
|
it('should provide value even if controls are disabled', () => {
|
|
const control = new ExtendedFormArray([
|
|
new FormControl('1'),
|
|
new FormControl('2'),
|
|
]);
|
|
|
|
expect(control.value).toEqual(['1', '2']);
|
|
|
|
assertValue(control, ['1', '2'], () => {
|
|
control.controls[0].disable();
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('UndefinableFormArray', () => {
|
|
const tests = [{
|
|
name: 'undefined (on)',
|
|
undefinable: true,
|
|
valueExpected: undefined,
|
|
valueActual: undefined,
|
|
}, {
|
|
name: 'defined (on)',
|
|
undefinable: true,
|
|
valueExpected: [1],
|
|
valueActual: [1],
|
|
}, {
|
|
name: 'defined (off)',
|
|
undefinable: false,
|
|
valueExpected: [1],
|
|
valueActual: [1],
|
|
}];
|
|
|
|
it('should provide value even if controls are disabled', () => {
|
|
const control = new UndefinableFormArray([
|
|
new FormControl('1'),
|
|
new FormControl('2'),
|
|
]);
|
|
|
|
expect(control.value).toEqual(['1', '2']);
|
|
|
|
assertValue(control, ['1', '2'], () => {
|
|
control.controls[0].disable();
|
|
});
|
|
});
|
|
|
|
tests.forEach(x => {
|
|
it(`should set value as <${x.name}>`, () => {
|
|
const control = buildControl(x.undefinable);
|
|
|
|
assertValue(control, x.valueExpected, () => {
|
|
control.setValue(x.valueActual as any);
|
|
});
|
|
});
|
|
});
|
|
|
|
tests.forEach(x => {
|
|
it(`should patch value as <${x.name}>`, () => {
|
|
const control = buildControl(x.undefinable);
|
|
|
|
assertValue(control, x.valueExpected, () => {
|
|
control.patchValue(x.valueActual as any);
|
|
});
|
|
});
|
|
});
|
|
|
|
tests.forEach(x => {
|
|
it(`should reset value as <${x.name}>`, () => {
|
|
const control = buildControl(x.undefinable);
|
|
|
|
assertValue(control, x.valueExpected, () => {
|
|
control.reset(x.valueActual as any);
|
|
});
|
|
});
|
|
});
|
|
|
|
it('should reset value back after push', () => {
|
|
const control = new UndefinableFormArray([]);
|
|
|
|
assertValue(control, ['1'], () => {
|
|
control.setValue(undefined);
|
|
control.push(new FormControl('1'));
|
|
});
|
|
});
|
|
|
|
it('should reset value back after insert', () => {
|
|
const control = new UndefinableFormArray([]);
|
|
|
|
assertValue(control, ['1'], () => {
|
|
control.setValue(undefined);
|
|
control.insert(0, new FormControl('1'));
|
|
});
|
|
});
|
|
|
|
function buildControl(undefinable: boolean) {
|
|
return undefinable ?
|
|
new UndefinableFormArray([
|
|
new FormControl(''),
|
|
]) :
|
|
new ExtendedFormArray([
|
|
new FormControl(''),
|
|
]);
|
|
}
|
|
});
|
|
|
|
function assertValue(control: FormArray, expected: any, action: () => void) {
|
|
let currentValue: any;
|
|
|
|
control.valueChanges.subscribe(value => {
|
|
currentValue = value;
|
|
});
|
|
|
|
action();
|
|
|
|
expect(currentValue).toEqual(expected);
|
|
expect(control.getRawValue()).toEqual(expected);
|
|
expect(control.value).toEqual(expected);
|
|
}
|
|
|