/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
1707.2.2 by Robert Collins
Start on bench_add, an add benchtest.
1
# Copyright (C) 2006 by 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
"""Benchmark test suite for bzr."""
18
1908.2.2 by John Arbash Meinel
Allow caching basic kernel-like trees
19
from bzrlib import (
20
    plugin,
21
    )
1773.4.1 by Martin Pool
Add pyflakes makefile target; fix many warnings
22
from bzrlib.tests.TestUtil import TestLoader
1714.1.4 by Robert Collins
Add new benchmarks for status and commit.
23
from bzrlib.tests.blackbox import ExternalBase
24
1841.1.1 by John Arbash Meinel
Allow plugins to provide benchmarks just like they do tests
25
1714.1.4 by Robert Collins
Add new benchmarks for status and commit.
26
class Benchmark(ExternalBase):
27
1908.2.2 by John Arbash Meinel
Allow caching basic kernel-like trees
28
    def make_kernel_like_tree(self, url=None, root='.',
1908.2.11 by John Arbash Meinel
Change caching logic. Don't cache at all without --cache-dir being supplied
29
                              link_working=False):
1725.2.5 by Robert Collins
Bugfix create_branch_convenience at the root of a file system to not loop
30
        """Setup a temporary tree roughly like a kernel tree.
31
        
32
        :param url: Creat the kernel like tree as a lightweight checkout
33
        of a new branch created at url.
1908.2.11 by John Arbash Meinel
Change caching logic. Don't cache at all without --cache-dir being supplied
34
        :param link_working: instead of creating a new copy of all files
1908.2.2 by John Arbash Meinel
Allow caching basic kernel-like trees
35
            just hardlink the working tree. Tests must request this, because
36
            they must break links if they want to change the files
1725.2.5 by Robert Collins
Bugfix create_branch_convenience at the root of a file system to not loop
37
        """
1908.2.16 by John Arbash Meinel
Move all the new TreeCreator classes into separate files.
38
        from bzrlib.benchmarks.tree_creator.kernel_like import (
39
            KernelLikeTreeCreator,
40
            )
1908.2.14 by John Arbash Meinel
Hook the bench_bench.py tests up for the new classes
41
        creator = KernelLikeTreeCreator(self, link_working=link_working,
42
                                        url=url)
43
        return creator.create(root=root)
1908.2.5 by John Arbash Meinel
Updated bench_bench tests to test exactly what we really want to test
44
1908.2.6 by John Arbash Meinel
Allow the many_merged and many_commit trees to be cached
45
    def make_many_commit_tree(self, directory_name='.',
46
                              hardlink=False):
47
        """Create a tree with many commits.
48
        
49
        No file changes are included. Not hardlinking the working tree, 
50
        because there are no working tree files.
1756.2.19 by Aaron Bentley
Add benchmarks for merged trees
51
        """
1908.2.16 by John Arbash Meinel
Move all the new TreeCreator classes into separate files.
52
        from bzrlib.benchmarks.tree_creator.simple_many_commit import (
53
            SimpleManyCommitTreeCreator,
54
            )
1908.2.15 by John Arbash Meinel
Switching many_merge and heavy_merge to new tree creator classes
55
        creator = SimpleManyCommitTreeCreator(self, link_bzr=hardlink)
56
        return creator.create(root=directory_name)
1908.2.6 by John Arbash Meinel
Allow the many_merged and many_commit trees to be cached
57
58
    def make_heavily_merged_tree(self, directory_name='.',
59
                                 hardlink=False):
60
        """Create a tree in which almost every commit is a merge.
61
       
62
        No file changes are included.  This produces two trees, 
63
        one of which is returned.  Except for the first commit, every
64
        commit in its revision-history is a merge another commit in the other
65
        tree.  Not hardlinking the working tree, because there are no working 
66
        tree files.
67
        """
1908.2.16 by John Arbash Meinel
Move all the new TreeCreator classes into separate files.
68
        from bzrlib.benchmarks.tree_creator.heavily_merged import (
69
            HeavilyMergedTreeCreator,
70
            )
1908.2.15 by John Arbash Meinel
Switching many_merge and heavy_merge to new tree creator classes
71
        creator = HeavilyMergedTreeCreator(self, link_bzr=hardlink)
72
        return creator.create(root=directory_name)
1756.2.19 by Aaron Bentley
Add benchmarks for merged trees
73
1707.2.2 by Robert Collins
Start on bench_add, an add benchtest.
74
75
def test_suite():
76
    """Build and return a TestSuite which contains benchmark tests only."""
77
    testmod_names = [ \
78
                   'bzrlib.benchmarks.bench_add',
1755.2.1 by Robert Collins
Add a benchmark for make_kernel_like_tree.
79
                   'bzrlib.benchmarks.bench_bench',
1714.1.4 by Robert Collins
Add new benchmarks for status and commit.
80
                   'bzrlib.benchmarks.bench_checkout',
1714.1.5 by Robert Collins
Add commit benchmark.
81
                   'bzrlib.benchmarks.bench_commit',
1757.2.10 by Robert Collins
Give all inventory entries __slots__ that are useful with the current codebase.
82
                   'bzrlib.benchmarks.bench_inventory',
1756.1.7 by Aaron Bentley
Merge bzr.dev
83
                   'bzrlib.benchmarks.bench_log',
1756.1.2 by Aaron Bentley
Show logs using get_revisions
84
                   'bzrlib.benchmarks.bench_osutils',
1752.1.2 by Aaron Bentley
Benchmark the rocks command
85
                   'bzrlib.benchmarks.bench_rocks',
1714.1.4 by Robert Collins
Add new benchmarks for status and commit.
86
                   'bzrlib.benchmarks.bench_status',
1534.10.33 by Aaron Bentley
Add canonicalize_path benchmark
87
                   'bzrlib.benchmarks.bench_transform',
1732.1.11 by John Arbash Meinel
Trying multiple things to get WorkingTree.list_files time down
88
                   'bzrlib.benchmarks.bench_workingtree',
1707.2.2 by Robert Collins
Start on bench_add, an add benchtest.
89
                   ]
1841.1.1 by John Arbash Meinel
Allow plugins to provide benchmarks just like they do tests
90
    suite = TestLoader().loadTestsFromModuleNames(testmod_names) 
91
92
    # Load any benchmarks from plugins
1711.2.78 by John Arbash Meinel
Cleanup the imports in bzrlib.benchmark
93
    for name, module in plugin.all_plugins().items():
94
        if getattr(module, 'bench_suite', None) is not None:
95
            suite.addTest(module.bench_suite())
1841.1.1 by John Arbash Meinel
Allow plugins to provide benchmarks just like they do tests
96
97
    return suite