/** * @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( this: ComponentHarnessConstructor, options: ProgressSpinnerHarnessFilters = {}, ): HarnessPredicate { return new HarnessPredicate(this, options); } /** Gets the progress spinner's value. */ async getValue(): Promise { 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 { const modeAttr = (await this.host()).getAttribute('mode'); return (await modeAttr) as ProgressSpinnerMode; } }