12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- import { ContentContainerComponentHarness, HarnessPredicate, parallel } from '@angular/cdk/testing';
- /** Harness for interacting with a mat-snack-bar in tests. */
- class MatSnackBarHarness extends ContentContainerComponentHarness {
- // Developers can provide a custom component or template for the
- // snackbar. The canonical snack-bar parent is the "MatSnackBarContainer".
- /** The selector for the host element of a `MatSnackBar` instance. */
- static hostSelector = '.mat-mdc-snack-bar-container:not([mat-exit])';
- _messageSelector = '.mdc-snackbar__label';
- _actionButtonSelector = '.mat-mdc-snack-bar-action';
- _snackBarLiveRegion = this.locatorFor('[aria-live]');
- /**
- * Gets a `HarnessPredicate` that can be used to search for a `MatSnackBarHarness` that meets
- * certain criteria.
- * @param options Options for filtering which snack bar instances are considered a match.
- * @return a `HarnessPredicate` configured with the given options.
- */
- static with(options = {}) {
- return new HarnessPredicate(MatSnackBarHarness, options);
- }
- /**
- * Gets the role of the snack-bar. The role of a snack-bar is determined based
- * on the ARIA politeness specified in the snack-bar config.
- * @deprecated Use `getAriaLive` instead.
- * @breaking-change 13.0.0
- */
- async getRole() {
- return (await this.host()).getAttribute('role');
- }
- /**
- * Gets the aria-live of the snack-bar's live region. The aria-live of a snack-bar is
- * determined based on the ARIA politeness specified in the snack-bar config.
- */
- async getAriaLive() {
- return (await this._snackBarLiveRegion()).getAttribute('aria-live');
- }
- /**
- * Whether the snack-bar has an action. Method cannot be used for snack-bar's with custom content.
- */
- async hasAction() {
- return (await this._getActionButton()) !== null;
- }
- /**
- * Gets the description of the snack-bar. Method cannot be used for snack-bar's without action or
- * with custom content.
- */
- async getActionDescription() {
- await this._assertHasAction();
- return (await this._getActionButton()).text();
- }
- /**
- * Dismisses the snack-bar by clicking the action button. Method cannot be used for snack-bar's
- * without action or with custom content.
- */
- async dismissWithAction() {
- await this._assertHasAction();
- await (await this._getActionButton()).click();
- }
- /**
- * Gets the message of the snack-bar. Method cannot be used for snack-bar's with custom content.
- */
- async getMessage() {
- return (await this.locatorFor(this._messageSelector)()).text();
- }
- /** Gets whether the snack-bar has been dismissed. */
- async isDismissed() {
- // We consider the snackbar dismissed if it's not in the DOM. We can assert that the
- // element isn't in the DOM by seeing that its width and height are zero.
- const host = await this.host();
- const [exit, dimensions] = await parallel(() => [
- // The snackbar container is marked with the "exit" attribute after it has been dismissed
- // but before the animation has finished (after which it's removed from the DOM).
- host.getAttribute('mat-exit'),
- host.getDimensions(),
- ]);
- return exit != null || (!!dimensions && dimensions.height === 0 && dimensions.width === 0);
- }
- /**
- * Asserts that the current snack-bar has an action defined. Otherwise the
- * promise will reject.
- */
- async _assertHasAction() {
- if (!(await this.hasAction())) {
- throw Error('Method cannot be used for a snack-bar without an action.');
- }
- }
- /** Gets the simple snack bar action button. */
- async _getActionButton() {
- return this.locatorForOptional(this._actionButtonSelector)();
- }
- }
- export { MatSnackBarHarness };
- //# sourceMappingURL=testing.mjs.map
|