mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 10:04:11 +00:00
101353: Add tests for BrowseByTaxonomyPageComponent
This commit is contained in:
@@ -1,14 +1,21 @@
|
|||||||
import { ComponentFixture, TestBed } from '@angular/core/testing';
|
import { ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
import { BrowseByTaxonomyPageComponent } from './browse-by-taxonomy-page.component';
|
import { BrowseByTaxonomyPageComponent } from './browse-by-taxonomy-page.component';
|
||||||
|
import { VocabularyEntryDetail } from '../../core/submission/vocabularies/models/vocabulary-entry-detail.model';
|
||||||
|
import { TranslateModule } from '@ngx-translate/core';
|
||||||
|
import { NO_ERRORS_SCHEMA } from '@angular/core';
|
||||||
|
|
||||||
describe('BrowseByTaxonomyPageComponent', () => {
|
describe('BrowseByTaxonomyPageComponent', () => {
|
||||||
let component: BrowseByTaxonomyPageComponent;
|
let component: BrowseByTaxonomyPageComponent;
|
||||||
let fixture: ComponentFixture<BrowseByTaxonomyPageComponent>;
|
let fixture: ComponentFixture<BrowseByTaxonomyPageComponent>;
|
||||||
|
let detail1: VocabularyEntryDetail;
|
||||||
|
let detail2: VocabularyEntryDetail;
|
||||||
|
|
||||||
beforeEach(async () => {
|
beforeEach(async () => {
|
||||||
await TestBed.configureTestingModule({
|
await TestBed.configureTestingModule({
|
||||||
declarations: [ BrowseByTaxonomyPageComponent ]
|
imports: [ TranslateModule.forRoot() ],
|
||||||
|
declarations: [ BrowseByTaxonomyPageComponent ],
|
||||||
|
schemas: [NO_ERRORS_SCHEMA]
|
||||||
})
|
})
|
||||||
.compileComponents();
|
.compileComponents();
|
||||||
});
|
});
|
||||||
@@ -17,9 +24,47 @@ describe('BrowseByTaxonomyPageComponent', () => {
|
|||||||
fixture = TestBed.createComponent(BrowseByTaxonomyPageComponent);
|
fixture = TestBed.createComponent(BrowseByTaxonomyPageComponent);
|
||||||
component = fixture.componentInstance;
|
component = fixture.componentInstance;
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
|
detail1 = new VocabularyEntryDetail();
|
||||||
|
detail2 = new VocabularyEntryDetail();
|
||||||
|
detail1.value = 'HUMANITIES and RELIGION';
|
||||||
|
detail2.value = 'TECHNOLOGY';
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should create', () => {
|
it('should create', () => {
|
||||||
expect(component).toBeTruthy();
|
expect(component).toBeTruthy();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should handle select event', () => {
|
||||||
|
component.onSelect(detail1);
|
||||||
|
expect(component.selectedItems.length).toBe(1);
|
||||||
|
expect(component.selectedItems).toContain(detail1);
|
||||||
|
expect(component.selectedItems.length).toBe(1);
|
||||||
|
expect(component.filterValues).toEqual(['HUMANITIES and RELIGION,equals'] );
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle select event with multiple selected items', () => {
|
||||||
|
component.onSelect(detail1);
|
||||||
|
component.onSelect(detail2);
|
||||||
|
expect(component.selectedItems.length).toBe(2);
|
||||||
|
expect(component.selectedItems).toContain(detail1, detail2);
|
||||||
|
expect(component.selectedItems.length).toBe(2);
|
||||||
|
expect(component.filterValues).toEqual(['HUMANITIES and RELIGION,equals', 'TECHNOLOGY,equals'] );
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle deselect event', () => {
|
||||||
|
component.onSelect(detail1);
|
||||||
|
component.onSelect(detail2);
|
||||||
|
expect(component.selectedItems.length).toBe(2);
|
||||||
|
expect(component.selectedItems.length).toBe(2);
|
||||||
|
component.onDeselect(detail1);
|
||||||
|
expect(component.selectedItems.length).toBe(1);
|
||||||
|
expect(component.selectedItems).toContain(detail2);
|
||||||
|
expect(component.selectedItems.length).toBe(1);
|
||||||
|
expect(component.filterValues).toEqual(['TECHNOLOGY,equals'] );
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
fixture.destroy();
|
||||||
|
component = null;
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user