UNPKG

@angular/material

Version:
449 lines 40.5 kB
/** * @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.io/license */ import { __awaiter, __extends, __generator, __values } from "tslib"; import { coerceBooleanProperty } from '@angular/cdk/coercion'; import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing'; /** Harness for interacting with a standard mat-radio-group in tests. */ var MatRadioGroupHarness = /** @class */ (function (_super) { __extends(MatRadioGroupHarness, _super); function MatRadioGroupHarness() { return _super !== null && _super.apply(this, arguments) || this; } /** * Gets a `HarnessPredicate` that can be used to search for a `MatRadioGroupHarness` that meets * certain criteria. * @param options Options for filtering which radio group instances are considered a match. * @return a `HarnessPredicate` configured with the given options. */ MatRadioGroupHarness.with = function (options) { if (options === void 0) { options = {}; } return new HarnessPredicate(MatRadioGroupHarness, options) .addOption('name', options.name, this._checkRadioGroupName); }; /** Gets the name of the radio-group. */ MatRadioGroupHarness.prototype.getName = function () { return __awaiter(this, void 0, void 0, function () { var hostName, radioNames; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._getGroupNameFromHost()]; case 1: hostName = _a.sent(); // It's not possible to always determine the "name" of a radio-group by reading // the attribute. This is because the radio-group does not set the "name" as an // element attribute if the "name" value is set through a binding. if (hostName !== null) { return [2 /*return*/, hostName]; } return [4 /*yield*/, this._getNamesFromRadioButtons()]; case 2: radioNames = _a.sent(); if (!radioNames.length) { return [2 /*return*/, null]; } if (!this._checkRadioNamesInGroupEqual(radioNames)) { throw Error('Radio buttons in radio-group have mismatching names.'); } return [2 /*return*/, radioNames[0]]; } }); }); }; /** Gets the id of the radio-group. */ MatRadioGroupHarness.prototype.getId = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.host()]; case 1: return [2 /*return*/, (_a.sent()).getProperty('id')]; } }); }); }; /** Gets the checked radio-button in a radio-group. */ MatRadioGroupHarness.prototype.getCheckedRadioButton = function () { return __awaiter(this, void 0, void 0, function () { var _a, _b, radioButton, e_1_1; var e_1, _c; return __generator(this, function (_d) { switch (_d.label) { case 0: _d.trys.push([0, 6, 7, 8]); return [4 /*yield*/, this.getRadioButtons()]; case 1: _a = __values.apply(void 0, [_d.sent()]), _b = _a.next(); _d.label = 2; case 2: if (!!_b.done) return [3 /*break*/, 5]; radioButton = _b.value; return [4 /*yield*/, radioButton.isChecked()]; case 3: if (_d.sent()) { return [2 /*return*/, radioButton]; } _d.label = 4; case 4: _b = _a.next(); return [3 /*break*/, 2]; case 5: return [3 /*break*/, 8]; case 6: e_1_1 = _d.sent(); e_1 = { error: e_1_1 }; return [3 /*break*/, 8]; case 7: try { if (_b && !_b.done && (_c = _a.return)) _c.call(_a); } finally { if (e_1) throw e_1.error; } return [7 /*endfinally*/]; case 8: return [2 /*return*/, null]; } }); }); }; /** Gets the checked value of the radio-group. */ MatRadioGroupHarness.prototype.getCheckedValue = function () { return __awaiter(this, void 0, void 0, function () { var checkedRadio; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.getCheckedRadioButton()]; case 1: checkedRadio = _a.sent(); if (!checkedRadio) { return [2 /*return*/, null]; } return [2 /*return*/, checkedRadio.getValue()]; } }); }); }; /** * Gets a list of radio buttons which are part of the radio-group. * @param filter Optionally filters which radio buttons are included. */ MatRadioGroupHarness.prototype.getRadioButtons = function (filter) { if (filter === void 0) { filter = {}; } return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { return [2 /*return*/, this.locatorForAll(MatRadioButtonHarness.with(filter))()]; }); }); }; /** * Checks a radio button in this group. * @param filter An optional filter to apply to the child radio buttons. The first tab matching * the filter will be selected. */ MatRadioGroupHarness.prototype.checkRadioButton = function (filter) { if (filter === void 0) { filter = {}; } return __awaiter(this, void 0, void 0, function () { var radioButtons; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.getRadioButtons(filter)]; case 1: radioButtons = _a.sent(); if (!radioButtons.length) { throw Error("Could not find radio button matching " + JSON.stringify(filter)); } return [2 /*return*/, radioButtons[0].check()]; } }); }); }; /** Gets the name attribute of the host element. */ MatRadioGroupHarness.prototype._getGroupNameFromHost = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.host()]; case 1: return [2 /*return*/, (_a.sent()).getAttribute('name')]; } }); }); }; /** Gets a list of the name attributes of all child radio buttons. */ MatRadioGroupHarness.prototype._getNamesFromRadioButtons = function () { return __awaiter(this, void 0, void 0, function () { var groupNames, _a, _b, radio, radioName, e_2_1; var e_2, _c; return __generator(this, function (_d) { switch (_d.label) { case 0: groupNames = []; _d.label = 1; case 1: _d.trys.push([1, 7, 8, 9]); return [4 /*yield*/, this.getRadioButtons()]; case 2: _a = __values.apply(void 0, [_d.sent()]), _b = _a.next(); _d.label = 3; case 3: if (!!_b.done) return [3 /*break*/, 6]; radio = _b.value; return [4 /*yield*/, radio.getName()]; case 4: radioName = _d.sent(); if (radioName !== null) { groupNames.push(radioName); } _d.label = 5; case 5: _b = _a.next(); return [3 /*break*/, 3]; case 6: return [3 /*break*/, 9]; case 7: e_2_1 = _d.sent(); e_2 = { error: e_2_1 }; return [3 /*break*/, 9]; case 8: try { if (_b && !_b.done && (_c = _a.return)) _c.call(_a); } finally { if (e_2) throw e_2.error; } return [7 /*endfinally*/]; case 9: return [2 /*return*/, groupNames]; } }); }); }; /** Checks if the specified radio names are all equal. */ MatRadioGroupHarness.prototype._checkRadioNamesInGroupEqual = function (radioNames) { var e_3, _a; var groupName = null; try { for (var radioNames_1 = __values(radioNames), radioNames_1_1 = radioNames_1.next(); !radioNames_1_1.done; radioNames_1_1 = radioNames_1.next()) { var radioName = radioNames_1_1.value; if (groupName === null) { groupName = radioName; } else if (groupName !== radioName) { return false; } } } catch (e_3_1) { e_3 = { error: e_3_1 }; } finally { try { if (radioNames_1_1 && !radioNames_1_1.done && (_a = radioNames_1.return)) _a.call(radioNames_1); } finally { if (e_3) throw e_3.error; } } return true; }; /** * Checks if a radio-group harness has the given name. Throws if a radio-group with * matching name could be found but has mismatching radio-button names. */ MatRadioGroupHarness._checkRadioGroupName = function (harness, name) { return __awaiter(this, void 0, void 0, function () { var radioNames; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, harness._getGroupNameFromHost()]; case 1: // Check if there is a radio-group which has the "name" attribute set // to the expected group name. It's not possible to always determine // the "name" of a radio-group by reading the attribute. This is because // the radio-group does not set the "name" as an element attribute if the // "name" value is set through a binding. if ((_a.sent()) === name) { return [2 /*return*/, true]; } return [4 /*yield*/, harness._getNamesFromRadioButtons()]; case 2: radioNames = _a.sent(); if (radioNames.indexOf(name) === -1) { return [2 /*return*/, false]; } if (!harness._checkRadioNamesInGroupEqual(radioNames)) { throw Error("The locator found a radio-group with name \"" + name + "\", but some " + "radio-button's within the group have mismatching names, which is invalid."); } return [2 /*return*/, true]; } }); }); }; /** The selector for the host element of a `MatRadioGroup` instance. */ MatRadioGroupHarness.hostSelector = 'mat-radio-group'; return MatRadioGroupHarness; }(ComponentHarness)); export { MatRadioGroupHarness }; /** Harness for interacting with a standard mat-radio-button in tests. */ var MatRadioButtonHarness = /** @class */ (function (_super) { __extends(MatRadioButtonHarness, _super); function MatRadioButtonHarness() { var _this = _super !== null && _super.apply(this, arguments) || this; _this._textLabel = _this.locatorFor('.mat-radio-label-content'); _this._clickLabel = _this.locatorFor('.mat-radio-label'); _this._input = _this.locatorFor('input'); return _this; } /** * Gets a `HarnessPredicate` that can be used to search for a `MatRadioButtonHarness` that meets * certain criteria. * @param options Options for filtering which radio button instances are considered a match. * @return a `HarnessPredicate` configured with the given options. */ MatRadioButtonHarness.with = function (options) { var _this = this; if (options === void 0) { options = {}; } return new HarnessPredicate(MatRadioButtonHarness, options) .addOption('label', options.label, function (harness, label) { return HarnessPredicate.stringMatches(harness.getLabelText(), label); }) .addOption('name', options.name, function (harness, name) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, harness.getName()]; case 1: return [2 /*return*/, (_a.sent()) === name]; } }); }); }); }; /** Whether the radio-button is checked. */ MatRadioButtonHarness.prototype.isChecked = function () { return __awaiter(this, void 0, void 0, function () { var checked, _a; return __generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, this._input()]; case 1: checked = (_b.sent()).getProperty('checked'); _a = coerceBooleanProperty; return [4 /*yield*/, checked]; case 2: return [2 /*return*/, _a.apply(void 0, [_b.sent()])]; } }); }); }; /** Whether the radio-button is disabled. */ MatRadioButtonHarness.prototype.isDisabled = function () { return __awaiter(this, void 0, void 0, function () { var disabled, _a; return __generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, this._input()]; case 1: disabled = (_b.sent()).getAttribute('disabled'); _a = coerceBooleanProperty; return [4 /*yield*/, disabled]; case 2: return [2 /*return*/, _a.apply(void 0, [_b.sent()])]; } }); }); }; /** Whether the radio-button is required. */ MatRadioButtonHarness.prototype.isRequired = function () { return __awaiter(this, void 0, void 0, function () { var required, _a; return __generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, this._input()]; case 1: required = (_b.sent()).getAttribute('required'); _a = coerceBooleanProperty; return [4 /*yield*/, required]; case 2: return [2 /*return*/, _a.apply(void 0, [_b.sent()])]; } }); }); }; /** Gets the radio-button's name. */ MatRadioButtonHarness.prototype.getName = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._input()]; case 1: return [2 /*return*/, (_a.sent()).getAttribute('name')]; } }); }); }; /** Gets the radio-button's id. */ MatRadioButtonHarness.prototype.getId = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.host()]; case 1: return [2 /*return*/, (_a.sent()).getProperty('id')]; } }); }); }; /** * Gets the value of the radio-button. The radio-button value will be converted to a string. * * Note: This means that for radio-button's with an object as a value `[object Object]` is * intentionally returned. */ MatRadioButtonHarness.prototype.getValue = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._input()]; case 1: return [2 /*return*/, (_a.sent()).getProperty('value')]; } }); }); }; /** Gets the radio-button's label text. */ MatRadioButtonHarness.prototype.getLabelText = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._textLabel()]; case 1: return [2 /*return*/, (_a.sent()).text()]; } }); }); }; /** Focuses the radio-button. */ MatRadioButtonHarness.prototype.focus = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._input()]; case 1: return [2 /*return*/, (_a.sent()).focus()]; } }); }); }; /** Blurs the radio-button. */ MatRadioButtonHarness.prototype.blur = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._input()]; case 1: return [2 /*return*/, (_a.sent()).blur()]; } }); }); }; /** * Puts the radio-button in a checked state by clicking it if it is currently unchecked, * or doing nothing if it is already checked. */ MatRadioButtonHarness.prototype.check = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.isChecked()]; case 1: if (!!(_a.sent())) return [3 /*break*/, 3]; return [4 /*yield*/, this._clickLabel()]; case 2: return [2 /*return*/, (_a.sent()).click()]; case 3: return [2 /*return*/]; } }); }); }; /** The selector for the host element of a `MatRadioButton` instance. */ MatRadioButtonHarness.hostSelector = 'mat-radio-button'; return MatRadioButtonHarness; }(ComponentHarness)); export { MatRadioButtonHarness }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-harness.js","sourceRoot":"","sources":["../../../../../../../../../../../../src/material/radio/testing/radio-harness.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {ComponentHarness, HarnessPredicate} from '@angular/cdk/testing';\nimport {RadioButtonHarnessFilters, RadioGroupHarnessFilters} from './radio-harness-filters';\n\n/** Harness for interacting with a standard mat-radio-group in tests. */\nexport class MatRadioGroupHarness extends ComponentHarness {\n  /** The selector for the host element of a `MatRadioGroup` instance. */\n  static hostSelector = 'mat-radio-group';\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a `MatRadioGroupHarness` that meets\n   * certain criteria.\n   * @param options Options for filtering which radio group instances are considered a match.\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: RadioGroupHarnessFilters = {}): HarnessPredicate<MatRadioGroupHarness> {\n    return new HarnessPredicate(MatRadioGroupHarness, options)\n        .addOption('name', options.name, this._checkRadioGroupName);\n  }\n\n  /** Gets the name of the radio-group. */\n  async getName(): Promise<string|null> {\n    const hostName = await this._getGroupNameFromHost();\n    // It's not possible to always determine the \"name\" of a radio-group by reading\n    // the attribute. This is because the radio-group does not set the \"name\" as an\n    // element attribute if the \"name\" value is set through a binding.\n    if (hostName !== null) {\n      return hostName;\n    }\n    // In case we couldn't determine the \"name\" of a radio-group by reading the\n    // \"name\" attribute, we try to determine the \"name\" of the group by going\n    // through all radio buttons.\n    const radioNames = await this._getNamesFromRadioButtons();\n    if (!radioNames.length) {\n      return null;\n    }\n    if (!this._checkRadioNamesInGroupEqual(radioNames)) {\n      throw Error('Radio buttons in radio-group have mismatching names.');\n    }\n    return radioNames[0]!;\n  }\n\n  /** Gets the id of the radio-group. */\n  async getId(): Promise<string|null> {\n    return (await this.host()).getProperty('id');\n  }\n\n  /** Gets the checked radio-button in a radio-group. */\n  async getCheckedRadioButton(): Promise<MatRadioButtonHarness|null> {\n    for (let radioButton of await this.getRadioButtons()) {\n      if (await radioButton.isChecked()) {\n        return radioButton;\n      }\n    }\n    return null;\n  }\n\n  /** Gets the checked value of the radio-group. */\n  async getCheckedValue(): Promise<string|null> {\n    const checkedRadio = await this.getCheckedRadioButton();\n    if (!checkedRadio) {\n      return null;\n    }\n    return checkedRadio.getValue();\n  }\n\n  /**\n   * Gets a list of radio buttons which are part of the radio-group.\n   * @param filter Optionally filters which radio buttons are included.\n   */\n  async getRadioButtons(filter: RadioButtonHarnessFilters = {}): Promise<MatRadioButtonHarness[]> {\n    return this.locatorForAll(MatRadioButtonHarness.with(filter))();\n  }\n\n  /**\n   * Checks a radio button in this group.\n   * @param filter An optional filter to apply to the child radio buttons. The first tab matching\n   *     the filter will be selected.\n   */\n  async checkRadioButton(filter: RadioButtonHarnessFilters = {}): Promise<void> {\n    const radioButtons = await this.getRadioButtons(filter);\n    if (!radioButtons.length) {\n      throw Error(`Could not find radio button matching ${JSON.stringify(filter)}`);\n    }\n    return radioButtons[0].check();\n  }\n\n  /** Gets the name attribute of the host element. */\n  private async _getGroupNameFromHost() {\n    return (await this.host()).getAttribute('name');\n  }\n\n  /** Gets a list of the name attributes of all child radio buttons. */\n  private async _getNamesFromRadioButtons(): Promise<string[]> {\n    const groupNames: string[] = [];\n    for (let radio of await this.getRadioButtons()) {\n      const radioName = await radio.getName();\n      if (radioName !== null) {\n        groupNames.push(radioName);\n      }\n    }\n    return groupNames;\n  }\n\n  /** Checks if the specified radio names are all equal. */\n  private _checkRadioNamesInGroupEqual(radioNames: string[]): boolean {\n    let groupName: string|null = null;\n    for (let radioName of radioNames) {\n      if (groupName === null) {\n        groupName = radioName;\n      } else if (groupName !== radioName) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  /**\n   * Checks if a radio-group harness has the given name. Throws if a radio-group with\n   * matching name could be found but has mismatching radio-button names.\n   */\n  private static async _checkRadioGroupName(harness: MatRadioGroupHarness, name: string) {\n    // Check if there is a radio-group which has the \"name\" attribute set\n    // to the expected group name. It's not possible to always determine\n    // the \"name\" of a radio-group by reading the attribute. This is because\n    // the radio-group does not set the \"name\" as an element attribute if the\n    // \"name\" value is set through a binding.\n    if (await harness._getGroupNameFromHost() === name) {\n      return true;\n    }\n    // Check if there is a group with radio-buttons that all have the same\n    // expected name. This implies that the group has the given name. It's\n    // not possible to always determine the name of a radio-group through\n    // the attribute because there is\n    const radioNames = await harness._getNamesFromRadioButtons();\n    if (radioNames.indexOf(name) === -1) {\n      return false;\n    }\n    if (!harness._checkRadioNamesInGroupEqual(radioNames)) {\n      throw Error(\n          `The locator found a radio-group with name \"${name}\", but some ` +\n          `radio-button's within the group have mismatching names, which is invalid.`);\n    }\n    return true;\n  }\n}\n\n/** Harness for interacting with a standard mat-radio-button in tests. */\nexport class MatRadioButtonHarness extends ComponentHarness {\n  /** The selector for the host element of a `MatRadioButton` instance. */\n  static hostSelector = 'mat-radio-button';\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a `MatRadioButtonHarness` that meets\n   * certain criteria.\n   * @param options Options for filtering which radio button instances are considered a match.\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: RadioButtonHarnessFilters = {}): HarnessPredicate<MatRadioButtonHarness> {\n    return new HarnessPredicate(MatRadioButtonHarness, options)\n        .addOption(\n            'label', options.label,\n            (harness, label) => HarnessPredicate.stringMatches(harness.getLabelText(), label))\n        .addOption(\n            'name', options.name, async (harness, name) => (await harness.getName()) === name);\n  }\n\n  private _textLabel = this.locatorFor('.mat-radio-label-content');\n  private _clickLabel = this.locatorFor('.mat-radio-label');\n  private _input = this.locatorFor('input');\n\n  /** Whether the radio-button is checked. */\n  async isChecked(): Promise<boolean> {\n    const checked = (await this._input()).getProperty('checked');\n    return coerceBooleanProperty(await checked);\n  }\n\n  /** Whether the radio-button is disabled. */\n  async isDisabled(): Promise<boolean> {\n    const disabled = (await this._input()).getAttribute('disabled');\n    return coerceBooleanProperty(await disabled);\n  }\n\n  /** Whether the radio-button is required. */\n  async isRequired(): Promise<boolean> {\n    const required = (await this._input()).getAttribute('required');\n    return coerceBooleanProperty(await required);\n  }\n\n  /** Gets the radio-button's name. */\n  async getName(): Promise<string|null> {\n    return (await this._input()).getAttribute('name');\n  }\n\n  /** Gets the radio-button's id. */\n  async getId(): Promise<string|null> {\n    return (await this.host()).getProperty('id');\n  }\n\n  /**\n   * Gets the value of the radio-button. The radio-button value will be converted to a string.\n   *\n   * Note: This means that for radio-button's with an object as a value `[object Object]` is\n   * intentionally returned.\n   */\n  async getValue(): Promise<string|null> {\n    return (await this._input()).getProperty('value');\n  }\n\n  /** Gets the radio-button's label text. */\n  async getLabelText(): Promise<string> {\n    return (await this._textLabel()).text();\n  }\n\n  /** Focuses the radio-button. */\n  async focus(): Promise<void> {\n    return (await this._input()).focus();\n  }\n\n  /** Blurs the radio-button. */\n  async blur(): Promise<void> {\n    return (await this._input()).blur();\n  }\n\n  /**\n   * Puts the radio-button in a checked state by clicking it if it is currently unchecked,\n   * or doing nothing if it is already checked.\n   */\n  async check(): Promise<void> {\n    if (!(await this.isChecked())) {\n      return (await this._clickLabel()).click();\n    }\n  }\n}\n"]}