/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
7476.2.1 by Jelmer Vernooij
Default to running Python 3.
1
#!/usr/bin/env python3
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
2
import random
3
import os
4
import time
5
import sys
6
import optparse
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
7
from breezy import (
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
8
    branch,
9
    commands,
10
    graph,
7291.1.1 by Jelmer Vernooij
Avoid using time.clock, which is going away in python 3.8.
11
    osutils,
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
12
    ui,
13
    trace,
14
    _known_graph_py,
15
    _known_graph_pyx,
16
    )
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
17
from breezy.ui import text
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
18
19
p = optparse.OptionParser()
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
20
p.add_option('--quick', default=False, action='store_true')
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
21
p.add_option('--max-combinations', default=500, type=int)
22
p.add_option('--lsprof', default=None, type=str)
23
opts, args = p.parse_args(sys.argv[1:])
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
24
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
25
trace.enable_default_logging()
26
ui.ui_factory = text.TextUIFactory()
27
7291.1.1 by Jelmer Vernooij
Avoid using time.clock, which is going away in python 3.8.
28
begin = osutils.perf_counter()
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
29
if len(args) >= 1:
30
    b = branch.Branch.open(args[0])
31
else:
32
    b = branch.Branch.open('.')
6754.8.4 by Jelmer Vernooij
Use new context stuff.
33
with b.lock_read():
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
34
    g = b.repository.get_graph()
35
    parent_map = dict(p for p in g.iter_ancestry([b.last_revision()])
7143.16.9 by Jelmer Vernooij
Fix E127
36
                      if p[1] is not None)
7291.1.1 by Jelmer Vernooij
Avoid using time.clock, which is going away in python 3.8.
37
end = osutils.perf_counter()
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
38
6619.3.3 by Jelmer Vernooij
Apply 2to3 print fix.
39
print('Found %d nodes, loaded in %.3fs' % (len(parent_map), end - begin))
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
40
41
def all_heads_comp(g, combinations):
42
    h = []
6861.4.1 by Jelmer Vernooij
Make progress bars context managers.
43
    with ui.ui_factory.nested_progress_bar() as pb:
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
44
        for idx, combo in enumerate(combinations):
45
            if idx & 0x1f == 0:
46
                pb.update('proc', idx, len(combinations))
47
            h.append(g.heads(combo))
48
    return h
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
49
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
50
combinations = []
51
# parents = parent_map.keys()
52
# for p1 in parents:
53
#     for p2 in random.sample(parents, 10):
54
#         combinations.append((p1, p2))
55
# Times for random sampling of 10x1150 of bzrtools
56
#   Graph        KnownGraph
57
#   96.1s   vs   25.7s  :)
58
# Times for 500 'merge parents' from bzr.dev
59
#   25.6s   vs   45.0s  :(
60
61
for revision_id, parent_ids in parent_map.iteritems():
62
    if parent_ids is not None and len(parent_ids) > 1:
63
        combinations.append(parent_ids)
4371.4.24 by John Arbash Meinel
Make a note of the 'worst case' for heads.
64
# The largest portion of the graph that has to be walked for a heads() check
65
# combinations = [('john@arbash-meinel.com-20090312021943-tu6tcog48aiujx4s',
66
#                  'john@arbash-meinel.com-20090312130552-09xa2xsitf6rilzc')]
4371.3.38 by John Arbash Meinel
Add a failing test for handling nodes that are in the same linear chain.
67
if opts.max_combinations > 0 and len(combinations) > opts.max_combinations:
68
    combinations = random.sample(combinations, opts.max_combinations)
69
6619.3.3 by Jelmer Vernooij
Apply 2to3 print fix.
70
print('      %d combinations' % (len(combinations),))
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
71
72
def combi_graph(graph_klass, comb):
73
    # DEBUG
74
    graph._counters[1] = 0
75
    graph._counters[2] = 0
76
7291.1.1 by Jelmer Vernooij
Avoid using time.clock, which is going away in python 3.8.
77
    begin = osutils.perf_counter()
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
78
    g = graph_klass(parent_map)
79
    if opts.lsprof is not None:
80
        heads = commands.apply_lsprofiled(opts.lsprof, all_heads_comp, g, comb)
81
    else:
82
        heads = all_heads_comp(g, comb)
7291.1.1 by Jelmer Vernooij
Avoid using time.clock, which is going away in python 3.8.
83
    end = osutils.perf_counter()
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
84
    return dict(elapsed=(end - begin), graph=g, heads=heads)
85
86
def report(name, g):
6619.3.3 by Jelmer Vernooij
Apply 2to3 print fix.
87
    print('%s: %.3fs' % (name, g['elapsed']))
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
88
    counters_used = False
89
    for c in graph._counters:
90
        if c:
91
            counters_used = True
92
    if counters_used:
6619.3.3 by Jelmer Vernooij
Apply 2to3 print fix.
93
        print('  %s' % (graph._counters,))
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
94
95
known_python = combi_graph(_known_graph_py.KnownGraph, combinations)
96
report('Known', known_python)
97
98
known_pyrex = combi_graph(_known_graph_pyx.KnownGraph, combinations)
99
report('Known (pyx)', known_pyrex)
100
101
def _simple_graph(parent_map):
102
    return graph.Graph(graph.DictParentsProvider(parent_map))
103
104
if opts.quick:
105
    if known_python['heads'] != known_pyrex['heads']:
106
        import pdb; pdb.set_trace()
6619.3.3 by Jelmer Vernooij
Apply 2to3 print fix.
107
    print('ratio: %.1f:1 faster' % (
108
        known_python['elapsed'] / known_pyrex['elapsed'],))
4371.4.11 by Vincent Ladeuil
Cleanup tools/time_graph.py and add a --quick option.
109
else:
110
    orig = combi_graph(_simple_graph, combinations)
111
    report('Orig', orig)
112
113
    if orig['heads'] != known_pyrex['heads']:
114
        import pdb; pdb.set_trace()
115
6619.3.3 by Jelmer Vernooij
Apply 2to3 print fix.
116
    print('ratio: %.1f:1 faster' % (
117
        orig['elapsed'] / known_pyrex['elapsed'],))