fune/tools/lint/eslint/eslint-plugin-mozilla/tests/use-includes-instead-of-indexOf.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

38 lines
1.3 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/use-includes-instead-of-indexOf");
var RuleTester = require("eslint/lib/testers/rule-tester");
const ruleTester = new RuleTester({ parserOptions: { ecmaVersion: 6 } });
// ------------------------------------------------------------------------------
// Tests
// ------------------------------------------------------------------------------
function invalidCode(code) {
let message = "use .includes instead of .indexOf";
return { code, errors: [{ message, type: "BinaryExpression" }] };
}
ruleTester.run("use-includes-instead-of-indexOf", rule, {
valid: [
"let a = foo.includes(bar);",
"let a = foo.indexOf(bar) > 0;",
"let a = foo.indexOf(bar) != 0;",
],
invalid: [
invalidCode("let a = foo.indexOf(bar) >= 0;"),
invalidCode("let a = foo.indexOf(bar) != -1;"),
invalidCode("let a = foo.indexOf(bar) !== -1;"),
invalidCode("let a = foo.indexOf(bar) == -1;"),
invalidCode("let a = foo.indexOf(bar) === -1;"),
invalidCode("let a = foo.indexOf(bar) < 0;"),
],
});