@angular/material
Version:
Angular Material
449 lines • 40.5 kB
JavaScript
/**
* @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"]}