summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatt Clay <matt@mystile.com>2017-09-11 16:39:34 -0700
committerToshio Kuratomi <a.badger@gmail.com>2017-09-11 17:31:29 -0700
commit0742e58e785aac8dd8c75aef51025c9a7ba4f735 (patch)
tree084013000fd2b9fbd43f268b161d77a412d388d1
parent525c2a3e85af5ae2b821747fc5ea6629dc815c57 (diff)
downloadansible-0742e58e785aac8dd8c75aef51025c9a7ba4f735.tar.gz
Fix ansible-test unicode and sanity tests. (#29743)
* Show warning when using pylint on Python 2.6. * Add pylint disable entries for Python 2. * Fix unicode handling in ansible-test. * Add missing documentation. (cherry picked from commit 79bc49e150443353ded8997760b53db4281bfb83)
-rw-r--r--test/runner/import/lib/ansible/__init__.py1
-rw-r--r--test/runner/lib/sanity/__init__.py4
-rw-r--r--test/runner/lib/sanity/ansible_doc.py4
-rw-r--r--test/runner/lib/sanity/pylint.py10
-rw-r--r--test/runner/lib/test.py2
-rw-r--r--test/runner/tox.ini2
-rw-r--r--test/sanity/pylint/disable.txt5
7 files changed, 22 insertions, 6 deletions
diff --git a/test/runner/import/lib/ansible/__init__.py b/test/runner/import/lib/ansible/__init__.py
index e69de29bb2..efba395dd1 100644
--- a/test/runner/import/lib/ansible/__init__.py
+++ b/test/runner/import/lib/ansible/__init__.py
@@ -0,0 +1 @@
+"""Empty placeholder for import sanity test."""
diff --git a/test/runner/lib/sanity/__init__.py b/test/runner/lib/sanity/__init__.py
index 490f960b16..0589b1bddd 100644
--- a/test/runner/lib/sanity/__init__.py
+++ b/test/runner/lib/sanity/__init__.py
@@ -169,7 +169,7 @@ class SanityFailure(TestFailure):
:type test: str
:type python_version: str
:type messages: list[SanityMessage]
- :type summary: str
+ :type summary: unicode
"""
super(SanityFailure, self).__init__(COMMAND, test, python_version, messages, summary)
@@ -227,7 +227,7 @@ class SanityCodeSmellTest(SanityTest):
status = ex.status
if stderr or status:
- summary = str(SubprocessError(cmd=cmd, status=status, stderr=stderr, stdout=stdout))
+ summary = u'%s' % SubprocessError(cmd=cmd, status=status, stderr=stderr, stdout=stdout)
return SanityFailure(self.name, summary=summary)
return SanitySuccess(self.name)
diff --git a/test/runner/lib/sanity/ansible_doc.py b/test/runner/lib/sanity/ansible_doc.py
index e3b9d50a3c..55f6436873 100644
--- a/test/runner/lib/sanity/ansible_doc.py
+++ b/test/runner/lib/sanity/ansible_doc.py
@@ -57,14 +57,14 @@ class AnsibleDocTest(SanityMultipleVersion):
status = ex.status
if status:
- summary = str(SubprocessError(cmd=cmd, status=status, stderr=stderr))
+ summary = u'%s' % SubprocessError(cmd=cmd, status=status, stderr=stderr)
return SanityFailure(self.name, summary=summary, python_version=python_version)
if stdout:
display.info(stdout.strip(), verbosity=3)
if stderr:
- summary = 'Output on stderr from ansible-doc is considered an error.\n\n%s' % SubprocessError(cmd, stderr=stderr)
+ summary = u'Output on stderr from ansible-doc is considered an error.\n\n%s' % SubprocessError(cmd, stderr=stderr)
return SanityFailure(self.name, summary=summary, python_version=python_version)
return SanitySuccess(self.name, python_version=python_version)
diff --git a/test/runner/lib/sanity/pylint.py b/test/runner/lib/sanity/pylint.py
index 45347a09e3..65c095eb0b 100644
--- a/test/runner/lib/sanity/pylint.py
+++ b/test/runner/lib/sanity/pylint.py
@@ -9,11 +9,13 @@ from lib.sanity import (
SanityMessage,
SanityFailure,
SanitySuccess,
+ SanitySkipped,
)
from lib.util import (
SubprocessError,
run_command,
+ display,
)
from lib.ansible_util import (
@@ -30,6 +32,10 @@ from lib.test import (
PYLINT_SKIP_PATH = 'test/sanity/pylint/skip.txt'
+UNSUPPORTED_PYTHON_VERSIONS = (
+ '2.6',
+)
+
class PylintTest(SanitySingleVersion):
"""Sanity test using pylint."""
@@ -39,6 +45,10 @@ class PylintTest(SanitySingleVersion):
:type targets: SanityTargets
:rtype: SanityResult
"""
+ if args.python_version in UNSUPPORTED_PYTHON_VERSIONS:
+ display.warning('Skipping pylint on unsupported Python version %s.' % args.python_version)
+ return SanitySkipped(self.name)
+
with open(PYLINT_SKIP_PATH, 'r') as skip_fd:
skip_paths = skip_fd.read().splitlines()
diff --git a/test/runner/lib/test.py b/test/runner/lib/test.py
index 967f1d842b..c199fb1f01 100644
--- a/test/runner/lib/test.py
+++ b/test/runner/lib/test.py
@@ -194,7 +194,7 @@ class TestFailure(TestResult):
:type test: str
:type python_version: str | None
:type messages: list[TestMessage] | None
- :type summary: str | None
+ :type summary: unicode | None
"""
super(TestFailure, self).__init__(command, test, python_version)
diff --git a/test/runner/tox.ini b/test/runner/tox.ini
index e3b6c47915..edd81f1c3f 100644
--- a/test/runner/tox.ini
+++ b/test/runner/tox.ini
@@ -5,7 +5,7 @@ minversion = 2.5.0
[testenv]
changedir = {toxinidir}/../../
commands = {posargs}
-passenv = HOME SHIPPABLE*
+passenv = HOME LC_ALL SHIPPABLE*
args_are_paths = False
deps = setuptools == 35.0.2
wheel < 0.30.0 ; python_version < '2.7'
diff --git a/test/sanity/pylint/disable.txt b/test/sanity/pylint/disable.txt
index 8bc2fae97d..e8a7bd0608 100644
--- a/test/sanity/pylint/disable.txt
+++ b/test/sanity/pylint/disable.txt
@@ -18,6 +18,7 @@ cell-var-from-loop
consider-iterating-dictionary
consider-using-enumerate
dangerous-default-value
+deprecated-lambda
deprecated-method
deprecated-module
duplicate-key
@@ -32,6 +33,7 @@ global-variable-not-assigned
global-variable-undefined
import-error
import-self
+invalid-encoded-data
invalid-name
line-too-long
locally-disabled
@@ -41,6 +43,7 @@ lost-exception
method-hidden
misplaced-comparison-constant
missing-docstring
+no-init
no-member
no-name-in-module
no-self-use
@@ -49,6 +52,7 @@ non-iterator-returned
not-a-mapping
not-an-iterable
not-callable
+old-style-class
pointless-statement
pointless-string-statement
protected-access
@@ -58,6 +62,7 @@ redefined-outer-name
redefined-variable-type
redundant-unittest-assert
reimported
+relative-import
signature-differs
simplifiable-if-statement
super-init-not-called