Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gevent
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
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gevent
Commits
32426779
Commit
32426779
authored
Mar 15, 2011
by
Denis Bilenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
tests: better implementation of timeouts (does not rely on setUp and tearDown)
parent
576f8f56
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
35 additions
and
28 deletions
+35
-28
greentest/greentest.py
greentest/greentest.py
+33
-27
greentest/helper.py
greentest/helper.py
+2
-1
No files found.
greentest/greentest.py
View file @
32426779
...
@@ -46,7 +46,19 @@ else:
...
@@ -46,7 +46,19 @@ else:
gettotalrefcount
=
getattr
(
sys
,
'gettotalrefcount'
,
None
)
gettotalrefcount
=
getattr
(
sys
,
'gettotalrefcount'
,
None
)
def
wrap
(
method
):
def
wrap_timeout
(
timeout
,
method
):
if
timeout
is
None
:
return
method
@
wraps
(
method
)
def
wrapped
(
self
,
*
args
,
**
kwargs
):
with
gevent
.
Timeout
(
timeout
,
'test timed out'
):
return
method
(
self
,
*
args
,
**
kwargs
)
return
wrapped
def
wrap_refcount
(
method
):
if
gettotalrefcount
is
None
:
return
method
@
wraps
(
method
)
@
wraps
(
method
)
def
wrapped
(
self
,
*
args
,
**
kwargs
):
def
wrapped
(
self
,
*
args
,
**
kwargs
):
import
gc
import
gc
...
@@ -74,25 +86,37 @@ def wrap(method):
...
@@ -74,25 +86,37 @@ def wrap(method):
return
wrapped
return
wrapped
class
CheckRefcountMetaClass
(
type
):
class
TestCaseMetaClass
(
type
):
# wrap each test method with
# a) timeout check
# b) totalrefcount check
def
__new__
(
meta
,
classname
,
bases
,
classDict
):
def
__new__
(
meta
,
classname
,
bases
,
classDict
):
if
classDict
.
get
(
'check_totalrefcount'
,
True
):
timeout
=
classDict
.
get
(
'__timeout__'
,
'NONE'
)
for
key
,
value
in
classDict
.
items
():
if
timeout
==
'NONE'
:
if
(
key
.
startswith
(
'test_'
)
or
key
==
'test'
)
and
callable
(
value
):
timeout
=
getattr
(
bases
[
0
],
'__timeout__'
,
None
)
classDict
.
pop
(
key
)
check_totalrefcount
=
classDict
.
get
(
'check_totalrefcount'
)
classDict
[
key
]
=
wrap
(
value
)
if
check_totalrefcount
is
None
:
check_totalrefcount
=
getattr
(
bases
[
0
],
'check_totalrefcount'
,
True
)
for
key
,
value
in
classDict
.
items
():
if
(
key
.
startswith
(
'test_'
)
or
key
==
'test'
)
and
callable
(
value
):
classDict
.
pop
(
key
)
value
=
wrap_timeout
(
timeout
,
value
)
if
check_totalrefcount
:
value
=
wrap_refcount
(
value
)
classDict
[
key
]
=
value
return
type
.
__new__
(
meta
,
classname
,
bases
,
classDict
)
return
type
.
__new__
(
meta
,
classname
,
bases
,
classDict
)
class
TestCase
0
(
BaseTestCase
):
class
TestCase
(
BaseTestCase
):
__metaclass__
=
TestCaseMetaClass
__timeout__
=
1
__timeout__
=
1
switch_expected
=
'default'
switch_expected
=
'default'
_switch_count
=
None
_switch_count
=
None
check_totalrefcount
=
True
def
__init__
(
self
,
*
args
,
**
kwargs
):
def
__init__
(
self
,
*
args
,
**
kwargs
):
BaseTestCase
.
__init__
(
self
,
*
args
,
**
kwargs
)
BaseTestCase
.
__init__
(
self
,
*
args
,
**
kwargs
)
self
.
_timer
=
None
self
.
_hub
=
gevent
.
hub
.
get_hub
()
self
.
_hub
=
gevent
.
hub
.
get_hub
()
self
.
_switch_count
=
None
self
.
_switch_count
=
None
...
@@ -105,7 +129,6 @@ class TestCase0(BaseTestCase):
...
@@ -105,7 +129,6 @@ class TestCase0(BaseTestCase):
gevent
.
sleep
(
0
)
# switch at least once to setup signal handlers
gevent
.
sleep
(
0
)
# switch at least once to setup signal handlers
if
hasattr
(
self
.
_hub
,
'switch_count'
):
if
hasattr
(
self
.
_hub
,
'switch_count'
):
self
.
_switch_count
=
self
.
_hub
.
switch_count
self
.
_switch_count
=
self
.
_hub
.
switch_count
self
.
_timer
=
gevent
.
Timeout
.
start_new
(
self
.
__timeout__
,
RuntimeError
(
'test is taking too long'
))
def
tearDown
(
self
):
def
tearDown
(
self
):
if
hasattr
(
self
,
'cleanup'
):
if
hasattr
(
self
,
'cleanup'
):
...
@@ -117,23 +140,6 @@ class TestCase0(BaseTestCase):
...
@@ -117,23 +140,6 @@ class TestCase0(BaseTestCase):
sys
.
__stderr__
.
write
(
self
.
stderr
)
sys
.
__stderr__
.
write
(
self
.
stderr
)
except
:
except
:
traceback
.
print_exc
()
traceback
.
print_exc
()
if
getattr
(
self
,
'_timer'
,
None
)
is
not
None
:
self
.
_timer
.
cancel
()
self
.
_timer
=
None
if
self
.
_switch_count
is
not
None
and
hasattr
(
self
.
_hub
,
'switch_count'
):
msg
=
''
if
self
.
_hub
.
switch_count
<
self
.
_switch_count
:
msg
=
'hub.switch_count decreased?
\
n
'
elif
self
.
_hub
.
switch_count
==
self
.
_switch_count
:
if
self
.
switch_expected
:
msg
=
'%s.%s did not switch
\
n
'
%
(
type
(
self
).
__name__
,
self
.
testname
)
elif
self
.
_hub
.
switch_count
>
self
.
_switch_count
:
if
not
self
.
switch_expected
:
msg
=
'%s.%s switched but expected not to
\
n
'
%
(
type
(
self
).
__name__
,
self
.
testname
)
if
msg
:
print
>>
sys
.
stderr
,
'WARNING: '
+
msg
else
:
sys
.
stderr
.
write
(
'WARNING: %s.setUp does not call base class setUp
\
n
'
%
(
type
(
self
).
__name__
,
))
@
property
@
property
def
testname
(
self
):
def
testname
(
self
):
...
...
greentest/helper.py
View file @
32426779
...
@@ -24,7 +24,8 @@ def patch_all(timeout=None):
...
@@ -24,7 +24,8 @@ def patch_all(timeout=None):
monkey
.
patch_all
(
aggressive
=
True
)
monkey
.
patch_all
(
aggressive
=
True
)
import
unittest
import
unittest
import
greentest
import
greentest
unittest
.
TestCase
=
greentest
.
TestCase0
unittest
.
TestCase
=
greentest
.
TestCase
unittest
.
TestCase
.
check_totalrefcount
=
False
if
timeout
is
not
None
:
if
timeout
is
not
None
:
unittest
.
TestCase
.
__timeout__
=
timeout
unittest
.
TestCase
.
__timeout__
=
timeout
...
...
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