UNPKG

igniteui-angular-sovn

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

238 lines (193 loc) 13.4 kB
import { Component, ViewChild } from '@angular/core'; import { TestBed, waitForAsync } from '@angular/core/testing'; import { By } from '@angular/platform-browser'; import { IgxAvatarComponent, IgxAvatarType, IgxAvatarSize } from './avatar.component'; import { configureTestSuite } from '../test-utils/configure-suite'; describe('Avatar', () => { configureTestSuite(); const baseClass = 'igx-avatar'; const classes = { round: `${baseClass}--rounded`, circle: `${baseClass}--circle`, small: `${baseClass}--small`, medium: `${baseClass}--medium`, large: `${baseClass}--large`, image: `${baseClass}--image`, initials: `${baseClass}--initials`, icon: `${baseClass}--icon` }; beforeAll(waitForAsync(() => { TestBed.configureTestingModule({ imports: [ InitAvatarComponent, AvatarWithAttribsComponent, IgxAvatarComponent, InitIconAvatarComponent, InitImageAvatarComponent ] }).compileComponents(); })); it('Initializes avatar with auto-incremented id', () => { const fixture = TestBed.createComponent(InitAvatarComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(instance.id).toContain('igx-avatar-'); expect(hostEl.id).toContain('igx-avatar-'); instance.id = 'customAvatar'; fixture.detectChanges(); expect(instance.id).toBe('customAvatar'); expect(hostEl.id).toBe('customAvatar'); }); it('Initializes square and round avatar', () => { const fixture = TestBed.createComponent(AvatarWithAttribsComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(instance.roundShape).toBeTruthy(); expect(instance.shape).toEqual('circle'); expect(hostEl.classList).toContain(classes.circle); expect(hostEl.classList).not.toContain(classes.round); instance.shape = "square"; fixture.detectChanges(); expect(instance.roundShape).toBeFalsy(); expect(instance.shape).toEqual('square'); expect(hostEl.classList).not.toContain(classes.round); expect(hostEl.classList).not.toContain(classes.circle); instance.shape = "rounded"; fixture.detectChanges(); expect(instance.roundShape).toBeFalsy(); expect(instance.shape).toEqual('rounded'); expect(hostEl.classList).toContain(classes.round); expect(hostEl.classList).not.toContain(classes.circle); }); it('Can change its size', () => { const fixture = TestBed.createComponent(AvatarWithAttribsComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(instance.size).toEqual(IgxAvatarSize.SMALL); expect(hostEl.classList).toContain(classes.small); instance.size = IgxAvatarSize.MEDIUM; fixture.detectChanges(); expect(instance.size).toEqual(IgxAvatarSize.MEDIUM); expect(hostEl.classList).toContain(classes.medium); instance.size = IgxAvatarSize.LARGE; fixture.detectChanges(); expect(instance.size).toEqual(IgxAvatarSize.LARGE); expect(hostEl.classList).toContain(classes.large); instance.size = 'nonsense' as any; fixture.detectChanges(); expect(instance.size).toEqual(IgxAvatarSize.SMALL); expect(hostEl.classList).toContain(classes.small); }); it('Initializes default avatar', () => { const fixture = TestBed.createComponent(InitAvatarComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(instance.initials).toBeUndefined(); expect(instance.src).toBeUndefined(); expect(instance.icon).toBeUndefined(); expect(instance.shape).toEqual('square'); expect(hostEl.textContent).toEqual('TEST'); }); it('Initializes initials avatar', () => { const fixture = TestBed.createComponent(AvatarWithAttribsComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(instance.type).toEqual(IgxAvatarType.INITIALS); expect(instance.initials).toEqual('ZK'); expect(hostEl.querySelector('span').textContent).toEqual('ZK'); expect(hostEl.classList).toContain(classes.initials); }); it('Initializes icon avatar', () => { const fixture = TestBed.createComponent(InitIconAvatarComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(instance.type).toEqual(IgxAvatarType.ICON); expect(instance.icon).toBeTruthy(); expect(hostEl.classList).toContain(classes.icon); }); it('Initializes image avatar', () => { const fixture = TestBed.createComponent(InitImageAvatarComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(instance.type).toEqual(IgxAvatarType.IMAGE); const image = instance.elementRef.nativeElement.children[0]; expect(image).toBeTruthy(); expect(image.style.backgroundImage).toBeDefined(); expect(image.classList).toContain(`${baseClass}__image`); expect(hostEl.classList).toContain(classes.image); }); it('Sets background and foreground colors', () => { const fixture = TestBed.createComponent(AvatarWithAttribsComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(hostEl.style.background).toEqual(instance.bgColor); expect(hostEl.style.color).toEqual(instance.color); instance.bgColor = '#000'; instance.color = '#fff'; fixture.detectChanges(); expect(hostEl.style.background).toEqual('rgb(0, 0, 0)'); expect(hostEl.style.color).toEqual('rgb(255, 255, 255)'); }); it('Sets ARIA attributes', () => { const fixture = TestBed.createComponent(InitImageAvatarComponent); fixture.detectChanges(); const instance = fixture.componentInstance.avatar; const hostEl = fixture.debugElement.query(By.css(baseClass)).nativeElement; expect(instance.roleDescription).toEqual('image avatar'); expect(hostEl.getAttribute('role')).toEqual('img'); expect(hostEl.getAttribute('aria-roledescription')).toEqual('image avatar'); expect(hostEl.getAttribute('aria-label')).toEqual('avatar'); }); }); @Component({ template: `<igx-avatar>TEST</igx-avatar>`, standalone: true, imports: [IgxAvatarComponent] }) class InitAvatarComponent { @ViewChild(IgxAvatarComponent, { static: true }) public avatar: IgxAvatarComponent; } @Component({ template: ` <igx-avatar [initials]="initials" [bgColor]="bgColor" [color]="color" size="small" [roundShape]="true"> </igx-avatar>`, standalone: true, imports: [IgxAvatarComponent] }) class AvatarWithAttribsComponent { @ViewChild(IgxAvatarComponent, { static: true }) public avatar: IgxAvatarComponent; public initials = 'ZK'; public color = 'orange'; public bgColor = 'royalblue'; } @Component({ template: `<igx-avatar icon="person"></igx-avatar>`, standalone: true, imports: [IgxAvatarComponent] }) class InitIconAvatarComponent { @ViewChild(IgxAvatarComponent, { static: true }) public avatar: IgxAvatarComponent; } @Component({ template: `<igx-avatar [src]="source"></igx-avatar>`, standalone: true, imports: [IgxAvatarComponent] }) class InitImageAvatarComponent { @ViewChild(IgxAvatarComponent, { static: true }) public avatar: IgxAvatarComponent; // eslint-disable-next-line max-len public source = ''; }