fune/tools/lint/eslint/eslint-plugin-mozilla/tests/no-compare-against-boolean-literals.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

61 lines
1.6 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/no-compare-against-boolean-literals");
var RuleTester = require("eslint/lib/testers/rule-tester");
const ruleTester = new RuleTester({ parserOptions: { ecmaVersion: 6 } });
// ------------------------------------------------------------------------------
// Tests
// ------------------------------------------------------------------------------
function callError(message) {
return [{ message, type: "BinaryExpression" }];
}
const MESSAGE = "Don't compare for inexact equality against boolean literals";
ruleTester.run("no-compare-against-boolean-literals", rule, {
valid: [`if (!foo) {}`, `if (!!foo) {}`],
invalid: [
{
code: `if (foo == true) {}`,
errors: callError(MESSAGE),
},
{
code: `if (foo != true) {}`,
errors: callError(MESSAGE),
},
{
code: `if (foo == false) {}`,
errors: callError(MESSAGE),
},
{
code: `if (foo != false) {}`,
errors: callError(MESSAGE),
},
{
code: `if (true == foo) {}`,
errors: callError(MESSAGE),
},
{
code: `if (true != foo) {}`,
errors: callError(MESSAGE),
},
{
code: `if (false == foo) {}`,
errors: callError(MESSAGE),
},
{
code: `if (false != foo) {}`,
errors: callError(MESSAGE),
},
],
});