This structure is closer to how ember-cli expects tests to be placed. It is not their final position, just the first step towards it.
93 lines
2.4 KiB
JavaScript
93 lines
2.4 KiB
JavaScript
import I18n from "I18n";
|
|
import componentTest from "helpers/component-test";
|
|
moduleForComponent("secret-value-list", { integration: true });
|
|
|
|
componentTest("adding a value", {
|
|
template: "{{secret-value-list values=values}}",
|
|
|
|
async test(assert) {
|
|
this.set("values", "firstKey|FirstValue\nsecondKey|secondValue");
|
|
|
|
await fillIn(".new-value-input.key", "thirdKey");
|
|
await click(".add-value-btn");
|
|
|
|
assert.ok(
|
|
find(".values .value").length === 2,
|
|
"it doesn't add the value to the list if secret is missing"
|
|
);
|
|
|
|
await fillIn(".new-value-input.key", "");
|
|
await fillIn(".new-value-input.secret", "thirdValue");
|
|
await click(".add-value-btn");
|
|
|
|
assert.ok(
|
|
find(".values .value").length === 2,
|
|
"it doesn't add the value to the list if key is missing"
|
|
);
|
|
|
|
await fillIn(".new-value-input.key", "thirdKey");
|
|
await fillIn(".new-value-input.secret", "thirdValue");
|
|
await click(".add-value-btn");
|
|
|
|
assert.ok(
|
|
find(".values .value").length === 3,
|
|
"it adds the value to the list of values"
|
|
);
|
|
|
|
assert.deepEqual(
|
|
this.values,
|
|
"firstKey|FirstValue\nsecondKey|secondValue\nthirdKey|thirdValue",
|
|
"it adds the value to the list of values"
|
|
);
|
|
},
|
|
});
|
|
|
|
componentTest("adding an invalid value", {
|
|
template: "{{secret-value-list values=values}}",
|
|
|
|
async test(assert) {
|
|
await fillIn(".new-value-input.key", "someString");
|
|
await fillIn(".new-value-input.secret", "keyWithAPipe|Hidden");
|
|
await click(".add-value-btn");
|
|
|
|
assert.ok(
|
|
find(".values .value").length === 0,
|
|
"it doesn't add the value to the list of values"
|
|
);
|
|
|
|
assert.deepEqual(
|
|
this.values,
|
|
undefined,
|
|
"it doesn't add the value to the list of values"
|
|
);
|
|
|
|
assert.ok(
|
|
find(".validation-error")
|
|
.html()
|
|
.indexOf(I18n.t("admin.site_settings.secret_list.invalid_input")) > -1,
|
|
"it shows validation error"
|
|
);
|
|
},
|
|
});
|
|
|
|
componentTest("removing a value", {
|
|
template: "{{secret-value-list values=values}}",
|
|
|
|
async test(assert) {
|
|
this.set("values", "firstKey|FirstValue\nsecondKey|secondValue");
|
|
|
|
await click(".values .value[data-index='0'] .remove-value-btn");
|
|
|
|
assert.ok(
|
|
find(".values .value").length === 1,
|
|
"it removes the value from the list of values"
|
|
);
|
|
|
|
assert.equal(
|
|
this.values,
|
|
"secondKey|secondValue",
|
|
"it removes the expected value"
|
|
);
|
|
},
|
|
});
|