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'],)) |