Home

Awesome

<!-- markdownlint-disable MD013 MD033 MD034 -->

NPM GROOVY LINT (+ Format & Auto-fix)

Version Downloads/week Downloads/total Test codecov Mega-Linter GitHub contributors GitHub stars Docker Pulls Docker Stars License PRs Welcome

Groovy & Jenkinsfile Linter, Formatter and Auto-fixer

New: The article about the story of npm-groovy-lint, and why you should dive in open-source community !

Based on CodeNarc , this out of the box package allows to track groovy errors and correct a part of them

Easy to integrate in a CI/CD process (Jenkins Pipeline,CircleCI...) to lint your groovy or Jenkinsfile at each build :)

You can also use this package in :

image

See CHANGELOG

Any question, problem or enhancement request ? Ask here :)

Usage

    npm-groovy-lint [OPTIONS] [FILES|PATH|PATTERN]
ParameterTypeDescription
-o<br/> --outputStringOutput format (txt,json,sarif,html,xml), or path to a file with one of these extensions<br/> Default: txt<br/> Examples:<br/> - "txt"<br/> - "json"<br/> - "./logs/myLintResults.txt"<br/> - "./logs/myLintResults.sarif"<br/> - "./logs/myLintResults.html"<br/> - "./logs/myLintResults.xml"<br/>Note: HTML and XML are directly from CodeNarc so using these formats will disable many npm-groovy-lint features
-l<br/> --loglevelStringLog level (error,warning or info)<br/>Default: info
--failonStringDefines the error level where CLI will fail (return code = 1). error,warning,info or none. Each failure level includes the more critical ones.
-c<br/> --configStringCustom path to GroovyLint config file, or preset config recommended|recommended-jenkinsfile|all<br/> Default: Browse current directory to find .groovylintrc.json|js|yml|package.json config file, or default npm-groovy-lint config if not defined.<br/>Note: command-line arguments have priority on config file properties
--parseBooleanTry to compile the source code and return parse errors (since v5.7.0, default to true, use --no-parse to deactivate)
--formatBooleanFormat source code
--fixBooleanAutomatically fix problems when possible<br/> See Auto-fixable rules
-x<br/> --fixrulesStringOption for --fix argument: List of rule identifiers to fix (if not specified, all available fixes will be applied). See Auto-fixable rules <br/> Examples:<br/> - "SpaceBeforeClosingBrace,SpaceAfterClosingBrace,UnusedImport"<br/> - "Indentation"<br/>
--nolintafterBooleanWhen format or fix is called, a new lint is performed after the fixes to update the returned error list. If you just want the updated source code and do not care about the error logs, use this parameter to improve performances
-r<br/> --rulesetsStringRuleSet file(s) to use for linting, if you do not want to use recommended rules or .groovylintrc.js defined rules.<br/>If list of comma separated strings corresponding to CodeNarc rules, a RuleSet file will be dynamically generated </br> Examples:<br/> - "./config/codenarc/RuleSet-Custom.groovy"<br/> - "./path/to/my/ruleset/files"<br/>- Indentation{"spacesPerIndentLevel":2,"severity":"warning"},UnnecessarySemicolon,UnnecessaryGString
--rulesetsoverridetypeStringIf list of rules sent in rulesets option, defines if they replace rules defined in .groovylintrc.json, or if they are appended<br/> Values: replaceConfig (default), appendConfig
-s<br/> --sourceStringIf path and files are not set, you can directly send the source code string to analyze
--verboseBooleanMore outputs in console, including performed fixes
-i<br/> --ignorepatternStringComma-separated list of Ant-style file patterns specifying files that must be ignored<br/> Default: none<br/> Example: "**/test/*""
--noserverBooleannpm-groovy-lint launches a microservice to avoid performance issues caused by loading java/groovy each time,that auto kills itself after 1h idle. Use this argument if you do not want to use this feature
--returnrulesBooleanReturn rules descriptions and URL if set
--javaexecutableStringOverride java executable to use <br/>Default: java<br/>Example: C:\Program Files\Java\jdk1.8.0_144\bin\java.exe
--javaoptionsStringOverride java options to use <br/>Default: "-Xms256m,-Xmx2048m"
--insightBooleannpm-groovy-lint collects anonymous usage statistics using amplitude, in order to make new improvements based on how users use this package. <br/> Summary charts are available at https://tinyurl.com/groovy-stats.<br/> Analytics obviously does not receive sensitive information like your code, as you can see in analytics.js.<br/> If you want to enable anonymous usage statistics, use --insight option.
--codenarcargsStringUse core CodeNarc arguments (all npm-groovy-lint arguments will be ignored)<br/> Doc: http://codenarc.github.io/CodeNarc/codenarc-command-line.html<br/> Example: npm-groovy-lint --codenarcargs -basedir="lib/example" -rulesetfiles="file:lib/example/RuleSet-Groovy.groovy" -maxPriority1Violations=0 -report="xml:ReportTestCodenarc.xml
-h<br/> --helpBooleanShow help (npm-groovy-lint -h OPTIONNAME to see option detail with examples)
-v<br/> --versionBooleanShow npm-groovy-lint version (with CodeNarc version)
-p<br/> --pathString(DEPRECATED) Directory containing the files to lint<br/> Example: ./path/to/my/groovy/files
-f<br/> --filesString(DEPRECATED) Comma-separated list of Ant-style file patterns specifying files that must be included.<br/> Default: "**/*.groovy,**/Jenkinsfile,**/*.gradle"<br/>Examples:<br/> - "**/Jenkinsfile"<br/> - "**/*.groovy"<br/> - "**/*.gradle"<br/> - "**/mySingleFile.groovy"

Example calls

    npm-groovy-lint path/to/my/groovy/file.groovy
    npm-groovy-lint path/to/my/groovy/file.groovy path/to/my/groovy/file2.groovy path/to/my/groovy/file3.groovy
    npm-groovy-lint path/to/my/groovy
    npm-groovy-lint path/to/my/groovy/*.groovy
    npm-groovy-lint --output json
    npm-groovy-lint --format my/path/to/file.groovy my/path/to/file2.groovy
    npm-groovy-lint --fix my/path/to/file.groovy my/path/to/file2.groovy
    cat path/to/my/Jenkinsfile | npm-groovy-lint --format -
    npm-groovy-lint --path "./path/to/my/groovy/files" --files "**/*.groovy" --config "./config/codenarc/.groovylintrcCustom.js" --loglevel warning --output txt
    npm-groovy-lint --codenarcargs -basedir="lib/example" -rulesetfiles="file:lib/example/RuleSet-Groovy.groovy" -title="TestTitleCodenarc" -maxPriority1Violations=0' -report="html:ReportTestCodenarc.html"

Installation

    npm install -g npm-groovy-lint

Configuration

Default rules definition (recommended, based on all tracks a lot of errors, do not hesitate to ignore some of them (like NoDef ou RequiredVariableType) if they are too mean for your project.

Create a file named .groovylintrc.json in the current or any parent directory of where your files to analyze are located

If you are using VsCode Groovy Lint extension, just use QuickFix Ignore in all files and it will generate groovylintrc.json file.

Format

OR

Examples

{
    "extends": "recommended",
    "rules": {
        "comments.ClassJavadoc": "off",
        "formatting.Indentation": {
            "spacesPerIndentLevel": 4,
            "severity": "info"
        },
        "UnnecessaryReturnKeyword": "error"
    }
}
{
    "extends": "recommended-jenkinsfile",
    "rules": {
        "CouldBeElvis": "off",
        "CouldBeSwitchStatement": "off",
        "VariableName": {
            "severity": "info"
        }
    }
}
{
    "codenarcRulesets": "RuleSet-1.groovy,RuleSet-2.groovy"
}

Disabling rules in source

You can disable rules directly by adding comment in file, using eslint style

To temporarily disable rule warnings in your file, use block comments in the following format:

/* groovylint-disable */

def variable = 1;

/* groovylint-enable */

You can also disable or enable warnings for specific rules:

/* groovylint-disable NoDef, UnnecessarySemicolon */

def variable = 1;

/* groovylint-enable NoDef, UnnecessarySemicolon */

To disable rule warnings in an entire file, put a /* groovylint-disable */ block comment at the top of the file:

/* groovylint-disable */

def variable = 1;

You can also disable or enable specific rules for an entire file:

/* groovylint-disable NoDef */

def variable = 1;

To disable all rules on a specific line, use a line or block comment in one of the following formats:

def variable = 1; // groovylint-disable-line

// groovylint-disable-next-line
def variable = 1;

/* groovylint-disable-next-line */
def variable = 1;

def variable = 1; /* groovylint-disable-line */

To disable a specific rule on a specific line:

def variable = 1; // groovylint-disable-line NoDef

// groovylint-disable-next-line NoDef
def variable = 1;

def variable = 1; /* groovylint-disable-line NoDef */

/* groovylint-disable-next-line NoDef */
def variable = 1;

To disable multiple rules on a specific line:

def variable = 1; // groovylint-disable-line NoDef, UnnecessarySemicolon

// groovylint-disable-next-line NoDef, UnnecessarySemicolon
def variable = 1;

def variable = 1; /* groovylint-disable-line NoDef, UnnecessarySemicolon */

/* groovylint-disable-next-line NoDef, UnnecessarySemicolon */
def variable = 1;

Auto-Fixable rules

Contribute to add more rules fixes :)

CI/CD

Mega-Linter

Latest npm-groovy-lint version is natively integrated in Mega-Linter, that you can use as GitHub action or in other CI tools This tool can also automatically apply fixes on Pull Request branches

CircleCI

# .circleci/config.yml
version: 2.1
jobs:
  lint:
    docker:
      - image: nvuillam/npm-groovy-lint
    steps:
      - checkout

      - run: |
          npm-groovy-lint

workflows:
  version: 2
  "lint":
    jobs:
       - lint

Jenkins

node {
    checkout scm
    docker.image('nvuillam/npm-groovy-lint').inside {
        sh 'npm-groovy-lint'
    }
}

Shell

Run with default settings

docker run --rm -u "$(id -u):$(id -g)" -w=/tmp -v "$PWD":/tmp nvuillam/npm-groovy-lint

Run with additional flags by simply appending them at after docker image name:

docker run --rm -u "$(id -u):$(id -g)" -w=/tmp -v "$PWD":/tmp nvuillam/npm-groovy-lint --failon warning --verbose

Other

You can run npm-groovy-lint using its official docker image

Use as module

You can import npm-groovy-lint into your NPM package and call lint & fix via module, using the same options than from npm-groovy-lint command line

Example

    npm install npm-groovy-lint --save
    const NpmGroovyLint = require("npm-groovy-lint/lib/groovy-lint.js");
    const fse = require("fs-extra");

    const npmGroovyLintConfig = {
        source: fse.readFileSync('./lib/example/SampleFile.groovy').toString(),
        fix: true,
        loglevel: 'warning',
        output: 'none'
    };
    const linter = new NpmGroovyLint(npmGroovyLintConfig, {});
    await linter.run();
    console.log(JSON.stringify(linter.lintResult));

Troubleshooting

If you have issues with MegaLinter, you can report it on the repository

To help reproducing, you can access advanced logs using DEBUG env variables

Examples:

If you want to see what happens in CodeNarc Server, you can clone the repo and run locally npm server:run before running npm-groovy-lint: you'll see the live logs of the to CodeNarc Server for npm-groovy-lint.

Contribute

Contributions are very welcome !

Please follow Contribution instructions

Thanks

Other packages used

Contributors

<img alt="nvuillam" src="https://avatars1.githubusercontent.com/u/17500430?v=4&s=50 width=50"><img alt="Dave Gallant" src="https://avatars2.githubusercontent.com/u/4519234?v=4&s=50 width=50"><img alt="warhod" src="https://avatars1.githubusercontent.com/u/1305176?v=4&s=50 width=50"><img alt="pawelkopka" src="https://avatars1.githubusercontent.com/u/17784034?v=4&s=50 width=50"><img alt="docwhat" src="https://avatars1.githubusercontent.com/u/40799?v=4&s=50 width=50"><img alt="CatSue" src="https://avatars3.githubusercontent.com/u/26134618?v=4&s=50 width=50">
Nicolas VuillamyDave GallantHoward LoPawel KopkadocwhatCatSue

Release notes

See complete CHANGELOG