From fc2b7f80123221fef5c29701a863ed0401827637 Mon Sep 17 00:00:00 2001 From: Lee Clemens Date: Tue, 7 Jul 2015 20:10:26 -0400 Subject: [PATCH] Multiple Travis and coverage related changes Reorganize .travis.yml Separate coverage tests for Python 2 and Python 3 Execute setup.py install using the environment's Python exe Sanitize Travis execution order --- .travis.yml | 67 +++++++++++++++++++++++++++++++++++++---------------- ChangeLog | 1 + 2 files changed, 48 insertions(+), 20 deletions(-) diff --git a/.travis.yml b/.travis.yml index c48b6335..8a72163a 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,29 +1,56 @@ # vim ft=yaml # travis-ci.org definition for Fail2Ban build +# https://travis-ci.org/fail2ban/fail2ban/ language: python python: - - "2.6" - - "2.7" - - "3.2" - - "3.3" - - "3.4" -# - "pypy" # disabled for now due to frequent unreproducable failures # gh-1089 - - "pypy3" + - 2.6 + - 2.7 + - pypy + - 3.2 + - 3.3 + - 3.4 + - pypy3 before_install: - - if [[ $TRAVIS_PYTHON_VERSION == 2.7 ]]; then travis_retry sudo apt-get update -qq; fi + - if [[ $TRAVIS_PYTHON_VERSION == 2* || $TRAVIS_PYTHON_VERSION == 'pypy' ]]; then export F2B_PY_2=true && echo "Set F2B_PY_2"; fi + - if [[ $TRAVIS_PYTHON_VERSION == 3* || $TRAVIS_PYTHON_VERSION == 'pypy3' ]]; then export F2B_PY_3=true && echo "Set F2B_PY_3"; fi + - travis_retry sudo apt-get update -qq + # Set this so sudo executes the correct python binary + # Anything not using sudo will already have the correct environment + - export PYTHON_CMD="$VIRTUAL_ENV/bin/python" && echo "PYTHON_CMD set to $PYTHON_CMD" install: + # Install Python packages / dependencies + # coverage + - travis_retry pip install coverage + # coveralls + - travis_retry pip install coveralls + # dnspython or dnspython3 + - if [[ "$F2B_PY_2" ]]; then travis_retry pip install dnspython; fi + - if [[ "$F2B_PY_3" ]]; then travis_retry pip install dnspython3; fi + # gamin - install manually (not in PyPI) - travis-ci system Python is 2.7 + - if [[ $TRAVIS_PYTHON_VERSION == 2.7 ]]; then travis_retry sudo apt-get install -qq python-gamin && cp /usr/share/pyshared/gamin.py /usr/lib/pyshared/python2.7/_gamin.so $VIRTUAL_ENV/lib/python2.7/site-packages/; fi + # pyinotify - travis_retry pip install pyinotify - - if [[ $TRAVIS_PYTHON_VERSION == 2* || $TRAVIS_PYTHON_VERSION == 'pypy' ]]; then travis_retry pip install dnspython; fi - - if [[ $TRAVIS_PYTHON_VERSION == 3* || $TRAVIS_PYTHON_VERSION == 'pypy3' ]]; then travis_retry pip install dnspython3; fi - - if [[ $TRAVIS_PYTHON_VERSION == 2.7 ]]; then travis_retry sudo apt-get install -qq python-gamin; cp /usr/share/pyshared/gamin.py /usr/lib/pyshared/python2.7/_gamin.so $VIRTUAL_ENV/lib/python2.7/site-packages/; fi - - if [[ $TRAVIS_PYTHON_VERSION == 2.7 ]]; then cd ..; travis_retry pip install -q coveralls; cd -; fi - # overcome buggy pypy - - if [[ $TRAVIS_PYTHON_VERSION == pypy ]] ; then dpkg --compare-versions $(pypy --version 2>&1 | awk '/PyPy/{print $2;}') ge 2.5.1 || { d=$PWD; cd /tmp; wget --no-check-certificate https://bitbucket.org/pypy/pypy/downloads/pypy-2.5.1-linux64.tar.bz2; tar -xjvf pypy*bz2; cd pypy-*/bin/; export PATH=$PWD:$PATH; cd $d; } ; fi +before_script: + # Manually execute 2to3 for now + - if [[ "$F2B_PY_3" ]]; then ./fail2ban-2to3; fi script: - - if [[ $TRAVIS_PYTHON_VERSION == 2.7 ]]; then coverage run --rcfile=.travis_coveragerc setup.py test; else python setup.py test; fi -# test installation - - sudo python setup.py install + # Keep the legacy setup.py test approach of checking coverage for python2 + - if [[ "$F2B_PY_2" ]]; then coverage run setup.py test; fi + # Coverage doesn't pick up setup.py test with python3, so run it directly + - if [[ "$F2B_PY_3" ]]; then coverage run bin/fail2ban-testcases; fi + # Use $PYTHON_CMD (not python) or else sudo will always run the system's python (2.7) + - sudo $PYTHON_CMD setup.py install after_success: -# Coverage config file must be .coveragerc for coveralls - - if [[ $TRAVIS_PYTHON_VERSION == 2.7 ]]; then cp -v .travis_coveragerc .coveragerc; fi - - if [[ $TRAVIS_PYTHON_VERSION == 2.7 ]]; then coveralls; fi + - coveralls +matrix: + fast_finish: true +# Might be worth looking into +#notifications: +# email: true +# irc: +# channels: "irc.freenode.org#fail2ban" +# template: +# - "%{repository}@%{branch}: %{message} (%{build_url})" +# on_success: change +# on_failure: change +# skip_join: true diff --git a/ChangeLog b/ChangeLog index 6821a5f9..a1c39ad8 100644 --- a/ChangeLog +++ b/ChangeLog @@ -41,6 +41,7 @@ ver. 0.9.3 (2015/XX/XXX) - wanna-be-released * fail2ban-testcases man page * filter.d/apache-badbots.conf, filter.d/nginx-botsearch.conf - add HEAD method verb + * Revamp of Travis and coverage automated testing ver. 0.9.2 (2015/04/29) - better-quick-now-than-later