summaryrefslogtreecommitdiff
path: root/speed-test
blob: 13a99f4b30574c399b7cc345d7afd2b625603cae (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#!/bin/sh
#
# Copyright 2013  Lars Wirzenius
# 
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# 
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
# 
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
#
# =*= License: GPL-3+ =*=

set -e

measure() {
python -m timeit \
    -s 'import logging, tracing' \
    -s 'logging.basicConfig(filename="/dev/null")' \
    -s "$1" \
    -s '
class Foo(object):
    def foo(self):
        tracing.trace("%s", "bar")
f = Foo()
' \
    'f.foo()'
}

echo tracing: Without patterns
measure "pass"

echo tracing: With unmatching pattern
measure 'tracing.trace_add_pattern("yikes")'

echo tracing: With matching pattern
measure 'tracing.trace_add_pattern("timeit-src")'


measure_logging() {
python -m timeit \
    -s 'import logging' \
    -s 'logging.basicConfig(filename="/dev/null")' \
    -s "$1" \
    -s '
class Foo(object):
    def foo(self):
        logging.debug("%s", "bar")
f = Foo()
' \
    'f.foo()'
}

echo logging: With debug messages
measure_logging pass

echo logging: Without debug messages
measure_logging \
    'logging.basicConfig(filename="/dev/null", level=logging.INFO)'