summaryrefslogtreecommitdiff
path: root/numpy/tests/test_warnings.py
diff options
context:
space:
mode:
Diffstat (limited to 'numpy/tests/test_warnings.py')
-rw-r--r--numpy/tests/test_warnings.py114
1 files changed, 55 insertions, 59 deletions
diff --git a/numpy/tests/test_warnings.py b/numpy/tests/test_warnings.py
index f5560a099..d7a6d880c 100644
--- a/numpy/tests/test_warnings.py
+++ b/numpy/tests/test_warnings.py
@@ -2,77 +2,73 @@
Tests which scan for certain occurrences in the code, they may not find
all of these occurrences but should catch almost all.
"""
-from __future__ import division, absolute_import, print_function
-
-import sys
import pytest
-if sys.version_info >= (3, 4):
- from pathlib import Path
- import ast
- import tokenize
- import numpy
-
- class ParseCall(ast.NodeVisitor):
- def __init__(self):
- self.ls = []
-
- def visit_Attribute(self, node):
- ast.NodeVisitor.generic_visit(self, node)
- self.ls.append(node.attr)
-
- def visit_Name(self, node):
- self.ls.append(node.id)
+from pathlib import Path
+import ast
+import tokenize
+import numpy
+class ParseCall(ast.NodeVisitor):
+ def __init__(self):
+ self.ls = []
- class FindFuncs(ast.NodeVisitor):
- def __init__(self, filename):
- super().__init__()
- self.__filename = filename
+ def visit_Attribute(self, node):
+ ast.NodeVisitor.generic_visit(self, node)
+ self.ls.append(node.attr)
- def visit_Call(self, node):
- p = ParseCall()
- p.visit(node.func)
- ast.NodeVisitor.generic_visit(self, node)
+ def visit_Name(self, node):
+ self.ls.append(node.id)
- if p.ls[-1] == 'simplefilter' or p.ls[-1] == 'filterwarnings':
- if node.args[0].s == "ignore":
- raise AssertionError(
- "ignore filter should not be used; found in "
- "{} on line {}".format(self.__filename, node.lineno))
- if p.ls[-1] == 'warn' and (
- len(p.ls) == 1 or p.ls[-2] == 'warnings'):
+class FindFuncs(ast.NodeVisitor):
+ def __init__(self, filename):
+ super().__init__()
+ self.__filename = filename
- if "testing/tests/test_warnings.py" == self.__filename:
- # This file
- return
+ def visit_Call(self, node):
+ p = ParseCall()
+ p.visit(node.func)
+ ast.NodeVisitor.generic_visit(self, node)
- # See if stacklevel exists:
- if len(node.args) == 3:
- return
- args = {kw.arg for kw in node.keywords}
- if "stacklevel" in args:
- return
+ if p.ls[-1] == 'simplefilter' or p.ls[-1] == 'filterwarnings':
+ if node.args[0].s == "ignore":
raise AssertionError(
"warnings should have an appropriate stacklevel; found in "
"{} on line {}".format(self.__filename, node.lineno))
+ if p.ls[-1] == 'warn' and (
+ len(p.ls) == 1 or p.ls[-2] == 'warnings'):
+
+ if "testing/tests/test_warnings.py" == self.__filename:
+ # This file
+ return
+
+ # See if stacklevel exists:
+ if len(node.args) == 3:
+ return
+ args = {kw.arg for kw in node.keywords}
+ if "stacklevel" in args:
+ return
+ raise AssertionError(
+ "warnings should have an appropriate stacklevel; found in "
+ "{} on line {}".format(self.__filename, node.lineno))
+
- @pytest.mark.slow
- def test_warning_calls():
- # combined "ignore" and stacklevel error
- base = Path(numpy.__file__).parent
+@pytest.mark.slow
+def test_warning_calls():
+ # combined "ignore" and stacklevel error
+ base = Path(numpy.__file__).parent
- for path in base.rglob("*.py"):
- if base / "testing" in path.parents:
- continue
- if path == base / "__init__.py":
- continue
- if path == base / "random" / "__init__.py":
- continue
- # use tokenize to auto-detect encoding on systems where no
- # default encoding is defined (e.g. LANG='C')
- with tokenize.open(str(path)) as file:
- tree = ast.parse(file.read())
- FindFuncs(path).visit(tree)
+ for path in base.rglob("*.py"):
+ if base / "testing" in path.parents:
+ continue
+ if path == base / "__init__.py":
+ continue
+ if path == base / "random" / "__init__.py":
+ continue
+ # use tokenize to auto-detect encoding on systems where no
+ # default encoding is defined (e.g. LANG='C')
+ with tokenize.open(str(path)) as file:
+ tree = ast.parse(file.read())
+ FindFuncs(path).visit(tree)