项目作者: miyajan

项目描述 :
A client tool to lint Jenkinsfile
高级语言: JavaScript
项目地址: git://github.com/miyajan/jflint.git
创建时间: 2017-02-16T13:56:31Z
项目社区:https://github.com/miyajan/jflint

开源协议:MIT License

下载


jflint

A helper tool to lint a Declarative Jenkinsfile

npm version
npm downloads
Node.js Version Support
Build Status
dependencies Status
Coverage Status
License

Description

This tool helps to lint a Declarative Jenkinsfile.

The official document-a-Declarative-Jenkinsfile-from-the-command-line) provides a ssh approach and a curl approach to lint a Declarative Jenkinsfile. However, both approaches are a bit complicated for daily use.

So I created this tool to lint easily. This tool itself does not lint a Jenkinsfile, but sends a request to Jenkins in the same way as curl approach and displays the result.

Install

  1. $ npm install jflint -g

Usage

  1. $ jflint [options] /path/to/Jenkinsfile

Options

-j or --jenkins-url

Specify the URL of Jenkins to lint Jenkinsfile. The URL must be passed by this option or a config file.

-u or --username

Specify username for Jenkins. Username is required when security is enabled on Jenkins.

-p or --password

Specify password or API token for Jenkins. Password or API token is required when security is enabled on Jenkins.

--csrf-disabled

Specify this options when CSRF security setting is disabled on Jenkins.

-c or --config

Specify a path to config file.

--ssl-verification-disabled

Disable SSL verification.

Config file

You can load options from json file like the following.

  1. {
  2. "jenkinsUrl": "http://jenkins.example.com",
  3. "username": "admin",
  4. "password": "p@ssword"
  5. }

Config file is searched in the following order.

  • the path specified by -c|--config
  • .jflintrc from the current directory all the way up to the filesystem root
  • ${HOME}/.jflintrc

If the same setting is specified in both option and config file, the option setting overrides the config setting.

Contribution

  1. Fork
  2. Create a feature branch
  3. Commit your changes
  4. Rebase your local changes against the master branch
  5. Run npm test
  6. Create new Pull Request

License

MIT

Author

miyajan: Jumpei Miyata miyajan777@gmail.com