/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
2493.2.3 by Ian Clatworthy
changes requested in jameinel's review incorporated
1
# Copyright (C) 2005, 2006 Canonical Ltd
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
"""Tests for profiling data collection."""
18
19
20
import cPickle
21
import os
22
23
import bzrlib
2493.2.6 by Aaron Bentley
Make LSProf into a Feature required by the appropriate tests
24
from bzrlib import tests
25
26
27
class LSProf(tests.Feature):
28
29
    def available(self):
30
        try:
31
            from bzrlib import lsprof
32
        except ImportError:
33
            return False
34
        else:
35
            return True
2493.2.3 by Ian Clatworthy
changes requested in jameinel's review incorporated
36
37
2493.2.5 by Ian Clatworthy
explicit format saving test
38
_TXT_HEADER = "   CallCount    Recursive    Total(ms)   " + \
39
    "Inline(ms) module:lineno(function)\n"
40
41
2493.2.3 by Ian Clatworthy
changes requested in jameinel's review incorporated
42
def _junk_callable():
43
    "A simple routine to profile."
44
    result = sorted(['abc', 'def', 'ghi'])
45
46
47
def _collect_stats():
48
    "Collect and return some dummy profile data."
2493.2.6 by Aaron Bentley
Make LSProf into a Feature required by the appropriate tests
49
    from bzrlib.lsprof import profile
2493.2.3 by Ian Clatworthy
changes requested in jameinel's review incorporated
50
    ret, stats = profile(_junk_callable)
51
    return stats
52
53
2493.2.6 by Aaron Bentley
Make LSProf into a Feature required by the appropriate tests
54
class TestStatsSave(tests.TestCaseInTempDir):
2493.2.3 by Ian Clatworthy
changes requested in jameinel's review incorporated
55
56
    def setUp(self):
2493.2.11 by Aaron Bentley
Compensate for brittle requireFeature behavior
57
        self.requireFeature(LSProf())
2493.2.6 by Aaron Bentley
Make LSProf into a Feature required by the appropriate tests
58
        super(tests.TestCaseInTempDir, self).setUp()
2493.2.3 by Ian Clatworthy
changes requested in jameinel's review incorporated
59
        self.stats = _collect_stats()
60
61
    def _tempfile(self, ext):
62
        dir = self.test_dir
63
        return os.path.join(dir, "tmp_profile_data." + ext)
64
65
    def test_stats_save_to_txt(self):
66
        f = self._tempfile("txt")
67
        self.stats.save(f)
68
        lines = open(f).readlines()
2493.2.5 by Ian Clatworthy
explicit format saving test
69
        self.assertEqual(lines[0], _TXT_HEADER)
2493.2.3 by Ian Clatworthy
changes requested in jameinel's review incorporated
70
71
    def test_stats_save_to_callgrind(self):
72
        f = self._tempfile("callgrind")
73
        self.stats.save(f)
74
        lines = open(f).readlines()
2493.2.5 by Ian Clatworthy
explicit format saving test
75
        self.assertEqual(lines[0], "events: Ticks\n")
76
        # Test explicit format nommination
77
        f2 = self._tempfile("txt")
78
        self.stats.save(f2, format="callgrind")
79
        lines2 = open(f2).readlines()
80
        self.assertEqual(lines2[0], "events: Ticks\n")
2493.2.3 by Ian Clatworthy
changes requested in jameinel's review incorporated
81
82
    def test_stats_save_to_pickle(self):
83
        f = self._tempfile("pkl")
84
        self.stats.save(f)
85
        data1 = cPickle.load(open(f))
86
        self.assertEqual(type(data1), bzrlib.lsprof.Stats)