Parcourir la source

Consolidate root/utils tests

- Consolidate tests between the root of the repo and utils
Jason DeTiberus il y a 8 ans
Parent
commit
fda3b434b7
13 fichiers modifiés avec 38 ajouts et 110 suppressions
  1. 3 2
      .coveragerc
  2. 2 1
      .flake8
  3. 21 4
      .travis.yml
  4. 0 2
      pytest.ini
  5. 4 3
      requirements.txt
  6. 1 3
      test-requirements.txt
  7. 7 4
      tox.ini
  8. 0 18
      utils/.coveragerc
  9. 0 1
      utils/.pylintrc
  10. 0 27
      utils/setup.cfg
  11. 0 11
      utils/setup.py
  12. 0 15
      utils/test-requirements.txt
  13. 0 19
      utils/tox.ini

+ 3 - 2
.coveragerc

@@ -4,16 +4,17 @@ omit =
     */lib/python*/site-packages/*
     */lib/python*/*
     /usr/*
-    setup.py
+    */setup.py
     # TODO(rhcarvalho): this is used to ignore test files from coverage report.
     # We can make this less generic when we stick with a single test pattern in
     # the repo.
     */conftest.py
     */test_*.py
     */*_tests.py
+    */test/*
 
 [report]
-fail_under = 25
+fail_under = 29
 
 [html]
 directory = cover

+ 2 - 1
.flake8

@@ -1,4 +1,5 @@
 [flake8]
-exclude=.tox,utils,inventory
+# TODO: cleanup flake8 issues with utils/test/*
+exclude=.tox,inventory,utils/test
 max_line_length = 120
 ignore = E501,T003

+ 21 - 4
.travis.yml

@@ -4,17 +4,34 @@ sudo: false
 cache:
   - pip
 
+before_cache:
+  - rm ~/.cache/pip/log/debug.log
+
 language: python
 python:
   - "2.7"
   - "3.5"
 
 install:
-  - pip install -r requirements.txt
   - pip install tox-travis
 
 script:
-  # TODO(rhcarvalho): check syntax of other important entrypoint playbooks
-  - ansible-playbook --syntax-check playbooks/byo/config.yml
   - tox
-  - cd utils && tox
+
+notifications:
+  email:
+    recipients:
+      - jdetiber@redhat.com
+      - sdodson@redhat.com
+    on_success: change
+    on_failure: always
+  irc:
+    channels:
+      - chat.freenode.net#openshift-dev
+    on_success: change
+    on_failure: always
+    template:
+      - "%{repository}#%{build_number} (%{branch} - %{commit} : %{author}): %{message}"
+      - "Change view : %{compare_url}"
+      - "Build details : %{build_url}"
+      - "sdodson jdetiber: ^"

+ 0 - 2
pytest.ini

@@ -4,8 +4,6 @@ norecursedirs =
     __pycache__
     cover
     docs
-    # utils has it's own config
-    utils
 python_files =
     # TODO(rhcarvalho): rename test files to follow a single pattern. "test*.py"
     # is Python unittest's default, while pytest discovers both "test_*.py" and

+ 4 - 3
requirements.txt

@@ -1,5 +1,6 @@
 ansible>=2.2
-six
+click
 pyOpenSSL
-PyYAML
-ruamel.yaml
+# We need to disable ruamel.yaml for now because of test failures
+#ruamel.yaml
+six

+ 1 - 3
test-requirements.txt

@@ -1,11 +1,9 @@
-six
-pyOpenSSL
+# flake8 must be listed before pylint to avoid dependency conflicts
 flake8
 flake8-mutable
 flake8-print
 pylint
 setuptools-lint
-PyYAML
 yamllint
 coverage
 mock

+ 7 - 4
tox.ini

@@ -1,21 +1,24 @@
 [tox]
 minversion=2.3.1
 envlist =
-    py{27,35}-ansible22-{pylint,unit,flake8,yamllint,generate_validation}
+    py{27,35}-{flake8,pylint,unit}
+    py27-{yamllint,ansible_syntax,generate_validation}
 skipsdist=True
 skip_missing_interpreters=True
 
 [testenv]
+skip_install=True
 deps =
+    -rrequirements.txt
     -rtest-requirements.txt
     py35-flake8: flake8-bugbear
-    ansible22: ansible~=2.2
 
 commands =
+    unit: pip install -e utils
     unit: pytest {posargs}
     flake8: flake8 {posargs}
     pylint: python setup.py lint
     yamllint: python setup.py yamllint
     generate_validation: python setup.py generate_validation
-
-
+    # TODO(rhcarvalho): check syntax of other important entrypoint playbooks
+    ansible_syntax: ansible-playbook --syntax-check playbooks/byo/config.yml

+ 0 - 18
utils/.coveragerc

@@ -1,18 +0,0 @@
-[run]
-branch = True
-omit =
-    */lib/python*/site-packages/*
-    */lib/python*/*
-    /usr/*
-    setup.py
-    # TODO(rhcarvalho): this is used to ignore test files from coverage report.
-    # We can make this less generic when we stick with a single test pattern in
-    # the repo.
-    test_*.py
-    *_tests.py
-
-[report]
-fail_under = 73
-
-[html]
-directory = cover

+ 0 - 1
utils/.pylintrc

@@ -1 +0,0 @@
-../.pylintrc

+ 0 - 27
utils/setup.cfg

@@ -3,30 +3,3 @@
 # 3. If at all possible, it is good practice to do this. If you cannot, you
 # will need to generate wheels for each Python version that you support.
 universal=1
-
-[aliases]
-test=pytest
-
-[flake8]
-max-line-length=120
-exclude=test/*,setup.py,oo-installenv
-ignore=E501
-
-[lint]
-lint_disable=fixme,locally-disabled,file-ignored,duplicate-code
-
-[tool:pytest]
-testpaths = test
-norecursedirs =
-    .*
-    __pycache__
-python_files =
-    # TODO(rhcarvalho): rename test files to follow a single pattern. "test*.py"
-    # is Python unittest's default, while pytest discovers both "test_*.py" and
-    # "*_test.py" by default.
-    test_*.py
-    *_tests.py
-addopts =
-    --cov=.
-    --cov-report=term
-    --cov-report=html

+ 0 - 11
utils/setup.py

@@ -38,26 +38,15 @@ setup(
 
     # You can just specify the packages manually here if your project is
     # simple. Or you can use find_packages().
-    #packages=find_packages(exclude=['contrib', 'docs', 'tests*']),
     packages=['ooinstall'],
     package_dir={'': 'src'},
 
-
     # List run-time dependencies here.  These will be installed by pip when
     # your project is installed. For an analysis of "install_requires" vs pip's
     # requirements files see:
     # https://packaging.python.org/en/latest/requirements.html
     install_requires=['click', 'PyYAML', 'ansible'],
 
-    # List additional groups of dependencies here (e.g. development
-    # dependencies). You can install these using the following syntax,
-    # for example:
-    # $ pip install -e .[dev,test]
-    #extras_require={
-    #    'dev': ['check-manifest'],
-    #    'test': ['coverage'],
-    #},
-
     # If there are data files included in your packages that need to be
     # installed, specify them here.  If using Python 2.6 or less, then these
     # have to be included in MANIFEST.in as well.

+ 0 - 15
utils/test-requirements.txt

@@ -1,15 +0,0 @@
-ansible
-# flake8 moved to before setuptools-lint to satisfy mccabe dependency issue
-flake8
-setuptools-lint
-coverage
-mock
-PyYAML
-click
-backports.functools_lru_cache
-pyOpenSSL
-yamllint
-tox
-detox
-pytest
-pytest-cov

+ 0 - 19
utils/tox.ini

@@ -1,19 +0,0 @@
-[tox]
-minversion=2.3.1
-envlist =
-    py{27,35}-{flake8,unit,pylint}
-skipsdist=True
-skip_missing_interpreters=True
-
-[testenv]
-usedevelop=True
-deps =
-    -rtest-requirements.txt
-    py35-flake8: flake8-bugbear
-commands =
-    # Needed to make detox work, since it ignores usedevelop
-    # https://github.com/tox-dev/tox/issues/180
-    unit: pip install -e .
-    unit: pytest {posargs}
-    flake8: python setup.py flake8
-    pylint: python setup.py lint