(see also licenses for dev. deps.)
Create badges to reflect the number/types of failing or passing eslint rules.
npm i eslint-formatter-badger
eslint -f badger .
Or, to get use of full options, use the CLI interface.
The programmatic API.
badgerDefault(resultsArray, {rulesMeta: <object>}, options) => ""
This method is needed as the default so as to work when called by eslint -f
.
However, the named exports badger
or badgerEngine
are to be
preferred for regular progrmmatic usage (or use our CLI) as the
ESLint formatting API forces us to adhere to these limitations:
- Return an (empty) string rather than a Promise (otherwise ESLint will print "Promise"), and as such, if used programmatically, the caller wouldn't be notified when the formatting is complete.
- The formatter adheres to the multiple argument signature, and
though we pass on
options
if this is called programmatically, ESLint does not pass in any third argument, so foreslint -f
usage, we default to checking for any options in theeslintFormatterBadgerOptions
property of the current working directory'spackage.json
.
For the structure of the resultsArray
, see https://eslint.org/docs/developer-guide/working-with-custom-formatters#the-results-object
and for the structure of the messages within that object, see https://eslint.org/docs/developer-guide/working-with-custom-formatters#the-message-object.
For the structure of the rulesMeta
object, see https://eslint.org/docs/developer-guide/working-with-custom-formatters#the-data-argument.
For options
, see badger
below.
badger({results, rulesMeta, ...options})
For the structure of the rulesMeta
object, see https://eslint.org/docs/developer-guide/working-with-custom-formatters#the-data-argument.
Note that in programmatic usage (not eslint -f
), a meta Map
as passed
in by cli.getRules()
(and as used by our badgerEngine
) can be used in addition to the
structure detailed at https://eslint.org/docs/developer-guide/working-with-custom-formatters#the-data-argument.
The other options are the same as those detailed in the CLI.
badgerEngine(options)
This is what is used by the CLI. See the CLI for the available options.
However, as a programmatic API, a few more type options are possible:
textColor
may be an array as well as a comma-separated string.- For
ruleMap
, an object may be provided in place of a string pointing to a module.
When we do not wish to lint all of node_modules
nor do we need to lint
entire project dependencies, we can use es-file-traverse
to lint just
those files which are actually in use in our project.
It can be particularly useful to make badges advertising the degree to which we have looked out for weaknesses in the third-party code we are using.
(Although any ESLint-based linting still depends on good faith (i.e., it is possible for dependencies to work around checks), one can still perform useful audits of the dependencies of one's project to catch problems of importance, such as finding code which introduces vulnerabilities or which is intrusive in polluting with globals, etc. (These tend to be more of the type of problems which third parties may be more willing to fix, as they are not mere stylistic concerns.))
Here is an example of eslint-formatter-badger
used to build our own
third-party linting badge for es-file-traverse
:
eslint-formatter-badger --mainTemplate=\"ESLint 3rd party light audit (\\${ruleMapCount} rules)\" --filteredTypes intrusive,vulnerability --ruleMap .eslintRuleTypeMap.json --outputPath badges/eslint-3rdparty.svg --eslintCache --noEslintInlineConfig --noUseEslintIgnore --noUseEslintrc --eslintConfigPath .eslintrc-3rdparty.js `es-file-traverse --file ./bin/cli.js --node --cjs`
The particular arguments which may be of interest:
--mainTemplate
- We override the main badge content here to highlight not the total of linting rules available but the total in our customruleMap
(i.e.,ruleMapCount
), which we use to indicate the number of applicable rules.--ruleMap
- Rather than relying on the default ofmeta.type
to determine rule type, we map rules in the targeted file to our own types, such as consideringno-eval
as belonging to a "vulnerability" type (rather than to the more generic "problem" type). We can then can show these types (and a count of their failures) in the badge (using--filteredTypes
to show the rule type(s) of interest).--filteredTypes
- We choose the rule types of interest (in this case, "intrusive" and "vulnerability") as used in our rule map (where we have mapped the rule names to these types).--eslintCache
- Sets ESLintcache
, creating.eslintcache
. Will be removed if ESLint called without cache, but useful for performance.--noEslintInlineConfig
- 3rd parties may disable rules you wish to check, or they may reference rules which your config does not include, causing linting errors.--noUseEslintIgnore
- Don't apply our own.eslintignore
to the explicit list of third party files we are including.--noUseEslintrc
- We don't want to check the normal hierarchy of.eslintrc.*
files, as these are used by our and other projects' for their stylstic concerns. We instead use--eslintConfigPath
to indicate the rules we wish to be applied to our visited files (including dependencies).--eslintConfigPath
- Indicates the actual rules we want applied to third party files discovered to be used by, or by the dependencies of, the--file
file passed toes-file-traverse
.- (The code in backticks, i.e., beginning
es-file-traverse...
) - This builds a list of files to pass to ESLint, i.e., only those files which are actually used (whether a dependency or our own), in this case, starting with the file./bin/cli.js
.
- filesize-badger - Locally created badges indicating file size (also buildable as part of Rollup routine)
- mocha-badge-generator - Locally created badges for Mocha test results
- coveradge - Locally-created badges for nyc/istanbul coverage
- license-badger - Locally-created badges indicating license types (by degree of permissiveness) used within or required by the project.
- Rule maps
- Accept multiple
ruleMap
's so can combine results (e.g., labeling all security rules in one map) - Bundle useful built-in config maps (optional) based on security
(e.g.,
"no-eval": "vulernable", "no-global-assign": "intrusive"
)
- Accept multiple
- Option to pass on to another reporter (so don't need to add
eslint-multiplexer
or eslint-formatter-multiple
in all cases. Could default to
spec
while allowing empty string if someone really didn't want any visuals. - See about getting tooltips into
badge-up
if external SVG allows; so can list all linting rules per section (also add to license-badger showing relevant npm packages per license type, and possibly the test names for failing Mocha tests inmocha-badge-reporter
)