Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
2feb6425
Commit
2feb6425
authored
Feb 11, 2016
by
Serhiy Storchaka
Browse files
Options
Browse Files
Download
Plain Diff
Issue #26325: Added test.support.check_no_resource_warning() to check that
no ResourceWarning is emitted.
parents
885bdc49
94a619d4
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
32 additions
and
20 deletions
+32
-20
Lib/test/support/__init__.py
Lib/test/support/__init__.py
+23
-1
Lib/test/test_asyncio/test_subprocess.py
Lib/test/test_asyncio/test_subprocess.py
+1
-2
Lib/test/test_io.py
Lib/test/test_io.py
+3
-9
Lib/test/test_xml_etree.py
Lib/test/test_xml_etree.py
+2
-8
Misc/NEWS
Misc/NEWS
+3
-0
No files found.
Lib/test/support/__init__.py
View file @
2feb6425
...
...
@@ -102,7 +102,8 @@ __all__ = [
# threads
"threading_setup"
,
"threading_cleanup"
,
"reap_threads"
,
"start_threads"
,
# miscellaneous
"check_warnings"
,
"EnvironmentVarGuard"
,
"run_with_locale"
,
"swap_item"
,
"check_warnings"
,
"check_no_resource_warning"
,
"EnvironmentVarGuard"
,
"run_with_locale"
,
"swap_item"
,
"swap_attr"
,
"Matcher"
,
"set_memlimit"
,
"SuppressCrashReport"
,
"sortdict"
,
"run_with_tz"
,
]
...
...
@@ -1149,6 +1150,27 @@ def check_warnings(*filters, **kwargs):
return
_filterwarnings
(
filters
,
quiet
)
@
contextlib
.
contextmanager
def
check_no_resource_warning
(
testcase
):
"""Context manager to check that no ResourceWarning is emitted.
Usage:
with check_no_resource_warning(self):
f = open(...)
...
del f
You must remove the object which may emit ResourceWarning before
the end of the context manager.
"""
with
warnings
.
catch_warnings
(
record
=
True
)
as
warns
:
warnings
.
filterwarnings
(
'always'
,
category
=
ResourceWarning
)
yield
gc_collect
()
testcase
.
assertEqual
(
warns
,
[])
class
CleanImport
(
object
):
"""Context manager to force import to return a new module reference.
...
...
Lib/test/test_asyncio/test_subprocess.py
View file @
2feb6425
...
...
@@ -427,10 +427,9 @@ class SubprocessMixin:
create
=
asyncio
.
create_subprocess_exec
(
sys
.
executable
,
'-c'
,
'pass'
,
loop
=
self
.
loop
)
with
warnings
.
catch_warnings
(
record
=
True
)
as
warns
:
with
support
.
check_no_resource_warning
(
self
)
:
with
self
.
assertRaises
(
exc
):
self
.
loop
.
run_until_complete
(
create
)
self
.
assertEqual
(
warns
,
[])
if
sys
.
platform
!=
'win32'
:
...
...
Lib/test/test_io.py
View file @
2feb6425
...
...
@@ -681,18 +681,14 @@ class IOTest(unittest.TestCase):
f2
.
readline
()
def
test_nonbuffered_textio
(
self
):
with
warnings
.
catch_warnings
(
record
=
True
)
as
recorded
:
with
support
.
check_no_resource_warning
(
self
)
:
with
self
.
assertRaises
(
ValueError
):
self
.
open
(
support
.
TESTFN
,
'w'
,
buffering
=
0
)
support
.
gc_collect
()
self
.
assertEqual
(
recorded
,
[])
def
test_invalid_newline
(
self
):
with
warnings
.
catch_warnings
(
record
=
True
)
as
recorded
:
with
support
.
check_no_resource_warning
(
self
)
:
with
self
.
assertRaises
(
ValueError
):
self
.
open
(
support
.
TESTFN
,
'w'
,
newline
=
'invalid'
)
support
.
gc_collect
()
self
.
assertEqual
(
recorded
,
[])
class
CIOTest
(
IOTest
):
...
...
@@ -3366,10 +3362,8 @@ class MiscIOTest(unittest.TestCase):
# When using closefd=False, there's no warning
r
,
w
=
os
.
pipe
()
fds
+=
r
,
w
with
warnings
.
catch_warnings
(
record
=
True
)
as
recorded
:
with
support
.
check_no_resource_warning
(
self
)
:
open
(
r
,
*
args
,
closefd
=
False
,
**
kwargs
)
support
.
gc_collect
()
self
.
assertEqual
(
recorded
,
[])
def
test_warn_on_dealloc_fd
(
self
):
self
.
_check_warn_on_dealloc_fd
(
"rb"
,
buffering
=
0
)
...
...
Lib/test/test_xml_etree.py
View file @
2feb6425
...
...
@@ -569,14 +569,11 @@ class ElementTreeTest(unittest.TestCase):
self
.
assertFalse
(
f
.
closed
)
self
.
assertEqual
(
str
(
cm
.
exception
),
"unknown event 'bogus'"
)
with
warnings
.
catch_warnings
(
record
=
True
)
as
w
:
warnings
.
filterwarnings
(
"always"
,
category
=
ResourceWarning
)
with
support
.
check_no_resource_warning
(
self
):
with
self
.
assertRaises
(
ValueError
)
as
cm
:
iterparse
(
SIMPLE_XMLFILE
,
events
)
self
.
assertEqual
(
str
(
cm
.
exception
),
"unknown event 'bogus'"
)
del
cm
support
.
gc_collect
()
self
.
assertEqual
(
w
,
[])
source
=
io
.
BytesIO
(
b"<?xml version='1.0' encoding='iso-8859-1'?>
\
n
"
...
...
@@ -603,15 +600,12 @@ class ElementTreeTest(unittest.TestCase):
it
=
iterparse
(
TESTFN
)
action
,
elem
=
next
(
it
)
self
.
assertEqual
((
action
,
elem
.
tag
),
(
'end'
,
'document'
))
with
warnings
.
catch_warnings
(
record
=
True
)
as
w
:
warnings
.
filterwarnings
(
"always"
,
category
=
ResourceWarning
)
with
support
.
check_no_resource_warning
(
self
):
with
self
.
assertRaises
(
ET
.
ParseError
)
as
cm
:
next
(
it
)
self
.
assertEqual
(
str
(
cm
.
exception
),
'junk after document element: line 1, column 12'
)
del
cm
,
it
support
.
gc_collect
()
self
.
assertEqual
(
w
,
[])
def
test_writefile
(
self
):
elem
=
ET
.
Element
(
"tag"
)
...
...
Misc/NEWS
View file @
2feb6425
...
...
@@ -673,6 +673,9 @@ Documentation
Tests
-----
- Issue #26325: Added test.support.check_no_resource_warning() to check that
no ResourceWarning is emitted.
- Issue #25940: Changed test_ssl to use self-signed.pythontest.net. This
avoids relying on svn.python.org, which recently changed root certificate.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment