Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
C
code_block_timer
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
OpenEdx
code_block_timer
Commits
efd19daa
Commit
efd19daa
authored
Feb 15, 2015
by
John Eskew
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'egafford-decorator_and_mock_test'
parents
fc5e63a4
35647b98
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
43 additions
and
8 deletions
+43
-8
.gitignore
+1
-0
code_block_timer/__init__.py
+14
-2
code_block_timer/storage.py
+2
-3
code_block_timer/tests/test_timer.py
+26
-3
No files found.
.gitignore
View file @
efd19daa
*.pyc
code_block_timer/tests/tmp_db_*
code_block_timer/__init__.py
View file @
efd19daa
...
...
@@ -12,9 +12,11 @@
# See the License for the specific language governing permissions and
# limitations under the License.
import
functools
import
threading
from
timeit
import
default_timer
from
.storage
import
TimingDataStorage
import
storage
class
Globals
(
threading
.
local
):
...
...
@@ -38,7 +40,7 @@ class CodeBlockTimer(object):
self
.
block_desc
=
block_desc
self
.
verbose
=
False
if
'verbose'
not
in
kwargs
else
kwargs
[
'verbose'
]
self
.
timer
=
default_timer
self
.
data_store
=
TimingDataStorage
(
**
kwargs
)
self
.
data_store
=
storage
.
TimingDataStorage
(
**
kwargs
)
def
__enter__
(
self
):
if
len
(
_m
.
nest_stack
)
==
0
:
...
...
@@ -65,3 +67,13 @@ class CodeBlockTimer(object):
print
'{}: elapsed time: {} ms'
.
format
(
self
.
block_desc
,
self
.
elapsed
)
def
code_block_timer
(
block_desc
,
**
cbt_kwargs
):
def
outer
(
func
):
@functools.wraps
(
func
)
def
inner
(
*
args
,
**
kwargs
):
with
CodeBlockTimer
(
block_desc
,
**
cbt_kwargs
):
return
func
(
*
args
,
**
kwargs
)
return
inner
return
outer
code_block_timer/storage.py
View file @
efd19daa
...
...
@@ -15,16 +15,15 @@
import
os
import
sqlite3
from
path
import
path
MODULE_DIR
=
path
(
__file__
)
.
dirname
(
)
MODULE_DIR
=
os
.
path
.
dirname
(
__file__
)
class
TimingDataStorage
(
object
):
SCHEMA_NAME
=
'schema.sql'
SCHEMA_PATH
=
MODULE_DIR
/
SCHEMA_NAME
SCHEMA_PATH
=
'
%
s/
%
s'
%
(
MODULE_DIR
,
SCHEMA_NAME
)
DEFAULT_DB_NAME
=
'block_times.db'
def
__init__
(
self
,
**
kwargs
):
...
...
code_block_timer/tests/test_timer.py
View file @
efd19daa
import
mock
import
os
import
unittest
import
random
import
sqlite3
from
code_block_timer
import
CodeBlockTimer
,
_m
from
code_block_timer
import
CodeBlockTimer
,
code_block_timer
,
_m
class
TestCodeBlockTimer
(
unittest
.
TestCase
):
...
...
@@ -34,9 +35,31 @@ class TestCodeBlockTimer(unittest.TestCase):
z
+=
i
self
.
_verifyEvents
(
run_id
,
[
'test'
,
]
+
[
"test:{}"
.
format
(
x
)
for
x
in
iterations
])
@mock.patch
(
'code_block_timer.storage.TimingDataStorage'
)
def
test_decorator
(
self
,
mock_class
):
store
=
mock
.
Mock
()
mock_class
.
return_value
=
store
store
.
run_id
.
return_value
=
45
@code_block_timer
(
'decorator_test'
,
db_name
=
self
.
db_name
)
def
wrapped_thing
(
*
args
,
**
kwargs
):
self
.
assertEquals
(
args
,
(
'an_arg'
,))
self
.
assertEquals
(
kwargs
,
{
'a_dict'
:
{}})
kwargs
[
'a_dict'
]
.
update
(
entered
=
True
)
test_dict
=
{}
run_id
=
wrapped_thing
(
'an_arg'
,
a_dict
=
test_dict
)
mock_class
.
assert_called_once_with
(
db_name
=
self
.
db_name
)
self
.
assertTrue
(
test_dict
[
'entered'
])
store
.
store
.
assert_called_with
(
45
,
'decorator_test'
,
mock
.
ANY
)
def
tearDown
(
self
):
# Destroy the sqlite DB.
os
.
remove
(
self
.
db_name
)
try
:
# Destroy the sqlite DB.
os
.
remove
(
self
.
db_name
)
except
:
pass
if
__name__
==
'__main__'
:
unittest
.
main
()
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