@bartekbp/regex-checkstyle
v5.0.0
Published
Library reporting regex output in checkstyle format
Downloads
2
Maintainers
Readme
Regex-checkstyle
Regex-checkstyle is a tool for finding mistakes in code using regexes and reporting them in checkstyle format. It was created to improve pull request decoration with typical sql errors.
Prerequisites
Project requires:
- nodejs 10
- npm
Installation
All arifacts are published to npm. To use the latest version, you can install it using:
npm i --save-dev @bartekbp/regex-checkstyle
Usage
Library executes a regular expression over files with optional text substitution and reports results in checkstyle
format.
You can use it to find variables in code that begin with underscore and recommend to strip it:
> npx @bartekbp/regex-checkstyle -p '(const|let)\s+(_.*)' -s 'Variable $2 has a name starting with underscore. Please remove it.' 'src/**/*.js'
Supported parameters:
-p
specifies regex to use for finding text-s
specifies substitution
The last positional argument is a glob that specifies searched files. For example glob values please refer to https://github.com/mrmlnc/fast-glob.
Pull request decoration with regex output
If you want to automate adding comments to your pull request based on regexes this tool will help you achieve it.
To configure it, I will use jenkins
, but the solution applies to other continuous integration systems as well.
Jenkins pipleline
You need to setup a jenkins pipeline
that will be triggered with bitbucket branch source plugin or github branch source plugin.
In the pipeline you need to run regex-checkstyle redirect output to a file:
stage('regex') {
steps {
sh 'npx @bartekbp/regex-checkstyle ... > regex-checkstyle.xml'
}
}
Depending on your code review system, tomasbjerre created different plugins for pull request decoration. You can find the full list of them at the bottom of violations-lib readme. I'll focus on the configuration for bitbucket cloud
.
You need to update pipeline with additional stage for pr decoration:
The bold parts in the stage needs to updated to reflect your project:
- jenkins-pr-writes with credentials to bitbucket user
- workspace with bitbucket workspace
- repoName with repository that has an opened pull request
License
Distributed under the MIT License. See LICENSE for more information.
Acknowledgements
Great thanks to:
- tomasbjerre for his tools enabling pull request decoration
- jimf for tool to convert json to xml checkstyle format