ipsos-components
Version:
Material Design components for Angular
266 lines (200 loc) • 10.5 kB
text/typescript
import {TestBed, async} from '@angular/core/testing';
import {Component} from '@angular/core';
import {By} from '@angular/platform-browser';
import {MatProgressSpinnerModule, MatProgressSpinner} from './index';
describe('MatProgressSpinner', () => {
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [MatProgressSpinnerModule],
declarations: [
BasicProgressSpinner,
IndeterminateProgressSpinner,
ProgressSpinnerWithValueAndBoundMode,
ProgressSpinnerWithColor,
ProgressSpinnerCustomStrokeWidth,
ProgressSpinnerCustomDiameter,
SpinnerWithColor,
ProgressSpinnerWithStringValues,
],
}).compileComponents();
}));
it('should apply a mode of "determinate" if no mode is provided.', () => {
let fixture = TestBed.createComponent(BasicProgressSpinner);
fixture.detectChanges();
let progressElement = fixture.debugElement.query(By.css('mat-progress-spinner'));
expect(progressElement.componentInstance.mode).toBe('determinate');
});
it('should not modify the mode if a valid mode is provided.', () => {
let fixture = TestBed.createComponent(IndeterminateProgressSpinner);
fixture.detectChanges();
let progressElement = fixture.debugElement.query(By.css('mat-progress-spinner'));
expect(progressElement.componentInstance.mode).toBe('indeterminate');
});
it('should define a default value of zero for the value attribute', () => {
let fixture = TestBed.createComponent(BasicProgressSpinner);
fixture.detectChanges();
let progressElement = fixture.debugElement.query(By.css('mat-progress-spinner'));
expect(progressElement.componentInstance.value).toBe(0);
});
it('should set the value to 0 when the mode is set to indeterminate', () => {
let fixture = TestBed.createComponent(ProgressSpinnerWithValueAndBoundMode);
let progressElement = fixture.debugElement.query(By.css('mat-progress-spinner'));
fixture.componentInstance.mode = 'determinate';
fixture.detectChanges();
expect(progressElement.componentInstance.value).toBe(50);
fixture.componentInstance.mode = 'indeterminate';
fixture.detectChanges();
expect(progressElement.componentInstance.value).toBe(0);
});
it('should retain the value if it updates while indeterminate', () => {
let fixture = TestBed.createComponent(ProgressSpinnerWithValueAndBoundMode);
let progressElement = fixture.debugElement.query(By.css('mat-progress-spinner'));
fixture.componentInstance.mode = 'determinate';
fixture.detectChanges();
expect(progressElement.componentInstance.value).toBe(50);
fixture.componentInstance.mode = 'indeterminate';
fixture.detectChanges();
expect(progressElement.componentInstance.value).toBe(0);
fixture.componentInstance.value = 75;
fixture.detectChanges();
expect(progressElement.componentInstance.value).toBe(0);
fixture.componentInstance.mode = 'determinate';
fixture.detectChanges();
expect(progressElement.componentInstance.value).toBe(75);
});
it('should clamp the value of the progress between 0 and 100', () => {
let fixture = TestBed.createComponent(BasicProgressSpinner);
fixture.detectChanges();
let progressElement = fixture.debugElement.query(By.css('mat-progress-spinner'));
let progressComponent = progressElement.componentInstance;
progressComponent.value = 50;
expect(progressComponent.value).toBe(50);
progressComponent.value = 0;
expect(progressComponent.value).toBe(0);
progressComponent.value = 100;
expect(progressComponent.value).toBe(100);
progressComponent.value = 999;
expect(progressComponent.value).toBe(100);
progressComponent.value = -10;
expect(progressComponent.value).toBe(0);
});
it('should default to a stroke width that is 10% of the diameter', () => {
const fixture = TestBed.createComponent(ProgressSpinnerCustomDiameter);
const spinner = fixture.debugElement.query(By.directive(MatProgressSpinner));
fixture.componentInstance.diameter = 67;
fixture.detectChanges();
expect(spinner.componentInstance.strokeWidth).toBe(6.7);
});
it('should allow a custom diameter', () => {
const fixture = TestBed.createComponent(ProgressSpinnerCustomDiameter);
const spinner = fixture.debugElement.query(By.css('mat-progress-spinner')).nativeElement;
const svgElement = fixture.nativeElement.querySelector('svg');
fixture.componentInstance.diameter = 32;
fixture.detectChanges();
expect(parseInt(spinner.style.width))
.toBe(32, 'Expected the custom diameter to be applied to the host element width.');
expect(parseInt(spinner.style.height))
.toBe(32, 'Expected the custom diameter to be applied to the host element height.');
expect(parseInt(svgElement.style.width))
.toBe(32, 'Expected the custom diameter to be applied to the svg element width.');
expect(parseInt(svgElement.style.height))
.toBe(32, 'Expected the custom diameter to be applied to the svg element height.');
expect(svgElement.getAttribute('viewBox'))
.toBe('0 0 25.2 25.2', 'Expected the custom diameter to be applied to the svg viewBox.');
});
it('should allow a custom stroke width', () => {
const fixture = TestBed.createComponent(ProgressSpinnerCustomStrokeWidth);
const circleElement = fixture.nativeElement.querySelector('circle');
const svgElement = fixture.nativeElement.querySelector('svg');
fixture.componentInstance.strokeWidth = 40;
fixture.detectChanges();
expect(parseInt(circleElement.style.strokeWidth)).toBe(30, 'Expected the custom stroke ' +
'width to be applied to the circle element as a percentage of the element size.');
expect(svgElement.getAttribute('viewBox'))
.toBe('0 0 130 130', 'Expected the viewBox to be adjusted based on the stroke width.');
});
it('should expand the host element if the stroke width is greater than the default', () => {
const fixture = TestBed.createComponent(ProgressSpinnerCustomStrokeWidth);
const element = fixture.debugElement.nativeElement.querySelector('.mat-progress-spinner');
fixture.componentInstance.strokeWidth = 40;
fixture.detectChanges();
expect(element.style.width).toBe('130px');
expect(element.style.height).toBe('130px');
});
it('should not collapse the host element if the stroke width is less than the default', () => {
const fixture = TestBed.createComponent(ProgressSpinnerCustomStrokeWidth);
const element = fixture.debugElement.nativeElement.querySelector('.mat-progress-spinner');
fixture.componentInstance.strokeWidth = 5;
fixture.detectChanges();
expect(element.style.width).toBe('100px');
expect(element.style.height).toBe('100px');
});
it('should set the color class on the mat-spinner', () => {
let fixture = TestBed.createComponent(SpinnerWithColor);
fixture.detectChanges();
let progressElement = fixture.debugElement.query(By.css('mat-spinner'));
expect(progressElement.nativeElement.classList).toContain('mat-primary');
fixture.componentInstance.color = 'accent';
fixture.detectChanges();
expect(progressElement.nativeElement.classList).toContain('mat-accent');
expect(progressElement.nativeElement.classList).not.toContain('mat-primary');
});
it('should set the color class on the mat-progress-spinner', () => {
let fixture = TestBed.createComponent(ProgressSpinnerWithColor);
fixture.detectChanges();
let progressElement = fixture.debugElement.query(By.css('mat-progress-spinner'));
expect(progressElement.nativeElement.classList).toContain('mat-primary');
fixture.componentInstance.color = 'accent';
fixture.detectChanges();
expect(progressElement.nativeElement.classList).toContain('mat-accent');
expect(progressElement.nativeElement.classList).not.toContain('mat-primary');
});
it('should remove the underlying SVG element from the tab order explicitly', () => {
const fixture = TestBed.createComponent(BasicProgressSpinner);
fixture.detectChanges();
expect(fixture.nativeElement.querySelector('svg').getAttribute('focusable')).toBe('false');
});
it('should handle the number inputs being passed in as strings', () => {
const fixture = TestBed.createComponent(ProgressSpinnerWithStringValues);
const spinner = fixture.debugElement.query(By.directive(MatProgressSpinner));
const svgElement = spinner.nativeElement.querySelector('svg');
fixture.detectChanges();
expect(spinner.componentInstance.diameter).toBe(37);
expect(spinner.componentInstance.strokeWidth).toBe(11);
expect(spinner.componentInstance.value).toBe(25);
expect(spinner.nativeElement.style.width).toBe('38px');
expect(spinner.nativeElement.style.height).toBe('38px');
expect(svgElement.style.width).toBe('38px');
expect(svgElement.style.height).toBe('38px');
expect(svgElement.getAttribute('viewBox')).toBe('0 0 38 38');
});
});
({template: '<mat-progress-spinner></mat-progress-spinner>'})
class BasicProgressSpinner {}
({template: '<mat-progress-spinner [strokeWidth]="strokeWidth"></mat-progress-spinner>'})
class ProgressSpinnerCustomStrokeWidth {
strokeWidth: number;
}
({template: '<mat-progress-spinner [diameter]="diameter"></mat-progress-spinner>'})
class ProgressSpinnerCustomDiameter {
diameter: number;
}
({template: '<mat-progress-spinner mode="indeterminate"></mat-progress-spinner>'})
class IndeterminateProgressSpinner { }
({
template: '<mat-progress-spinner [value]="value" [mode]="mode"></mat-progress-spinner>'
})
class ProgressSpinnerWithValueAndBoundMode {
mode = 'indeterminate';
value = 50;
}
({template: `<mat-spinner [color]="color"></mat-spinner>`})
class SpinnerWithColor { color: string = 'primary'; }
({template: `<mat-progress-spinner value="50" [color]="color"></mat-progress-spinner>`})
class ProgressSpinnerWithColor { color: string = 'primary'; }
({
template: `
<mat-progress-spinner value="25" diameter="37" strokeWidth="11"></mat-progress-spinner>
`
})
class ProgressSpinnerWithStringValues { }