blob: 7bb0d525a808cd8fd6368261636c1c7c6cbc38fa [file] [log] [blame]
/********************************************************************************
* Copyright (c) 2020 Contributors to the Eclipse Foundation
*
* See the NOTICE file(s) distributed with this work for additional
* information regarding copyright ownership.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0
*
* SPDX-License-Identifier: EPL-2.0
********************************************************************************/
import {ComponentFixture, TestBed} from "@angular/core/testing";
import {RouterTestingModule} from "@angular/router/testing";
import {MemoizedSelector} from "@ngrx/store";
import {MockStore, provideMockStore} from "@ngrx/store/testing";
import {I18nModule} from "../../../../core";
import {
IStatementInfoForm,
IStatementInfoFormValue,
newStatementFormErrorSelector,
newStatementFormLoadingSelector,
newStatementFormValueSelector,
submitNewStatementAction
} from "../../../../store";
import {NewStatementModule} from "../../new-statement.module";
import {NewStatementComponent} from "./new-statement.component";
describe("NewStatementComponent", () => {
let component: NewStatementComponent;
let fixture: ComponentFixture<NewStatementComponent>;
let store: MockStore;
let mockIsLoadingSelector: MemoizedSelector<IStatementInfoForm, boolean>;
let mockErrorSelector: MemoizedSelector<IStatementInfoForm, string>;
let mockFormSelector: MemoizedSelector<IStatementInfoForm, IStatementInfoFormValue>;
beforeEach(async () => {
await TestBed.configureTestingModule({
imports: [RouterTestingModule, NewStatementModule, I18nModule],
providers: [provideMockStore({})]
}).compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(NewStatementComponent);
component = fixture.componentInstance;
fixture.detectChanges();
store = TestBed.inject(MockStore);
mockIsLoadingSelector = store.overrideSelector(
newStatementFormLoadingSelector,
false
);
mockErrorSelector = store.overrideSelector(
newStatementFormErrorSelector,
undefined
);
mockFormSelector = store.overrideSelector(
newStatementFormValueSelector,
newStatementFormValue
);
});
it("should create", () => {
expect(component).toBeTruthy();
});
it("should dispatch action on submit", () => {
const expectedAction = submitNewStatementAction({value: {...newStatementFormValue}});
spyOn(store, "dispatch");
component.submit(newStatementFormValue);
expect(store.dispatch).toHaveBeenCalledWith(expectedAction);
});
it("should show an empty form if there is no user data", async () => {
mockIsLoadingSelector.setResult(false);
mockErrorSelector.setResult(undefined);
mockFormSelector.setResult(newStatementFormValue);
fixture.detectChanges();
await component.ngOnInit();
expect(component.form).toEqual(undefined);
});
it("should show the saved form data if appIsLoading is true", async () => {
mockIsLoadingSelector.setResult(true);
mockErrorSelector.setResult(undefined);
mockFormSelector.setResult(newStatementFormValue);
fixture.detectChanges();
await component.ngOnInit();
expect(component.form).toEqual(newStatementFormValue);
});
it("should show the saved form data if there was an error", async () => {
mockIsLoadingSelector.setResult(false);
mockErrorSelector.setResult("some error");
mockFormSelector.setResult(newStatementFormValue);
fixture.detectChanges();
await component.ngOnInit();
expect(component.form).toEqual(newStatementFormValue);
});
const newStatementFormValue: IStatementInfoFormValue = {
title: "title",
receiptDate: "21-05-2020",
dueDate: "21-05-2020",
typeId: 2,
city: "city",
district: "district"
};
});