grunt-eslint-sonar

It aims to be a substitute of the eslint-json reporter that provides a Sonar-compatible report.

#Getting started

npm i --save-dev grunt-eslint-sonar

#Default Usage

eslint : {
    target : { ...},
    options: {
          format: require('eslint-json-sonar'),
          ...
    }
gulp lint

All params for launchReporters are optional, if you dont pass them, they'll skip linters. We rarely need to scan both css and scss for example. #Configuration Since not all project will match the default values, you can customize it, each reporter has params :

  • src : the gulp.src params to use for the task, probably the only one you'll have to override
  • report : the report json file path to use
  • task : the gulp task name to use for the report
  • base : (for eslint only) the base folder for seeking sources

##Default values

gulp.task('lint', function() {
    return SonarWebReporters.launchReporters({
        project: projectName,
        css : {
          src : "src/**/*.scss",
          report : "reports/sonar/csslint.json",
          task : "ci-csslint"
        },
        scss : {
          src : "src/**/*.scss",
          report : "reports/sonar/scsslint.json",
          task : "ci-scsslint"
        },
        html : {
          src : "src/**/*.scss",
          report : "reports/sonar/htmlhint.json",
          task : "ci-htmlhint"
        },
        js : {
          src : "src/**/*.scss",
          report : "reports/sonar/jshint.json",
          task : "ci-jshint"
        },
        eslint : {
          src : "src/**/*.scss",
          report : "reports/sonar/eslint-angular.json",
          task : "ci-eslint",
          base : "src"
        },
        ts : {
          src : "src/**/*.ts",
          report : "reports/sonar/tslint.json",
          task : "ci-tslint"
        }
    });
});

Informations for Sonarqube

The export files for Sonarqube are JSON files providing all informations a Sonarqube issue might need :

  • Project Description
    • language : The programmation(cough) language of the project (HTML, CSS, JS, whatever)
    • project : The name of the project
    • projectPath : The path to the sources of the project for Sonarqube parsing
    • version : The project version
    • violations : Object summarizing the number of violations in the project sorted by severity
    • nbFiles : Number of scanned files in the project
    • nbLines : Total number of lines in scanned files
    • nbComments : Total number of commented lines in scanned files
    • nbCloc : Total number of lines of code (non empty non comment) in scanned files
    • files : Array of scanned files
  • File description
    • name : File name
    • path : File path relative to project's path
    • nbLines : Number of lines in the file
    • nbComments : Number of commented lines in the file
    • nbCloc : Number of lines of code (non empty non comment) in the file
    • violations : Object summarizing the number of violations in the file sorted by severity
    • issues : Array of issues in the file
  • Issue description
    • line : The line where the issue occurs in the file
    • col : The column where the issue occurs in the line
    • message : Summary of the issue
    • description : Long test descrtibing the issue
    • rulekey : The unique identifier of the issue
    • severity : Issue severity (one of INFO,MINOR,MAJOR,CRITICAL,BLOCKER)
    • reporter : Name of the reporter used to generate this issue
    • creationDate : Date of issue creation

Developers

Tests are in mocha + chai so:

  • Install: npm install mocha -g
  • Run: mocha tests --recursive --watch