Compare commits
86 Commits
v0.6
...
v0.6_Flatp
Author | SHA1 | Date | |
---|---|---|---|
8b6f9853cd | |||
|
f0e75af3e8 | ||
|
0395355e6c | ||
|
bafe704012 | ||
|
9d648566d6 | ||
|
7a66fa2279 | ||
|
c7a4876e06 | ||
|
e9a5fe278d | ||
|
244d95d53b | ||
|
aaf1af6c59 | ||
|
20502a2142 | ||
|
670f022aba | ||
|
a10f926845 | ||
|
28b9a6c241 | ||
|
32fdc5c2b3 | ||
|
f72adf1474 | ||
|
a605c58c30 | ||
|
96b2680378 | ||
|
59940e33c2 | ||
|
171c2cb2d3 | ||
|
e6a39fc745 | ||
|
80306b9d9d | ||
|
7d5bd5fda3 | ||
|
023fda884a | ||
|
6567eb7672 | ||
|
677905277d | ||
|
24305aa251 | ||
|
432b8aafc5 | ||
|
d5fe9c723f | ||
|
d6929e8c06 | ||
|
25806d0c5c | ||
|
056c41c307 | ||
|
a26293e509 | ||
|
aaec5b58db | ||
|
fb1ad71265 | ||
|
b4d731c798 | ||
|
f02e600d82 | ||
|
1f9d71d611 | ||
|
66d4b77286 | ||
|
e5997349e6 | ||
|
b26405251d | ||
|
baafcfe739 | ||
|
0f89e0db05 | ||
|
afa4f515d3 | ||
|
6d505f5a74 | ||
|
ff36d380a5 | ||
|
cc9fdaf28f | ||
|
1467912299 | ||
|
43e42bbe6c | ||
|
8f6cad8b12 | ||
|
ccb4775991 | ||
|
d16ac68fad | ||
|
f4f46da249 | ||
|
5045f95fc2 | ||
|
c5872c4ea1 | ||
|
95b6ef42f1 | ||
|
68b3c7edb2 | ||
|
7749268e62 | ||
|
5be7fd1840 | ||
|
048a7239a5 | ||
|
34e77e980d | ||
|
a90eedefe7 | ||
|
18fbe9629a | ||
|
3156423597 | ||
|
b372c64a51 | ||
|
31e40e7a9a | ||
|
906bd0ff10 | ||
|
a8d870bf7f | ||
|
890f8e2475 | ||
|
e3b3ffcd7a | ||
|
b6b43a3b93 | ||
|
2b00970070 | ||
|
44d849263d | ||
|
934c6ce978 | ||
|
9585362d36 | ||
|
391fe5446a | ||
|
1b4009812f | ||
|
546f168d08 | ||
|
49cb0a69e0 | ||
|
5dd842f238 | ||
|
d67d646913 | ||
|
6e061e198c | ||
|
7ef2acc2d0 | ||
|
a526740e2f | ||
|
2f9f18be53 | ||
|
bb9c334add |
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -19,3 +19,6 @@ docs/_*/*
|
|||
docs/autodoc/
|
||||
build
|
||||
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
|
||||
psutil
|
||||
pycrypto
|
||||
nose
|
||||
radon
|
||||
coverage
|
||||
pytest
|
||||
|
|
0
results.xml
Normal file
0
results.xml
Normal file
|
@ -1,4 +1,4 @@
|
|||
# pylint: disable=too-many-branches,too-many-statements,protected-access
|
||||
# pylint: disable=too-many-branches,too-many-statements,protected-access
|
||||
"""
|
||||
Proof of work calculation
|
||||
"""
|
||||
|
|
Loading…
Reference in New Issue
Block a user