fune/tools/lint/eslint/eslint-plugin-mozilla/tests/avoid-removeChild.js
Victor Porof 5c7cdbd4ba Bug 1561435 - Format tools/, a=automatic-formatting
# ignore-this-changeset

Differential Revision: https://phabricator.services.mozilla.com/D35940

--HG--
extra : source : d214f0c82813e5a8d3987debc490a2c11f1308ff
2019-07-05 11:18:19 +02:00

46 lines
1.5 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
// ------------------------------------------------------------------------------
// Requirements
// ------------------------------------------------------------------------------
var rule = require("../lib/rules/avoid-removeChild");
var RuleTester = require("eslint/lib/testers/rule-tester");
const ruleTester = new RuleTester({ parserOptions: { ecmaVersion: 6 } });
// ------------------------------------------------------------------------------
// Tests
// ------------------------------------------------------------------------------
function invalidCode(code, message) {
if (!message) {
message =
"use element.remove() instead of " +
"element.parentNode.removeChild(element)";
}
return { code, errors: [{ message, type: "CallExpression" }] };
}
ruleTester.run("avoid-removeChild", rule, {
valid: [
"elt.remove();",
"elt.parentNode.parentNode.removeChild(elt2.parentNode);",
"elt.parentNode.removeChild(elt2);",
"elt.removeChild(elt2);",
],
invalid: [
invalidCode("elt.parentNode.removeChild(elt);"),
invalidCode("elt.parentNode.parentNode.removeChild(elt.parentNode);"),
invalidCode("$(e).parentNode.removeChild($(e));"),
invalidCode("$('e').parentNode.removeChild($('e'));"),
invalidCode(
"elt.removeChild(elt.firstChild);",
"use element.firstChild.remove() instead of " +
"element.removeChild(element.firstChild)"
),
],
});