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
text/typescript
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 = '';
}