Skip to main content

jenkins pylint api.

Project description

lintjenkins Documentation Status Updates

lintjenkins 是干什么的? 这里举一个使用场景的例子. 我又一个django项目需要使用jenkins进行持续代码检查, 需要做的操作是:

  1. 在jenkins上创建一个job, 配置job 和violations等信息.
  2. 在配置job时,添加svn代码时,需要输入账号和密码进行验证
  3. 查看检查结果
  4. 当需要统计历史结果时, 只能手动去看一次次检查结果.

lintjenkins 就是将上述场景操作封装为接口,便于二次开发.


  1. 目标机器装有jenkins+violations

  2. 被检查的python代码所在目录符合包的形式,如:

    • requirements.txt
    • pylint.cfg
  3. pylint配置文件也需要修改.

    • 没有配置可以使用`pylint –generate-rcfile > pylint.cfg`生成配置.
    • 将`output-format`项的值改为`parseable`
    • init-hook`添加’import sys; sys.path.append(“/var/lib/jenkins/workspace/xxx”)’,`xxx`为jenkins job名. 否则会出现`W0403 Relative import ‘xxxx’警告


In [2]: from lintjenkins import LintJenkins

In [3]: lint_jenkins = LintJenkins('http://x.x.x.x:8080', username='username', password='password')

In [4]: lint_jenkins.add_job(svn = 'svn', username='username', password='password',job_name='aliyun')

In [7]: lint_jenkins.get_build_numbers('aliyun')
Out[7]: [2, 1]

In [8]: lint_jenkins.get_build_info('aliyun',2)
         "violation_info": {
             "violation_num": 2027,
             "violation_file_num": 80
         "commits": [
                 "msg": "svn提交信息",
                 "paths": [
                         "editType": "add",
                         "file": "新增的文件"
                         "editType": "edit",
                         "file": "编辑的文件"
                 "revision": 18830,
                 "datetime": "2017-06-12 09:44:38",
                 "author": "huzhongzhong"
         "datetime": "2017-06-12 09:55:13",
         "result": "UNSTABLE",
         "duration": 49,
         "revisions": [
                 "module": "svn地址",
                 "revision": 18830






  • Credentials Plugin`使用的是版本`2.1.16
  • 如果报错`403 no valid crumb was included in the request , 简单可以这样处理:`setup jenkins’s “global security settings”: Uncheck “Prevent Cross Site Request Forgery exploits”


This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.


0.1.0 (2017-06-11)

  • First release on PyPI.

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for lintjenkins, version 0.1.13
Filename, size File type Python version Upload date Hashes
Filename, size lintjenkins-0.1.13-py2.py3-none-any.whl (11.4 kB) File type Wheel Python version 3.6 Upload date Hashes View hashes
Filename, size lintjenkins-0.1.13.tar.gz (19.0 kB) File type Source Python version None Upload date Hashes View hashes

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN SignalFx SignalFx Supporter DigiCert DigiCert EV certificate StatusPage StatusPage Status page