sass-references/angular-material/material/progress-spinner/testing/progress-spinner-harness.ts

49 lines
1.8 KiB
TypeScript

/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.dev/license
*/
import {coerceNumberProperty} from '@angular/cdk/coercion';
import {
ComponentHarness,
ComponentHarnessConstructor,
HarnessPredicate,
} from '@angular/cdk/testing';
import {ProgressSpinnerMode} from '@angular/material/progress-spinner';
import {ProgressSpinnerHarnessFilters} from './progress-spinner-harness-filters';
/** Harness for interacting with a MDC based mat-progress-spinner in tests. */
export class MatProgressSpinnerHarness extends ComponentHarness {
/** The selector for the host element of a `MatProgressSpinner` instance. */
static hostSelector = '.mat-mdc-progress-spinner';
/**
* Gets a `HarnessPredicate` that can be used to search for a progress spinnner with specific
* attributes.
* @param options Options for filtering which progress spinner instances are considered a match.
* @return a `HarnessPredicate` configured with the given options.
*/
static with<T extends MatProgressSpinnerHarness>(
this: ComponentHarnessConstructor<T>,
options: ProgressSpinnerHarnessFilters = {},
): HarnessPredicate<T> {
return new HarnessPredicate(this, options);
}
/** Gets the progress spinner's value. */
async getValue(): Promise<number | null> {
const host = await this.host();
const ariaValue = await host.getAttribute('aria-valuenow');
return ariaValue ? coerceNumberProperty(ariaValue) : null;
}
/** Gets the progress spinner's mode. */
async getMode(): Promise<ProgressSpinnerMode> {
const modeAttr = (await this.host()).getAttribute('mode');
return (await modeAttr) as ProgressSpinnerMode;
}
}