mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 10:04:11 +00:00
235 lines
8.2 KiB
TypeScript
235 lines
8.2 KiB
TypeScript
// Load the implementations that should be tested
|
|
import { Component, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
import { async, ComponentFixture, inject, TestBed, } from '@angular/core/testing';
|
|
import { By } from '@angular/platform-browser';
|
|
|
|
import { of as observableOf } from 'rxjs';
|
|
import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
|
|
import { TranslateModule } from '@ngx-translate/core';
|
|
|
|
import { SubmissionSectionContainerComponent } from './section-container.component';
|
|
import { createTestComponent } from '../../../shared/testing/utils';
|
|
import { SectionsType } from '../sections-type';
|
|
import { SectionsDirective } from '../sections.directive';
|
|
import { SubmissionService } from '../../submission.service';
|
|
import { SectionsService } from '../sections.service';
|
|
import { SubmissionServiceStub } from '../../../shared/testing/submission-service-stub';
|
|
import { SectionsServiceStub } from '../../../shared/testing/sections-service-stub';
|
|
import { SectionDataObject } from '../models/section-data.model';
|
|
import { mockSubmissionCollectionId, mockSubmissionId } from '../../../shared/mocks/mock-submission';
|
|
|
|
const sectionState = {
|
|
header: 'submit.progressbar.describe.stepone',
|
|
config: 'https://rest.api/dspace-spring-rest/api/config/submissionforms/traditionalpageone',
|
|
mandatory: true,
|
|
sectionType: 'submission-form',
|
|
collapsed: false,
|
|
enabled: true,
|
|
data: {},
|
|
errors: [],
|
|
isLoading: false,
|
|
isValid: false
|
|
} as any;
|
|
|
|
const sectionObject: SectionDataObject = {
|
|
config: 'https://dspace7.4science.it/or2018/api/config/submissionforms/traditionalpageone',
|
|
mandatory: true,
|
|
data: {},
|
|
errors: [],
|
|
header: 'submit.progressbar.describe.stepone',
|
|
id: 'traditionalpageone',
|
|
sectionType: SectionsType.SubmissionForm
|
|
};
|
|
|
|
describe('SubmissionSectionContainerComponent test suite', () => {
|
|
|
|
let comp: SubmissionSectionContainerComponent;
|
|
let compAsAny: any;
|
|
let fixture: ComponentFixture<SubmissionSectionContainerComponent>;
|
|
|
|
let submissionServiceStub: SubmissionServiceStub;
|
|
let sectionsServiceStub: SectionsServiceStub;
|
|
|
|
const submissionId = mockSubmissionId;
|
|
const collectionId = mockSubmissionCollectionId;
|
|
|
|
function init() {
|
|
sectionsServiceStub = TestBed.get(SectionsService);
|
|
submissionServiceStub = TestBed.get(SubmissionService);
|
|
|
|
sectionsServiceStub.isSectionValid.and.returnValue(observableOf(true));
|
|
sectionsServiceStub.getSectionState.and.returnValue(observableOf(sectionState));
|
|
submissionServiceStub.getActiveSectionId.and.returnValue(observableOf('traditionalpageone'));
|
|
}
|
|
|
|
// async beforeEach
|
|
beforeEach(async(() => {
|
|
|
|
TestBed.configureTestingModule({
|
|
imports: [
|
|
NgbModule,
|
|
TranslateModule.forRoot()
|
|
],
|
|
declarations: [
|
|
SubmissionSectionContainerComponent,
|
|
SectionsDirective,
|
|
TestComponent,
|
|
], // declare the test component
|
|
providers: [
|
|
{ provide: SectionsService, useClass: SectionsServiceStub },
|
|
{ provide: SubmissionService, useClass: SubmissionServiceStub },
|
|
SubmissionSectionContainerComponent
|
|
],
|
|
schemas: [CUSTOM_ELEMENTS_SCHEMA]
|
|
}).compileComponents();
|
|
|
|
}));
|
|
|
|
describe('', () => {
|
|
let testComp: TestComponent;
|
|
let testFixture: ComponentFixture<TestComponent>;
|
|
let html;
|
|
|
|
// synchronous beforeEach
|
|
beforeEach(() => {
|
|
html = `
|
|
<ds-submission-section-container [collectionId]="collectionId"
|
|
[submissionId]="submissionId"
|
|
[sectionData]="object"></ds-submission-section-container>`;
|
|
|
|
testFixture = createTestComponent(html, TestComponent) as ComponentFixture<TestComponent>;
|
|
testComp = testFixture.componentInstance;
|
|
init();
|
|
});
|
|
|
|
it('should create SubmissionSectionContainerComponent', inject([SubmissionSectionContainerComponent], (app: SubmissionSectionContainerComponent) => {
|
|
expect(app).toBeDefined();
|
|
}));
|
|
});
|
|
|
|
describe('', () => {
|
|
beforeEach(() => {
|
|
init();
|
|
fixture = TestBed.createComponent(SubmissionSectionContainerComponent);
|
|
comp = fixture.componentInstance;
|
|
compAsAny = comp;
|
|
comp.submissionId = submissionId;
|
|
comp.collectionId = collectionId;
|
|
comp.sectionData = sectionObject;
|
|
|
|
spyOn(comp, 'getSectionContent');
|
|
fixture.detectChanges();
|
|
});
|
|
|
|
afterEach(() => {
|
|
fixture.destroy();
|
|
comp = null;
|
|
compAsAny = null;
|
|
});
|
|
|
|
it('should inject section properly', () => {
|
|
spyOn(comp.sectionRef, 'isEnabled').and.returnValue(observableOf(true));
|
|
spyOn(comp.sectionRef, 'hasGenericErrors').and.returnValue(false);
|
|
|
|
comp.ngOnInit();
|
|
fixture.detectChanges();
|
|
|
|
const section = fixture.debugElement.query(By.css('[id^=\'sectionContent_\']'));
|
|
expect(comp.getSectionContent).toHaveBeenCalled();
|
|
expect(section).toBeDefined();
|
|
});
|
|
|
|
it('should call removeSection properly', () => {
|
|
|
|
const mockEvent = jasmine.createSpyObj('event', {
|
|
preventDefault: jasmine.createSpy('preventDefault'),
|
|
stopPropagation: jasmine.createSpy('stopPropagation'),
|
|
});
|
|
spyOn(comp.sectionRef, 'removeSection');
|
|
comp.removeSection(mockEvent);
|
|
|
|
expect(mockEvent.preventDefault).toHaveBeenCalled();
|
|
expect(mockEvent.stopPropagation).toHaveBeenCalled();
|
|
expect(comp.sectionRef.removeSection).toHaveBeenCalledWith(submissionId, 'traditionalpageone');
|
|
});
|
|
|
|
it('should display generic section errors div', () => {
|
|
let sectionErrorsDiv = fixture.debugElement.query(By.css('[id^=\'sectionGenericError_\']'));
|
|
expect(sectionErrorsDiv).toBeNull();
|
|
|
|
spyOn(comp.sectionRef, 'isEnabled').and.returnValue(observableOf(true));
|
|
spyOn(comp.sectionRef, 'hasGenericErrors').and.returnValue(true);
|
|
|
|
comp.ngOnInit();
|
|
fixture.detectChanges();
|
|
|
|
sectionErrorsDiv = fixture.debugElement.query(By.css('[id^=\'sectionGenericError_\']'));
|
|
expect(sectionErrorsDiv).toBeDefined();
|
|
});
|
|
|
|
it('should display warning icon', () => {
|
|
|
|
spyOn(comp.sectionRef, 'isEnabled').and.returnValue(observableOf(true));
|
|
spyOn(comp.sectionRef, 'isValid').and.returnValue(observableOf(false));
|
|
spyOn(comp.sectionRef, 'hasErrors').and.returnValue(false);
|
|
|
|
comp.ngOnInit();
|
|
fixture.detectChanges();
|
|
|
|
const iconWarn = fixture.debugElement.query(By.css('i.text-warning'));
|
|
const iconErr = fixture.debugElement.query(By.css('i.text-danger'));
|
|
const iconSuccess = fixture.debugElement.query(By.css('i.text-success'));
|
|
expect(iconWarn).toBeDefined();
|
|
expect(iconErr).toBeNull();
|
|
expect(iconSuccess).toBeNull();
|
|
});
|
|
|
|
it('should display error icon', () => {
|
|
|
|
spyOn(comp.sectionRef, 'isEnabled').and.returnValue(observableOf(true));
|
|
spyOn(comp.sectionRef, 'isValid').and.returnValue(observableOf(false));
|
|
spyOn(comp.sectionRef, 'hasErrors').and.returnValue(true);
|
|
|
|
comp.ngOnInit();
|
|
fixture.detectChanges();
|
|
|
|
const iconWarn = fixture.debugElement.query(By.css('i.text-warning'));
|
|
const iconErr = fixture.debugElement.query(By.css('i.text-danger'));
|
|
const iconSuccess = fixture.debugElement.query(By.css('i.text-success'));
|
|
expect(iconWarn).toBeNull();
|
|
expect(iconErr).toBeDefined();
|
|
expect(iconSuccess).toBeNull();
|
|
});
|
|
|
|
it('should display success icon', () => {
|
|
|
|
spyOn(comp.sectionRef, 'isEnabled').and.returnValue(observableOf(true));
|
|
spyOn(comp.sectionRef, 'isValid').and.returnValue(observableOf(true));
|
|
spyOn(comp.sectionRef, 'hasErrors').and.returnValue(false);
|
|
|
|
comp.ngOnInit();
|
|
fixture.detectChanges();
|
|
|
|
const iconWarn = fixture.debugElement.query(By.css('i.text-warning'));
|
|
const iconErr = fixture.debugElement.query(By.css('i.text-danger'));
|
|
const iconSuccess = fixture.debugElement.query(By.css('i.text-success'));
|
|
expect(iconWarn).toBeNull();
|
|
expect(iconErr).toBeNull();
|
|
expect(iconSuccess).toBeDefined();
|
|
});
|
|
|
|
});
|
|
});
|
|
|
|
// declare a test component
|
|
@Component({
|
|
selector: 'ds-test-cmp',
|
|
template: ``
|
|
})
|
|
class TestComponent {
|
|
|
|
public collectionId = '1c11f3f1-ba1f-4f36-908a-3f1ea9a557eb';
|
|
public submissionId = mockSubmissionId;
|
|
public object = sectionObject;
|
|
}
|