/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/benchmarks/bench_bundle.py

  • Committer: Carl Friedrich Bolz
  • Date: 2006-08-10 11:03:53 UTC
  • mto: (1908.8.4 bzr.bundle_bench)
  • mto: This revision was merged to the branch mainline in revision 2068.
  • Revision ID: cfbolz@gmx.de-20060810110353-0bad43599b30e74c
Add benchmark for applying a benchmark and fix some formatting/typos.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
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 version 2 as published by
 
5
# the Free Software Foundation.
 
6
#
 
7
# This program is distributed in the hope that it will be useful,
 
8
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
9
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
10
# GNU General Public License for more details.
 
11
#
 
12
# You should have received a copy of the GNU General Public License
 
13
# along with this program; if not, write to the Free Software
 
14
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
 
 
16
"""Tests for bzr bundle performance."""
 
17
 
 
18
from bzrlib.benchmarks import Benchmark
 
19
 
 
20
 
 
21
class BundleBenchmark(Benchmark):
 
22
    """
 
23
    The bundle tests should (also) be done at a lower level with
 
24
    direct call to the bzrlib."""
 
25
    
 
26
    def test_create_bundle_known_kernel_like_tree(self):
 
27
        """
 
28
        Create a bundle for a kernel sized tree with no ignored, unknowns,
 
29
        or added and one commit.""" 
 
30
        self.make_kernel_like_tree()
 
31
        self.run_bzr('add')
 
32
        self.run_bzr('commit', '-m', 'initial import')
 
33
        self.time(self.run_bzr, 'bundle', '--revision', '..-1')
 
34
 
 
35
    def test_create_bundle_many_commit_tree (self):
 
36
        """
 
37
        Create a bundle for a tree with many commits but no changes.""" 
 
38
        self.make_many_commit_tree()
 
39
        self.time(self.run_bzr, 'bundle', '--revision', '..-1')
 
40
 
 
41
    def test_create_bundle_heavily_merged_tree(self):
 
42
        """
 
43
        Create a bundle for a heavily merged tree.""" 
 
44
        self.make_heavily_merged_tree()
 
45
        self.time(self.run_bzr, 'bundle', '--revision', '..-1')
 
46
 
 
47
    def test_apply_bundle_known_kernel_like_tree(self):
 
48
        """
 
49
        Create a bundle for a kernel sized tree with no ignored, unknowns,
 
50
        or added and one commit.""" 
 
51
        self.make_kernel_like_tree()
 
52
        self.run_bzr('add')
 
53
        self.run_bzr('commit', '-m', 'initial import')
 
54
        self.run_bzr('branch', '.', '../branch_a')
 
55
        self.run_bzr('bundle', '--revision', '..-1')
 
56
        f = file('../bundle', 'wb')
 
57
        try:
 
58
            f.write(self.run_bzr('bundle', '--revision', '..-1')[0])
 
59
        finally:
 
60
            f.close()
 
61
        os.chdir('../branch_a')
 
62
        self.time(self.run_bzr, 'merge', '../bundle')
 
63