7a352ddfbc
* starting UtilService refactor * pre find-replace angular.module('quay') => angular.module('QuayModule') * successfully switched to ng-metadata for backported Angular2 API * working with parent component reference in child * fixing @Output to use EventEmitter * fixed @Output events for custom git trigger * more fixes * refactored QuayPages module for backwards-compatibility * reinitialized test.db * use minified libraries * replaced references for angular-ts-decorators * fixed ng-show
82 lines
2.4 KiB
TypeScript
82 lines
2.4 KiB
TypeScript
import { LinearWorkflowSectionComponent } from './linear-workflow-section.component';
|
|
import { LinearWorkflowComponent } from './linear-workflow.component';
|
|
import { SimpleChanges } from 'ng-metadata/core';
|
|
import Spy = jasmine.Spy;
|
|
|
|
|
|
describe("LinearWorkflowSectionComponent", () => {
|
|
var component: LinearWorkflowSectionComponent;
|
|
var parentMock: LinearWorkflowComponent;
|
|
|
|
beforeEach(() => {
|
|
parentMock = new LinearWorkflowComponent();
|
|
component = new LinearWorkflowSectionComponent(parentMock);
|
|
});
|
|
|
|
describe("ngOnInit", () => {
|
|
|
|
it("calls parent component to add itself as a section", () => {
|
|
var addSectionSpy: Spy = spyOn(parentMock, "addSection").and.returnValue(null);
|
|
component.ngOnInit();
|
|
|
|
expect(addSectionSpy.calls.argsFor(0)[0]).toBe(component);
|
|
});
|
|
});
|
|
|
|
describe("ngOnChanges", () => {
|
|
var onSectionInvalidSpy: Spy;
|
|
var changesObj: SimpleChanges;
|
|
|
|
beforeEach(() => {
|
|
onSectionInvalidSpy = spyOn(parentMock, "onSectionInvalid").and.returnValue(null);
|
|
changesObj = {
|
|
sectionValid: {
|
|
currentValue: true,
|
|
previousValue: false,
|
|
isFirstChange: () => false,
|
|
},
|
|
};
|
|
});
|
|
|
|
it("does nothing if 'sectionValid' input not changed", () => {
|
|
component.ngOnChanges({});
|
|
|
|
expect(onSectionInvalidSpy).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it("does nothing if 'sectionValid' input is true", () => {
|
|
component.ngOnChanges(changesObj);
|
|
|
|
expect(onSectionInvalidSpy).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it("calls parent method to inform that section is invalid if 'sectionValid' input changed to false", () => {
|
|
changesObj['sectionValid'].currentValue = false;
|
|
component.ngOnChanges(changesObj);
|
|
|
|
expect(onSectionInvalidSpy.calls.argsFor(0)[0]).toEqual(component.sectionId);
|
|
});
|
|
});
|
|
|
|
describe("onSubmitSection", () => {
|
|
var onNextSectionSpy: Spy;
|
|
|
|
beforeEach(() => {
|
|
onNextSectionSpy = spyOn(parentMock, "onNextSection").and.returnValue(null);
|
|
});
|
|
|
|
it("does nothing if section is invalid", () => {
|
|
component.sectionValid = false;
|
|
component.onSubmitSection();
|
|
|
|
expect(onNextSectionSpy).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it("calls parent method to go to next section if section is valid", () => {
|
|
component.sectionValid = true;
|
|
component.onSubmitSection();
|
|
|
|
expect(onNextSectionSpy).toHaveBeenCalled();
|
|
});
|
|
});
|
|
});
|