From fb79bd764e88c92019bab9eb9a092a2d902fd996 Mon Sep 17 00:00:00 2001 From: Wojciech Duda <69160975+wojd0@users.noreply.github.com> Date: Mon, 4 Dec 2023 10:53:21 +0100 Subject: [PATCH 1/4] [AAE-18450] fixed form value not updating instantly on radio change --- .../widgets/radio-buttons/radio-buttons-cloud.widget.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.ts b/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.ts index 3b507b0f2e7..a99d4525ca5 100644 --- a/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.ts +++ b/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.ts @@ -80,7 +80,7 @@ export class RadioButtonsCloudWidgetComponent extends WidgetComponent implements onOptionClick(optionSelected: any) { this.field.value = optionSelected; - this.fieldChanged.emit(this.field); + this.onFieldChanged(this.field); } handleError(error: any) { From 829fb2ac331b53df2f48da3c0abf719574fbda8a Mon Sep 17 00:00:00 2001 From: Wojciech Duda <69160975+wojd0@users.noreply.github.com> Date: Mon, 4 Dec 2023 12:08:58 +0100 Subject: [PATCH 2/4] [AAE-18450] added tests, removed material references --- .../radio-buttons-cloud.widget.spec.ts | 77 +++++++++++-------- 1 file changed, 43 insertions(+), 34 deletions(-) diff --git a/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts b/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts index 073f96b1075..cb5ca724787 100644 --- a/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts +++ b/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts @@ -22,13 +22,17 @@ import { FormCloudService } from '../../../services/form-cloud.service'; import { RadioButtonsCloudWidgetComponent } from './radio-buttons-cloud.widget'; import { ProcessServiceCloudTestingModule } from '../../../../testing/process-service-cloud.testing.module'; import { of, throwError } from 'rxjs'; -import { By } from '@angular/platform-browser'; +import { HarnessLoader } from '@angular/cdk/testing'; +import { TestbedHarnessEnvironment } from '@angular/cdk/testing/testbed'; +import { MatRadioButtonHarness, MatRadioGroupHarness } from '@angular/material/radio/testing'; +import { MatTooltipHarness } from '@angular/material/tooltip/testing'; describe('RadioButtonsCloudWidgetComponent', () => { let fixture: ComponentFixture; let widget: RadioButtonsCloudWidgetComponent; let formCloudService: FormCloudService; let element: HTMLElement; + let loader: HarnessLoader; const restOption: FormFieldOption[] = [ { id: 'opt-1', @@ -51,6 +55,7 @@ describe('RadioButtonsCloudWidgetComponent', () => { fixture = TestBed.createComponent(RadioButtonsCloudWidgetComponent); widget = fixture.componentInstance; element = fixture.nativeElement; + loader = TestbedHarnessEnvironment.loader(fixture); widget.field = new FormFieldModel(new FormModel(), { restUrl: '' }); }); @@ -124,18 +129,15 @@ describe('RadioButtonsCloudWidgetComponent', () => { expect(widgetLabel.innerText).toBe('radio-name-label*'); expect(widget.field.isValid).toBe(false); - const option = element.querySelector('#radio-id-opt-1 label'); - option.click(); + const option = await loader.getHarness(MatRadioButtonHarness.with({ label: 'opt-name-1' })); + await option.check(); - fixture.detectChanges(); - await fixture.whenStable(); - fixture.detectChanges(); - const selectedOption = element.querySelector('[class*="mat-radio-checked"]'); - expect(selectedOption.innerText).toBe('opt-name-1'); + const selectedOption = await loader.getHarness(MatRadioButtonHarness.with({ checked: true })); + expect(await selectedOption.getLabelText()).toBe('opt-name-1'); expect(widget.field.isValid).toBe(true); }); - it('should set Radio Button as valid when required and not empty', () => { + it('should set Radio Button as valid when required and not empty', async () => { widget.field = new FormFieldModel(new FormModel({}), { id: 'radio-id', name: 'radio-name-label', @@ -149,8 +151,8 @@ describe('RadioButtonsCloudWidgetComponent', () => { }); fixture.detectChanges(); - const selectedOption = element.querySelector('[class*="mat-radio-checked"]'); - expect(selectedOption.innerText).toBe('opt-name-2'); + const selectedOption = await loader.getHarness(MatRadioButtonHarness.with({ checked: true })); + expect(await selectedOption.getLabelText()).toBe('opt-name-2'); expect(widget.field.isValid).toBe(true); }); @@ -167,22 +169,22 @@ describe('RadioButtonsCloudWidgetComponent', () => { restUrl: 'http://mocky.com/mocky-12344', value: { id: 'opt-1' } }); - fixture.detectChanges(); - const selectedOption = element.querySelector('[class*="mat-radio-checked"]'); - expect(selectedOption.innerText).toBe('opt-name-1'); + + expect(widget.isChecked(widget.field.options[0])).toBeTrue(); expect(widget.field.isValid).toBe(true); }); - it('should show error message if the restUrl failed to fetch options', () => { + it('should show error message if the restUrl failed to fetch options', async () => { spyOn(formCloudService, 'getRestWidgetData').and.returnValue(throwError('Failed to fetch options')); widget.field.restUrl = 'https://fake-rest-url'; widget.field.optionType = 'rest'; widget.field.restIdProperty = 'name'; fixture.detectChanges(); - const radioButtons = element.querySelector('mat-radio-group'); - radioButtons.click(); + const radioButtons = await loader.getHarness(MatRadioGroupHarness); + await (await radioButtons.host()).click(); + fixture.detectChanges(); const errorMessage = element.querySelector('.adf-radio-group-error-message .adf-error-text'); @@ -192,6 +194,22 @@ describe('RadioButtonsCloudWidgetComponent', () => { expect(errorMessage.textContent).toBe('FORM.FIELD.REST_API_FAILED'); }); + it('should change the value of the form when an option is clicked', async () => { + widget.field = new FormFieldModel(new FormModel({}), { + id: 'radio-id', + name: 'radio-name-label', + type: FormFieldTypes.RADIO_BUTTONS, + options: restOption + }); + fixture.detectChanges(); + const formValueSpy = spyOn(widget.formService.formRulesEvent, 'next'); + const radioButton = await loader.getHarness(MatRadioButtonHarness.with({ label: 'opt-name-1' })); + await radioButton.check(); + + expect(widget.field.value).toEqual('opt-1'); + expect(formValueSpy).toHaveBeenCalled(); + }); + describe('when tooltip is set', () => { beforeEach(() => { @@ -205,28 +223,19 @@ describe('RadioButtonsCloudWidgetComponent', () => { }); it('should show tooltip', async () => { - const radioButtonsInput = element.querySelector('mat-radio-button'); - radioButtonsInput.dispatchEvent(new Event('mouseenter')); - await fixture.whenStable(); - fixture.detectChanges(); - - const tooltipElement = fixture.debugElement.query(By.css('.mat-tooltip')).nativeElement; - expect(tooltipElement).toBeTruthy(); - expect(tooltipElement.textContent.trim()).toBe('my custom tooltip'); + const tooltip = await loader.getHarness(MatTooltipHarness); + await tooltip.show(); + expect(await tooltip.getTooltipText()).toBe('my custom tooltip'); }); it('should hide tooltip', async () => { - const radioButtonsInput = element.querySelector('mat-radio-button'); - radioButtonsInput.dispatchEvent(new Event('mouseenter')); - await fixture.whenStable(); - fixture.detectChanges(); + const radioButton = await loader.getHarness(MatRadioButtonHarness); - radioButtonsInput.dispatchEvent(new Event('mouseleave')); - await fixture.whenStable(); - fixture.detectChanges(); + await radioButton.focus(); + await radioButton.blur(); - const tooltipElement = fixture.debugElement.query(By.css('.mat-tooltip')); - expect(tooltipElement).toBeFalsy(); + const tooltipElement = await loader.getHarness(MatTooltipHarness); + expect(await tooltipElement.isOpen()).toBeFalse(); }); }); }); From 2a280eda29036ada39da6693900fec53ad8b8aec Mon Sep 17 00:00:00 2001 From: Wojciech Duda <69160975+wojd0@users.noreply.github.com> Date: Mon, 4 Dec 2023 13:15:05 +0100 Subject: [PATCH 3/4] [AAE-18450] test enhancements --- .../radio-buttons-cloud.widget.spec.ts | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts b/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts index cb5ca724787..990d637435f 100644 --- a/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts +++ b/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts @@ -151,8 +151,7 @@ describe('RadioButtonsCloudWidgetComponent', () => { }); fixture.detectChanges(); - const selectedOption = await loader.getHarness(MatRadioButtonHarness.with({ checked: true })); - expect(await selectedOption.getLabelText()).toBe('opt-name-2'); + await loader.getHarness(MatRadioButtonHarness.with({ checked: true, label: 'opt-name-2' })); expect(widget.field.isValid).toBe(true); }); @@ -195,7 +194,8 @@ describe('RadioButtonsCloudWidgetComponent', () => { }); it('should change the value of the form when an option is clicked', async () => { - widget.field = new FormFieldModel(new FormModel({}), { + const form = new FormModel({}); + widget.field = new FormFieldModel(form, { id: 'radio-id', name: 'radio-name-label', type: FormFieldTypes.RADIO_BUTTONS, @@ -223,18 +223,20 @@ describe('RadioButtonsCloudWidgetComponent', () => { }); it('should show tooltip', async () => { + const radioButton = await loader.getHarness(MatRadioButtonHarness); + await (await radioButton.host()).hover(); const tooltip = await loader.getHarness(MatTooltipHarness); - await tooltip.show(); expect(await tooltip.getTooltipText()).toBe('my custom tooltip'); }); it('should hide tooltip', async () => { const radioButton = await loader.getHarness(MatRadioButtonHarness); + const tooltipElement = await loader.getHarness(MatTooltipHarness); - await radioButton.focus(); - await radioButton.blur(); + await (await radioButton.host()).hover(); + expect(await tooltipElement.isOpen()).toBeTrue(); - const tooltipElement = await loader.getHarness(MatTooltipHarness); + await (await radioButton.host()).mouseAway(); expect(await tooltipElement.isOpen()).toBeFalse(); }); }); From 3223da58c5bbd2d76b607302e391e519b8733419 Mon Sep 17 00:00:00 2001 From: Wojciech Duda <69160975+wojd0@users.noreply.github.com> Date: Mon, 4 Dec 2023 18:07:21 +0100 Subject: [PATCH 4/4] [AAE-18450] added label to filter --- .../widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts b/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts index 990d637435f..a783446a0c5 100644 --- a/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts +++ b/lib/process-services-cloud/src/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.spec.ts @@ -132,8 +132,7 @@ describe('RadioButtonsCloudWidgetComponent', () => { const option = await loader.getHarness(MatRadioButtonHarness.with({ label: 'opt-name-1' })); await option.check(); - const selectedOption = await loader.getHarness(MatRadioButtonHarness.with({ checked: true })); - expect(await selectedOption.getLabelText()).toBe('opt-name-1'); + await loader.getHarness(MatRadioButtonHarness.with({ checked: true, label: 'opt-name-1'})); expect(widget.field.isValid).toBe(true); });