Merge branch 'cis-kuldeep/v0.6' of https://git.bitmessage.org/cis-kuldeep/PyBitmessage-2021-04-27 into cis-kuldeep/v0.6
This commit is contained in:
commit
8b6f9853cd
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -19,3 +19,6 @@ docs/_*/*
|
||||||
docs/autodoc/
|
docs/autodoc/
|
||||||
build
|
build
|
||||||
pyan/
|
pyan/
|
||||||
|
*.swp
|
||||||
|
tags
|
||||||
|
.coverage
|
||||||
|
|
299
Jenkinsfile
vendored
Normal file
299
Jenkinsfile
vendored
Normal file
|
@ -0,0 +1,299 @@
|
||||||
|
pipeline {
|
||||||
|
agent any
|
||||||
|
triggers {
|
||||||
|
pollSCM('*/5 * * * 1-5')
|
||||||
|
}
|
||||||
|
options {
|
||||||
|
// skipDefaultCheckout(true)
|
||||||
|
// Keep the 10 most recent builds
|
||||||
|
buildDiscarder(logRotator(numToKeepStr: '10'))
|
||||||
|
// timestamps()
|
||||||
|
}
|
||||||
|
environment {
|
||||||
|
projectName = 'BitMessage'
|
||||||
|
emailTo = 'kuldeep.m@cisinlabs.com'
|
||||||
|
emailFrom = 'cis.dev393@gmail.com'
|
||||||
|
VIRTUAL_ENV = "${env.WORKSPACE}/venv"
|
||||||
|
}
|
||||||
|
|
||||||
|
stages {
|
||||||
|
|
||||||
|
|
||||||
|
// stage ('Checkout') {
|
||||||
|
// steps {
|
||||||
|
// checkout scm
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
|
||||||
|
stage ('Install_Requirements') {
|
||||||
|
steps {
|
||||||
|
sh """
|
||||||
|
echo ${SHELL}
|
||||||
|
[ -d venv ] && rm -rf venv
|
||||||
|
#virtualenv --python=python2.7 venv
|
||||||
|
virtualenv venv
|
||||||
|
#. venv/bin/activate
|
||||||
|
export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
pip install --upgrade pip
|
||||||
|
pip install -r requirements.txt -r dev-requirements.txt
|
||||||
|
make clean
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// stage ('Check_style') {
|
||||||
|
// steps {
|
||||||
|
// sh """
|
||||||
|
// if [ ! -d venv ] ; then
|
||||||
|
|
||||||
|
// virtualenv --python=python2.7 venv
|
||||||
|
// fi
|
||||||
|
// source venv/bin/activate
|
||||||
|
// export PYTHONPATH="$PWD:$PYTHONPATH"
|
||||||
|
|
||||||
|
// pip install pylint
|
||||||
|
|
||||||
|
// cd repo
|
||||||
|
// ### Need this because some strange control sequences when using default TERM=xterm
|
||||||
|
// export TERM="linux"
|
||||||
|
|
||||||
|
// ## || exit 0 because pylint only exits with 0 if everything is correct
|
||||||
|
// pylint --rcfile=pylint.cfg $(find . -maxdepth 1 -name "*.py" -print) MYMODULE/ > pylint.log || exit 0
|
||||||
|
// """
|
||||||
|
// step([$class: 'WarningsPublisher',
|
||||||
|
// parserConfigurations: [
|
||||||
|
// [
|
||||||
|
// parserName: 'pylint',
|
||||||
|
// pattern: 'report/pylint.log'
|
||||||
|
// ]],
|
||||||
|
// unstableTotalAll: '0',
|
||||||
|
// usePreviousBuildAsReference: true
|
||||||
|
// ])
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
stage('changes in script check') {
|
||||||
|
steps {
|
||||||
|
sh '''
|
||||||
|
echo ${SHELL}
|
||||||
|
'''
|
||||||
|
// sudo /home/cis/.local/bin/nosetests --with-xunit tests
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Test environment') {
|
||||||
|
steps {
|
||||||
|
sh '''
|
||||||
|
echo ${SHELL}
|
||||||
|
[ -d venv ] && rm -rf venv
|
||||||
|
#virtualenv --python=python2.7 venv
|
||||||
|
virtualenv venv
|
||||||
|
#. venv/bin/activate
|
||||||
|
export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
python setup.py install
|
||||||
|
pip install pylint
|
||||||
|
pip install radon
|
||||||
|
pip install coverage
|
||||||
|
'''
|
||||||
|
// sudo /home/cis/.local/bin/nosetests --with-xunit tests
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
stage('Pylint Checker'){
|
||||||
|
steps{
|
||||||
|
sh '''
|
||||||
|
export TERM="linux"
|
||||||
|
pylint --rcfile=pylint.cfg $(find . -maxdepth 1 -name "*.py" -print) PyBitmessage/src > pylint.log || exit 0
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// stage('Nosetest'){
|
||||||
|
// steps{
|
||||||
|
// sh '''
|
||||||
|
// echo ${SHELL}
|
||||||
|
// [ -d venv ] && rm -rf venv
|
||||||
|
// #virtualenv --python=python2.7 venv
|
||||||
|
// virtualenv venv
|
||||||
|
// #. venv/bin/activate
|
||||||
|
// export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
// python setup.py install
|
||||||
|
// sudo apt-get install python-mock python-nose python-coverage pylint
|
||||||
|
|
||||||
|
// '''
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// stage('Pylint Checker') {
|
||||||
|
// steps {
|
||||||
|
// sh '''
|
||||||
|
// echo ${SHELL}
|
||||||
|
// [ -d venv ] && rm -rf venv
|
||||||
|
// #virtualenv --python=python2.7 venv
|
||||||
|
// virtualenv venv
|
||||||
|
// #. venv/bin/activate
|
||||||
|
// export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
|
||||||
|
// pip install pylint
|
||||||
|
|
||||||
|
|
||||||
|
// export TERM="linux"
|
||||||
|
|
||||||
|
// ## || exit 0 because pylint only exits with 0 if everything is correct
|
||||||
|
// pylint --rcfile=pylint.cfg $(find . -maxdepth 1 -name "*.py" -print) Pybitmessage/ > pylint.log || exit 0
|
||||||
|
// '''
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
stage('Static code metrics') {
|
||||||
|
steps {
|
||||||
|
echo "Raw metrics"
|
||||||
|
sh ''' echo ${SHELL}
|
||||||
|
[ -d venv ] && rm -rf venv
|
||||||
|
#virtualenv --python=python2.7 venv
|
||||||
|
virtualenv venv
|
||||||
|
#. venv/bin/activate
|
||||||
|
export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
python setup.py install
|
||||||
|
pip install radon
|
||||||
|
radon raw --json PyBitmessage/ > raw_report.json
|
||||||
|
radon cc --json PyBitmessage/ > cc_report.json
|
||||||
|
radon mi --json PyBitmessage/ > mi_report.json
|
||||||
|
'''
|
||||||
|
|
||||||
|
|
||||||
|
echo "Test coverage"
|
||||||
|
sh '''
|
||||||
|
echo ${SHELL}
|
||||||
|
[ -d venv ] && rm -rf venv
|
||||||
|
#virtualenv --python=python2.7 venv
|
||||||
|
virtualenv venv
|
||||||
|
#. venv/bin/activate
|
||||||
|
export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
python setup.py install
|
||||||
|
pip install coverage
|
||||||
|
coverage run src/bitmessagemain.py -t 1 1 2 3
|
||||||
|
python -m coverage xml -o PyBitmessage/coverage.xml
|
||||||
|
'''
|
||||||
|
|
||||||
|
echo "Style check"
|
||||||
|
sh ''' echo ${SHELL}
|
||||||
|
[ -d venv ] && rm -rf venv
|
||||||
|
#virtualenv --python=python2.7 venv
|
||||||
|
virtualenv venv
|
||||||
|
#. venv/bin/activate
|
||||||
|
export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
python setup.py install
|
||||||
|
pip install pylint
|
||||||
|
pylint PyBitmessage || true
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
post{
|
||||||
|
always{
|
||||||
|
step([$class: 'CoberturaPublisher',
|
||||||
|
autoUpdateHealth: false,
|
||||||
|
autoUpdateStability: false,
|
||||||
|
coberturaReportFile: 'PyBitmessage/coverage.xml',
|
||||||
|
failNoReports: false,
|
||||||
|
failUnhealthy: false,
|
||||||
|
failUnstable: false,
|
||||||
|
maxNumberOfBuilds: 10,
|
||||||
|
onlyStable: false,
|
||||||
|
sourceEncoding: 'ASCII',
|
||||||
|
zoomCoverageChart: false])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Unit tests') {
|
||||||
|
steps {
|
||||||
|
sh ''' export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
pip install pytest
|
||||||
|
pip install psutil
|
||||||
|
pip install python-prctl==1.5.0
|
||||||
|
python -m pytest --verbose --junit-xml results.xml
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
post {
|
||||||
|
always {
|
||||||
|
// Archive unit tests for the future
|
||||||
|
junit allowEmptyResults: true, testResults: 'results.xml'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Setup Test') {
|
||||||
|
steps {
|
||||||
|
sh ''' export PATH=${VIRTUAL_ENV}/bin:${PATH}
|
||||||
|
pip install pytest
|
||||||
|
pip install psutil
|
||||||
|
pip install python-prctl==1.5.0
|
||||||
|
python -m pytest --verbose --junit-xml results.xml
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
post {
|
||||||
|
always {
|
||||||
|
// Archive unit tests for the future
|
||||||
|
junit allowEmptyResults: true, testResults: 'results.xml'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// stage('Unit tests') {
|
||||||
|
// steps {
|
||||||
|
// sh ''' source activate ${BUILD_TAG}
|
||||||
|
// python -m pytest --verbose --junit-xml reports/unit_tests.xml
|
||||||
|
// '''
|
||||||
|
// }
|
||||||
|
// post {
|
||||||
|
// always {
|
||||||
|
// // Archive unit tests for the future
|
||||||
|
// junit (allowEmptyResults: true,
|
||||||
|
// testResults: './reports/unit_tests.xml',
|
||||||
|
// testResults: true)
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
|
||||||
|
stage('Test Run') {
|
||||||
|
steps {
|
||||||
|
sh '''python src/bitmessagemain.py -t'''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage ('Cleanup') {
|
||||||
|
steps {
|
||||||
|
sh 'rm -rf venv'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
post {
|
||||||
|
failure {
|
||||||
|
mail body: "${env.JOB_NAME} (${env.BUILD_NUMBER}) ${env.projectName} build error " +
|
||||||
|
"is here: ${env.BUILD_URL}\nStarted by ${env.BUILD_CAUSE}" ,
|
||||||
|
from: env.emailFrom,
|
||||||
|
//replyTo: env.emailFrom,
|
||||||
|
subject: "${env.projectName} ${env.JOB_NAME} (${env.BUILD_NUMBER}) build failed",
|
||||||
|
to: env.emailTo
|
||||||
|
}
|
||||||
|
success {
|
||||||
|
mail body: "${env.JOB_NAME} (${env.BUILD_NUMBER}) ${env.projectName} build successful\n" +
|
||||||
|
"Started by ${env.BUILD_CAUSE}",
|
||||||
|
from: env.emailFrom,
|
||||||
|
//replyTo: env.emailFrom,
|
||||||
|
subject: "${env.projectName} ${env.JOB_NAME} (${env.BUILD_NUMBER}) build successful",
|
||||||
|
to: env.emailTo
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
99
Makefile
Normal file
99
Makefile
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
#!/usr/bin/make
|
||||||
|
# WARN: gmake syntax
|
||||||
|
########################################################
|
||||||
|
# Makefile for $(NAME)
|
||||||
|
#
|
||||||
|
# useful targets:
|
||||||
|
# make check -- manifest checks
|
||||||
|
# make clean -- clean distutils
|
||||||
|
# make coverage_report -- code coverage report
|
||||||
|
# make flake8 -- flake8 checks
|
||||||
|
# make pylint -- source code checks
|
||||||
|
# make rpm -- build RPM package
|
||||||
|
# make sdist -- build python source distribution
|
||||||
|
# make systest -- runs the system tests
|
||||||
|
# make tests -- run all of the tests
|
||||||
|
# make unittest -- runs the unit tests
|
||||||
|
#
|
||||||
|
# Notes:
|
||||||
|
# 1) flake8 is a wrapper around pep8, pyflakes, and McCabe.
|
||||||
|
########################################################
|
||||||
|
# variable section
|
||||||
|
|
||||||
|
NAME = "PyBitmessage"
|
||||||
|
|
||||||
|
PYTHON=python
|
||||||
|
COVERAGE=coverage
|
||||||
|
NOSE_OPTS = --with-coverage --cover-package=$(NAME)
|
||||||
|
SITELIB = $(shell $(PYTHON) -c "from distutils.sysconfig import get_python_lib; print get_python_lib()")
|
||||||
|
|
||||||
|
VERSION := $(shell awk '/__version__/{print $$NF}' $(NAME)/__init__.py | sed "s/'//g")
|
||||||
|
|
||||||
|
RPMSPECDIR = .
|
||||||
|
RPMSPEC = $(RPMSPECDIR)/$(NAME).spec
|
||||||
|
RPMRELEASE = 1
|
||||||
|
RPMNVR = "$(NAME)-$(VERSION)-$(RPMRELEASE)"
|
||||||
|
|
||||||
|
FLAKE8_IGNORE = E302,E203,E261
|
||||||
|
|
||||||
|
########################################################
|
||||||
|
|
||||||
|
all: clean check flake8 pylint tests
|
||||||
|
|
||||||
|
flake8:
|
||||||
|
flake8 --ignore=$(FLAKE8_IGNORE) $(NAME)/
|
||||||
|
flake8 --ignore=$(FLAKE8_IGNORE),E402 tests/
|
||||||
|
|
||||||
|
pylint:
|
||||||
|
find ./$(NAME) ./tests -name \*.py | xargs pylint --rcfile .pylintrc
|
||||||
|
|
||||||
|
check:
|
||||||
|
@echo "Check-manifest disabled pending https://github.com/mgedmin/check-manifest/issues/68"
|
||||||
|
#check-manifest
|
||||||
|
|
||||||
|
clean:
|
||||||
|
@echo "Cleaning up distutils stuff"
|
||||||
|
rm -rf build
|
||||||
|
rm -rf dist
|
||||||
|
rm -rf MANIFEST
|
||||||
|
rm -rf *.egg-info
|
||||||
|
@echo "Cleaning up byte compiled python stuff"
|
||||||
|
find . -type f -regex ".*\.py[co]$$" -delete
|
||||||
|
@echo "Cleaning up doc builds"
|
||||||
|
rm -rf docs/_build
|
||||||
|
rm -rf docs/api_modules
|
||||||
|
rm -rf docs/client_modules
|
||||||
|
@echo "Cleaning up test reports"
|
||||||
|
rm -rf report/*
|
||||||
|
|
||||||
|
rpmcommon: sdist
|
||||||
|
@mkdir -p rpmbuild
|
||||||
|
@cp dist/*.gz rpmbuild/
|
||||||
|
@cp -R conf/* rpmbuild/
|
||||||
|
@sed -e 's#^Version:.*#Version: $(VERSION)#' -e 's#^Release:.*#Release: $(RPMRELEASE)#' $(RPMSPEC) >rpmbuild/$(NAME).spec
|
||||||
|
|
||||||
|
rpm: rpmcommon
|
||||||
|
@rpmbuild --define "_topdir %(pwd)/rpmbuild" \
|
||||||
|
--define "_builddir %{_topdir}" \
|
||||||
|
--define "_rpmdir %{_topdir}" \
|
||||||
|
--define "_srcrpmdir %{_topdir}" \
|
||||||
|
--define "_specdir $(RPMSPECDIR)" \
|
||||||
|
--define "_sourcedir %{_topdir}" \
|
||||||
|
--define "_rpmfilename %%{NAME}-%%{VERSION}-%%{RELEASE}.%%{ARCH}.rpm" \
|
||||||
|
--define "__python /usr/bin/python" \
|
||||||
|
-ba rpmbuild/$(NAME).spec
|
||||||
|
@rm -f rpmbuild/$(NAME).spec
|
||||||
|
|
||||||
|
sdist: clean
|
||||||
|
$(PYTHON) setup.py sdist
|
||||||
|
|
||||||
|
tests: unittest systest coverage_report
|
||||||
|
|
||||||
|
unittest: clean
|
||||||
|
nosetests $(NOSE_OPTS) tests/unit/*
|
||||||
|
|
||||||
|
systest: clean
|
||||||
|
nosetests $(NOSE_OPTS) tests/system/*
|
||||||
|
|
||||||
|
coverage_report:
|
||||||
|
$(COVERAGE) report --rcfile=".coveragerc"
|
10
__init__.py
Normal file
10
__init__.py
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
|
||||||
|
"""
|
||||||
|
File: __init__.py
|
||||||
|
Author: Steve Francia <steve.francia@gmail.com>
|
||||||
|
Email: 0
|
||||||
|
Github: 0
|
||||||
|
Description: <`0`>
|
||||||
|
"""
|
||||||
|
__version__ = '0.1.develop'
|
||||||
|
__author__ = '{Peter Sudhra+}'
|
1
cc_report.json
Normal file
1
cc_report.json
Normal file
|
@ -0,0 +1 @@
|
||||||
|
cc_report.json
|
0
coverage.xml
Normal file
0
coverage.xml
Normal file
10
dev-requirements.txt
Normal file
10
dev-requirements.txt
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
check-manifest
|
||||||
|
coverage
|
||||||
|
flake8
|
||||||
|
nose
|
||||||
|
pdoc
|
||||||
|
pylint
|
||||||
|
pytest
|
||||||
|
setuptools>=35
|
||||||
|
testtools
|
||||||
|
unittest2
|
1
mi_report.json
Normal file
1
mi_report.json
Normal file
|
@ -0,0 +1 @@
|
||||||
|
mi_report.json
|
542
pylint.cfg
Normal file
542
pylint.cfg
Normal file
|
@ -0,0 +1,542 @@
|
||||||
|
[MASTER]
|
||||||
|
|
||||||
|
# A comma-separated list of package or module names from where C extensions may
|
||||||
|
# be loaded. Extensions are loading into the active Python interpreter and may
|
||||||
|
# run arbitrary code
|
||||||
|
extension-pkg-whitelist=
|
||||||
|
|
||||||
|
# Add files or directories to the blacklist. They should be base names, not
|
||||||
|
# paths.
|
||||||
|
ignore=CVS
|
||||||
|
|
||||||
|
# Add files or directories matching the regex patterns to the blacklist. The
|
||||||
|
# regex matches against base names, not paths.
|
||||||
|
ignore-patterns=
|
||||||
|
|
||||||
|
# Python code to execute, usually for sys.path manipulation such as
|
||||||
|
# pygtk.require().
|
||||||
|
#init-hook=
|
||||||
|
|
||||||
|
# Use multiple processes to speed up Pylint.
|
||||||
|
jobs=1
|
||||||
|
|
||||||
|
# List of plugins (as comma separated values of python modules names) to load,
|
||||||
|
# usually to register additional checkers.
|
||||||
|
load-plugins=
|
||||||
|
|
||||||
|
# Pickle collected data for later comparisons.
|
||||||
|
persistent=yes
|
||||||
|
|
||||||
|
# Specify a configuration file.
|
||||||
|
#rcfile=
|
||||||
|
|
||||||
|
# When enabled, pylint would attempt to guess common misconfiguration and emit
|
||||||
|
# user-friendly hints instead of false-positive error messages
|
||||||
|
suggestion-mode=yes
|
||||||
|
|
||||||
|
# Allow loading of arbitrary C extensions. Extensions are imported into the
|
||||||
|
# active Python interpreter and may run arbitrary code.
|
||||||
|
unsafe-load-any-extension=no
|
||||||
|
|
||||||
|
|
||||||
|
[MESSAGES CONTROL]
|
||||||
|
|
||||||
|
# Only show warnings with the listed confidence levels. Leave empty to show
|
||||||
|
# all. Valid levels: HIGH, INFERENCE, INFERENCE_FAILURE, UNDEFINED
|
||||||
|
confidence=
|
||||||
|
|
||||||
|
# Disable the message, report, category or checker with the given id(s). You
|
||||||
|
# can either give multiple identifiers separated by comma (,) or put this
|
||||||
|
# option multiple times (only on the command line, not in the configuration
|
||||||
|
# file where it should appear only once).You can also use "--disable=all" to
|
||||||
|
# disable everything first and then reenable specific checks. For example, if
|
||||||
|
# you want to run only the similarities checker, you can use "--disable=all
|
||||||
|
# --enable=similarities". If you want to run only the classes checker, but have
|
||||||
|
# no Warning level messages displayed, use"--disable=all --enable=classes
|
||||||
|
# --disable=W"
|
||||||
|
disable=print-statement,
|
||||||
|
parameter-unpacking,
|
||||||
|
unpacking-in-except,
|
||||||
|
old-raise-syntax,
|
||||||
|
backtick,
|
||||||
|
long-suffix,
|
||||||
|
old-ne-operator,
|
||||||
|
old-octal-literal,
|
||||||
|
import-star-module-level,
|
||||||
|
non-ascii-bytes-literal,
|
||||||
|
raw-checker-failed,
|
||||||
|
bad-inline-option,
|
||||||
|
locally-disabled,
|
||||||
|
locally-enabled,
|
||||||
|
file-ignored,
|
||||||
|
suppressed-message,
|
||||||
|
useless-suppression,
|
||||||
|
deprecated-pragma,
|
||||||
|
apply-builtin,
|
||||||
|
basestring-builtin,
|
||||||
|
buffer-builtin,
|
||||||
|
cmp-builtin,
|
||||||
|
coerce-builtin,
|
||||||
|
execfile-builtin,
|
||||||
|
file-builtin,
|
||||||
|
long-builtin,
|
||||||
|
raw_input-builtin,
|
||||||
|
reduce-builtin,
|
||||||
|
standarderror-builtin,
|
||||||
|
unicode-builtin,
|
||||||
|
xrange-builtin,
|
||||||
|
coerce-method,
|
||||||
|
delslice-method,
|
||||||
|
getslice-method,
|
||||||
|
setslice-method,
|
||||||
|
no-absolute-import,
|
||||||
|
old-division,
|
||||||
|
dict-iter-method,
|
||||||
|
dict-view-method,
|
||||||
|
next-method-called,
|
||||||
|
metaclass-assignment,
|
||||||
|
indexing-exception,
|
||||||
|
raising-string,
|
||||||
|
reload-builtin,
|
||||||
|
oct-method,
|
||||||
|
hex-method,
|
||||||
|
nonzero-method,
|
||||||
|
cmp-method,
|
||||||
|
input-builtin,
|
||||||
|
round-builtin,
|
||||||
|
intern-builtin,
|
||||||
|
unichr-builtin,
|
||||||
|
map-builtin-not-iterating,
|
||||||
|
zip-builtin-not-iterating,
|
||||||
|
range-builtin-not-iterating,
|
||||||
|
filter-builtin-not-iterating,
|
||||||
|
using-cmp-argument,
|
||||||
|
eq-without-hash,
|
||||||
|
div-method,
|
||||||
|
idiv-method,
|
||||||
|
rdiv-method,
|
||||||
|
exception-message-attribute,
|
||||||
|
invalid-str-codec,
|
||||||
|
sys-max-int,
|
||||||
|
bad-python3-import,
|
||||||
|
deprecated-string-function,
|
||||||
|
deprecated-str-translate-call,
|
||||||
|
deprecated-itertools-function,
|
||||||
|
deprecated-types-field,
|
||||||
|
next-method-defined,
|
||||||
|
dict-items-not-iterating,
|
||||||
|
dict-keys-not-iterating,
|
||||||
|
dict-values-not-iterating
|
||||||
|
|
||||||
|
# Enable the message, report, category or checker with the given id(s). You can
|
||||||
|
# either give multiple identifier separated by comma (,) or put this option
|
||||||
|
# multiple time (only on the command line, not in the configuration file where
|
||||||
|
# it should appear only once). See also the "--disable" option for examples.
|
||||||
|
enable=c-extension-no-member
|
||||||
|
|
||||||
|
|
||||||
|
[REPORTS]
|
||||||
|
|
||||||
|
# Python expression which should return a note less than 10 (10 is the highest
|
||||||
|
# note). You have access to the variables errors warning, statement which
|
||||||
|
# respectively contain the number of errors / warnings messages and the total
|
||||||
|
# number of statements analyzed. This is used by the global evaluation report
|
||||||
|
# (RP0004).
|
||||||
|
evaluation=10.0 - ((float(5 * error + warning + refactor + convention) / statement) * 10)
|
||||||
|
|
||||||
|
# Template used to display messages. This is a python new-style format string
|
||||||
|
# used to format the message information. See doc for all details
|
||||||
|
#msg-template=
|
||||||
|
|
||||||
|
# Set the output format. Available formats are text, parseable, colorized, json
|
||||||
|
# and msvs (visual studio).You can also give a reporter class, eg
|
||||||
|
# mypackage.mymodule.MyReporterClass.
|
||||||
|
output-format=text
|
||||||
|
|
||||||
|
# Tells whether to display a full report or only the messages
|
||||||
|
reports=no
|
||||||
|
|
||||||
|
# Activate the evaluation score.
|
||||||
|
score=yes
|
||||||
|
|
||||||
|
|
||||||
|
[REFACTORING]
|
||||||
|
|
||||||
|
# Maximum number of nested blocks for function / method body
|
||||||
|
max-nested-blocks=5
|
||||||
|
|
||||||
|
# Complete name of functions that never returns. When checking for
|
||||||
|
# inconsistent-return-statements if a never returning function is called then
|
||||||
|
# it will be considered as an explicit return statement and no message will be
|
||||||
|
# printed.
|
||||||
|
never-returning-functions=optparse.Values,sys.exit
|
||||||
|
|
||||||
|
|
||||||
|
[LOGGING]
|
||||||
|
|
||||||
|
# Logging modules to check that the string format arguments are in logging
|
||||||
|
# function parameter format
|
||||||
|
logging-modules=logging
|
||||||
|
|
||||||
|
|
||||||
|
[SPELLING]
|
||||||
|
|
||||||
|
# Limits count of emitted suggestions for spelling mistakes
|
||||||
|
max-spelling-suggestions=4
|
||||||
|
|
||||||
|
# Spelling dictionary name. Available dictionaries: none. To make it working
|
||||||
|
# install python-enchant package.
|
||||||
|
spelling-dict=
|
||||||
|
|
||||||
|
# List of comma separated words that should not be checked.
|
||||||
|
spelling-ignore-words=
|
||||||
|
|
||||||
|
# A path to a file that contains private dictionary; one word per line.
|
||||||
|
spelling-private-dict-file=
|
||||||
|
|
||||||
|
# Tells whether to store unknown words to indicated private dictionary in
|
||||||
|
# --spelling-private-dict-file option instead of raising a message.
|
||||||
|
spelling-store-unknown-words=no
|
||||||
|
|
||||||
|
|
||||||
|
[MISCELLANEOUS]
|
||||||
|
|
||||||
|
# List of note tags to take in consideration, separated by a comma.
|
||||||
|
notes=FIXME,
|
||||||
|
XXX,
|
||||||
|
TODO
|
||||||
|
|
||||||
|
|
||||||
|
[VARIABLES]
|
||||||
|
|
||||||
|
# List of additional names supposed to be defined in builtins. Remember that
|
||||||
|
# you should avoid to define new builtins when possible.
|
||||||
|
additional-builtins=
|
||||||
|
|
||||||
|
# Tells whether unused global variables should be treated as a violation.
|
||||||
|
allow-global-unused-variables=yes
|
||||||
|
|
||||||
|
# List of strings which can identify a callback function by name. A callback
|
||||||
|
# name must start or end with one of those strings.
|
||||||
|
callbacks=cb_,
|
||||||
|
_cb
|
||||||
|
|
||||||
|
# A regular expression matching the name of dummy variables (i.e. expectedly
|
||||||
|
# not used).
|
||||||
|
dummy-variables-rgx=_+$|(_[a-zA-Z0-9_]*[a-zA-Z0-9]+?$)|dummy|^ignored_|^unused_
|
||||||
|
|
||||||
|
# Argument names that match this expression will be ignored. Default to name
|
||||||
|
# with leading underscore
|
||||||
|
ignored-argument-names=_.*|^ignored_|^unused_
|
||||||
|
|
||||||
|
# Tells whether we should check for unused import in __init__ files.
|
||||||
|
init-import=no
|
||||||
|
|
||||||
|
# List of qualified module names which can have objects that can redefine
|
||||||
|
# builtins.
|
||||||
|
redefining-builtins-modules=six.moves,past.builtins,future.builtins
|
||||||
|
|
||||||
|
|
||||||
|
[TYPECHECK]
|
||||||
|
|
||||||
|
# List of decorators that produce context managers, such as
|
||||||
|
# contextlib.contextmanager. Add to this list to register other decorators that
|
||||||
|
# produce valid context managers.
|
||||||
|
contextmanager-decorators=contextlib.contextmanager
|
||||||
|
|
||||||
|
# List of members which are set dynamically and missed by pylint inference
|
||||||
|
# system, and so shouldn't trigger E1101 when accessed. Python regular
|
||||||
|
# expressions are accepted.
|
||||||
|
generated-members=
|
||||||
|
|
||||||
|
# Tells whether missing members accessed in mixin class should be ignored. A
|
||||||
|
# mixin class is detected if its name ends with "mixin" (case insensitive).
|
||||||
|
ignore-mixin-members=yes
|
||||||
|
|
||||||
|
# This flag controls whether pylint should warn about no-member and similar
|
||||||
|
# checks whenever an opaque object is returned when inferring. The inference
|
||||||
|
# can return multiple potential results while evaluating a Python object, but
|
||||||
|
# some branches might not be evaluated, which results in partial inference. In
|
||||||
|
# that case, it might be useful to still emit no-member and other checks for
|
||||||
|
# the rest of the inferred objects.
|
||||||
|
ignore-on-opaque-inference=yes
|
||||||
|
|
||||||
|
# List of class names for which member attributes should not be checked (useful
|
||||||
|
# for classes with dynamically set attributes). This supports the use of
|
||||||
|
# qualified names.
|
||||||
|
ignored-classes=optparse.Values,thread._local,_thread._local
|
||||||
|
|
||||||
|
# List of module names for which member attributes should not be checked
|
||||||
|
# (useful for modules/projects where namespaces are manipulated during runtime
|
||||||
|
# and thus existing member attributes cannot be deduced by static analysis. It
|
||||||
|
# supports qualified module names, as well as Unix pattern matching.
|
||||||
|
ignored-modules=
|
||||||
|
|
||||||
|
# Show a hint with possible names when a member name was not found. The aspect
|
||||||
|
# of finding the hint is based on edit distance.
|
||||||
|
missing-member-hint=yes
|
||||||
|
|
||||||
|
# The minimum edit distance a name should have in order to be considered a
|
||||||
|
# similar match for a missing member name.
|
||||||
|
missing-member-hint-distance=1
|
||||||
|
|
||||||
|
# The total number of similar names that should be taken in consideration when
|
||||||
|
# showing a hint for a missing member.
|
||||||
|
missing-member-max-choices=1
|
||||||
|
|
||||||
|
|
||||||
|
[SIMILARITIES]
|
||||||
|
|
||||||
|
# Ignore comments when computing similarities.
|
||||||
|
ignore-comments=yes
|
||||||
|
|
||||||
|
# Ignore docstrings when computing similarities.
|
||||||
|
ignore-docstrings=yes
|
||||||
|
|
||||||
|
# Ignore imports when computing similarities.
|
||||||
|
ignore-imports=no
|
||||||
|
|
||||||
|
# Minimum lines number of a similarity.
|
||||||
|
min-similarity-lines=4
|
||||||
|
|
||||||
|
|
||||||
|
[BASIC]
|
||||||
|
|
||||||
|
# Naming style matching correct argument names
|
||||||
|
argument-naming-style=snake_case
|
||||||
|
|
||||||
|
# Regular expression matching correct argument names. Overrides argument-
|
||||||
|
# naming-style
|
||||||
|
#argument-rgx=
|
||||||
|
|
||||||
|
# Naming style matching correct attribute names
|
||||||
|
attr-naming-style=snake_case
|
||||||
|
|
||||||
|
# Regular expression matching correct attribute names. Overrides attr-naming-
|
||||||
|
# style
|
||||||
|
#attr-rgx=
|
||||||
|
|
||||||
|
# Bad variable names which should always be refused, separated by a comma
|
||||||
|
bad-names=foo,
|
||||||
|
bar,
|
||||||
|
baz,
|
||||||
|
toto,
|
||||||
|
tutu,
|
||||||
|
tata
|
||||||
|
|
||||||
|
# Naming style matching correct class attribute names
|
||||||
|
class-attribute-naming-style=any
|
||||||
|
|
||||||
|
# Regular expression matching correct class attribute names. Overrides class-
|
||||||
|
# attribute-naming-style
|
||||||
|
#class-attribute-rgx=
|
||||||
|
|
||||||
|
# Naming style matching correct class names
|
||||||
|
class-naming-style=PascalCase
|
||||||
|
|
||||||
|
# Regular expression matching correct class names. Overrides class-naming-style
|
||||||
|
#class-rgx=
|
||||||
|
|
||||||
|
# Naming style matching correct constant names
|
||||||
|
const-naming-style=UPPER_CASE
|
||||||
|
|
||||||
|
# Regular expression matching correct constant names. Overrides const-naming-
|
||||||
|
# style
|
||||||
|
#const-rgx=
|
||||||
|
|
||||||
|
# Minimum line length for functions/classes that require docstrings, shorter
|
||||||
|
# ones are exempt.
|
||||||
|
docstring-min-length=-1
|
||||||
|
|
||||||
|
# Naming style matching correct function names
|
||||||
|
function-naming-style=snake_case
|
||||||
|
|
||||||
|
# Regular expression matching correct function names. Overrides function-
|
||||||
|
# naming-style
|
||||||
|
#function-rgx=
|
||||||
|
|
||||||
|
# Good variable names which should always be accepted, separated by a comma
|
||||||
|
good-names=i,
|
||||||
|
j,
|
||||||
|
k,
|
||||||
|
ex,
|
||||||
|
Run,
|
||||||
|
_
|
||||||
|
|
||||||
|
# Include a hint for the correct naming format with invalid-name
|
||||||
|
include-naming-hint=no
|
||||||
|
|
||||||
|
# Naming style matching correct inline iteration names
|
||||||
|
inlinevar-naming-style=any
|
||||||
|
|
||||||
|
# Regular expression matching correct inline iteration names. Overrides
|
||||||
|
# inlinevar-naming-style
|
||||||
|
#inlinevar-rgx=
|
||||||
|
|
||||||
|
# Naming style matching correct method names
|
||||||
|
method-naming-style=snake_case
|
||||||
|
|
||||||
|
# Regular expression matching correct method names. Overrides method-naming-
|
||||||
|
# style
|
||||||
|
#method-rgx=
|
||||||
|
|
||||||
|
# Naming style matching correct module names
|
||||||
|
module-naming-style=snake_case
|
||||||
|
|
||||||
|
# Regular expression matching correct module names. Overrides module-naming-
|
||||||
|
# style
|
||||||
|
#module-rgx=
|
||||||
|
|
||||||
|
# Colon-delimited sets of names that determine each other's naming style when
|
||||||
|
# the name regexes allow several styles.
|
||||||
|
name-group=
|
||||||
|
|
||||||
|
# Regular expression which should only match function or class names that do
|
||||||
|
# not require a docstring.
|
||||||
|
no-docstring-rgx=^_
|
||||||
|
|
||||||
|
# List of decorators that produce properties, such as abc.abstractproperty. Add
|
||||||
|
# to this list to register other decorators that produce valid properties.
|
||||||
|
property-classes=abc.abstractproperty
|
||||||
|
|
||||||
|
# Naming style matching correct variable names
|
||||||
|
variable-naming-style=snake_case
|
||||||
|
|
||||||
|
# Regular expression matching correct variable names. Overrides variable-
|
||||||
|
# naming-style
|
||||||
|
#variable-rgx=
|
||||||
|
|
||||||
|
|
||||||
|
[FORMAT]
|
||||||
|
|
||||||
|
# Expected format of line ending, e.g. empty (any line ending), LF or CRLF.
|
||||||
|
expected-line-ending-format=
|
||||||
|
|
||||||
|
# Regexp for a line that is allowed to be longer than the limit.
|
||||||
|
ignore-long-lines=^\s*(# )?<?https?://\S+>?$
|
||||||
|
|
||||||
|
# Number of spaces of indent required inside a hanging or continued line.
|
||||||
|
indent-after-paren=4
|
||||||
|
|
||||||
|
# String used as indentation unit. This is usually " " (4 spaces) or "\t" (1
|
||||||
|
# tab).
|
||||||
|
indent-string=' '
|
||||||
|
|
||||||
|
# Maximum number of characters on a single line.
|
||||||
|
max-line-length=100
|
||||||
|
|
||||||
|
# Maximum number of lines in a module
|
||||||
|
max-module-lines=1000
|
||||||
|
|
||||||
|
# List of optional constructs for which whitespace checking is disabled. `dict-
|
||||||
|
# separator` is used to allow tabulation in dicts, etc.: {1 : 1,\n222: 2}.
|
||||||
|
# `trailing-comma` allows a space between comma and closing bracket: (a, ).
|
||||||
|
# `empty-line` allows space-only lines.
|
||||||
|
no-space-check=trailing-comma,
|
||||||
|
dict-separator
|
||||||
|
|
||||||
|
# Allow the body of a class to be on the same line as the declaration if body
|
||||||
|
# contains single statement.
|
||||||
|
single-line-class-stmt=no
|
||||||
|
|
||||||
|
# Allow the body of an if to be on the same line as the test if there is no
|
||||||
|
# else.
|
||||||
|
single-line-if-stmt=no
|
||||||
|
|
||||||
|
|
||||||
|
[IMPORTS]
|
||||||
|
|
||||||
|
# Allow wildcard imports from modules that define __all__.
|
||||||
|
allow-wildcard-with-all=no
|
||||||
|
|
||||||
|
# Analyse import fallback blocks. This can be used to support both Python 2 and
|
||||||
|
# 3 compatible code, which means that the block might have code that exists
|
||||||
|
# only in one or another interpreter, leading to false positives when analysed.
|
||||||
|
analyse-fallback-blocks=no
|
||||||
|
|
||||||
|
# Deprecated modules which should not be used, separated by a comma
|
||||||
|
deprecated-modules=regsub,
|
||||||
|
TERMIOS,
|
||||||
|
Bastion,
|
||||||
|
rexec
|
||||||
|
|
||||||
|
# Create a graph of external dependencies in the given file (report RP0402 must
|
||||||
|
# not be disabled)
|
||||||
|
ext-import-graph=
|
||||||
|
|
||||||
|
# Create a graph of every (i.e. internal and external) dependencies in the
|
||||||
|
# given file (report RP0402 must not be disabled)
|
||||||
|
import-graph=
|
||||||
|
|
||||||
|
# Create a graph of internal dependencies in the given file (report RP0402 must
|
||||||
|
# not be disabled)
|
||||||
|
int-import-graph=
|
||||||
|
|
||||||
|
# Force import order to recognize a module as part of the standard
|
||||||
|
# compatibility libraries.
|
||||||
|
known-standard-library=
|
||||||
|
|
||||||
|
# Force import order to recognize a module as part of a third party library.
|
||||||
|
known-third-party=enchant
|
||||||
|
|
||||||
|
|
||||||
|
[CLASSES]
|
||||||
|
|
||||||
|
# List of method names used to declare (i.e. assign) instance attributes.
|
||||||
|
defining-attr-methods=__init__,
|
||||||
|
__new__,
|
||||||
|
setUp
|
||||||
|
|
||||||
|
# List of member names, which should be excluded from the protected access
|
||||||
|
# warning.
|
||||||
|
exclude-protected=_asdict,
|
||||||
|
_fields,
|
||||||
|
_replace,
|
||||||
|
_source,
|
||||||
|
_make
|
||||||
|
|
||||||
|
# List of valid names for the first argument in a class method.
|
||||||
|
valid-classmethod-first-arg=cls
|
||||||
|
|
||||||
|
# List of valid names for the first argument in a metaclass class method.
|
||||||
|
valid-metaclass-classmethod-first-arg=mcs
|
||||||
|
|
||||||
|
|
||||||
|
[DESIGN]
|
||||||
|
|
||||||
|
# Maximum number of arguments for function / method
|
||||||
|
max-args=5
|
||||||
|
|
||||||
|
# Maximum number of attributes for a class (see R0902).
|
||||||
|
max-attributes=7
|
||||||
|
|
||||||
|
# Maximum number of boolean expressions in a if statement
|
||||||
|
max-bool-expr=5
|
||||||
|
|
||||||
|
# Maximum number of branch for function / method body
|
||||||
|
max-branches=12
|
||||||
|
|
||||||
|
# Maximum number of locals for function / method body
|
||||||
|
max-locals=15
|
||||||
|
|
||||||
|
# Maximum number of parents for a class (see R0901).
|
||||||
|
max-parents=7
|
||||||
|
|
||||||
|
# Maximum number of public methods for a class (see R0904).
|
||||||
|
max-public-methods=20
|
||||||
|
|
||||||
|
# Maximum number of return / yield for function / method body
|
||||||
|
max-returns=6
|
||||||
|
|
||||||
|
# Maximum number of statements in function / method body
|
||||||
|
max-statements=50
|
||||||
|
|
||||||
|
# Minimum number of public methods for a class (see R0903).
|
||||||
|
min-public-methods=2
|
||||||
|
|
||||||
|
|
||||||
|
[EXCEPTIONS]
|
||||||
|
|
||||||
|
# Exceptions that will emit a warning when being caught. Defaults to
|
||||||
|
# "Exception"
|
||||||
|
overgeneral-exceptions=Exception
|
1
raw_report.json
Normal file
1
raw_report.json
Normal file
|
@ -0,0 +1 @@
|
||||||
|
raw_report.json
|
1
report-task.txt
Normal file
1
report-task.txt
Normal file
|
@ -0,0 +1 @@
|
||||||
|
report-task.txt
|
|
@ -2,3 +2,7 @@ coverage
|
||||||
python_prctl
|
python_prctl
|
||||||
psutil
|
psutil
|
||||||
pycrypto
|
pycrypto
|
||||||
|
nose
|
||||||
|
radon
|
||||||
|
coverage
|
||||||
|
pytest
|
||||||
|
|
0
results.xml
Normal file
0
results.xml
Normal file
Loading…
Reference in New Issue
Block a user