summaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2019-02-20 17:07:56 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2019-03-26 15:38:28 +0000
commitee12af6556b05a33b0c0bdb62994a13057c6a813 (patch)
tree8157ac6eb3efd7642b63e240a6c509d1613dbe7d /scripts
parent622e5728da070939c5a1407735f2f0c71337b969 (diff)
downloadpoky-ee12af6556b05a33b0c0bdb62994a13057c6a813.tar.gz
oe-build-perf-report/gitarchive: Move common useful functions to library
These functions can be reused by the resulttool code so move to the common function library for this purpose. (From OE-Core rev: c66f848938c04e133259c5b6903dc592866ab385) (From OE-Core rev: 94a3ca85d30fc957f8f01a216a75342be49f9143) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/oe-build-perf-report90
1 files changed, 10 insertions, 80 deletions
diff --git a/scripts/oe-build-perf-report b/scripts/oe-build-perf-report
index 1e0b55100a..cf1c947aee 100755
--- a/scripts/oe-build-perf-report
+++ b/scripts/oe-build-perf-report
@@ -37,58 +37,18 @@ from buildstats import BuildStats, diff_buildstats, BSVerDiff
37scriptpath.add_oe_lib_path() 37scriptpath.add_oe_lib_path()
38 38
39from oeqa.utils.git import GitRepo, GitError 39from oeqa.utils.git import GitRepo, GitError
40import oeqa.utils.gitarchive as gitarchive
40 41
41 42
42# Setup logging 43# Setup logging
43logging.basicConfig(level=logging.INFO, format="%(levelname)s: %(message)s") 44logging.basicConfig(level=logging.INFO, format="%(levelname)s: %(message)s")
44log = logging.getLogger('oe-build-perf-report') 45log = logging.getLogger('oe-build-perf-report')
45 46
46
47# Container class for tester revisions
48TestedRev = namedtuple('TestedRev', 'commit commit_number tags')
49
50
51def get_test_runs(repo, tag_name, **kwargs):
52 """Get a sorted list of test runs, matching given pattern"""
53 # First, get field names from the tag name pattern
54 field_names = [m.group(1) for m in re.finditer(r'{(\w+)}', tag_name)]
55 undef_fields = [f for f in field_names if f not in kwargs.keys()]
56
57 # Fields for formatting tag name pattern
58 str_fields = dict([(f, '*') for f in field_names])
59 str_fields.update(kwargs)
60
61 # Get a list of all matching tags
62 tag_pattern = tag_name.format(**str_fields)
63 tags = repo.run_cmd(['tag', '-l', tag_pattern]).splitlines()
64 log.debug("Found %d tags matching pattern '%s'", len(tags), tag_pattern)
65
66 # Parse undefined fields from tag names
67 str_fields = dict([(f, r'(?P<{}>[\w\-.()]+)'.format(f)) for f in field_names])
68 str_fields['branch'] = r'(?P<branch>[\w\-.()/]+)'
69 str_fields['commit'] = '(?P<commit>[0-9a-f]{7,40})'
70 str_fields['commit_number'] = '(?P<commit_number>[0-9]{1,7})'
71 str_fields['tag_number'] = '(?P<tag_number>[0-9]{1,5})'
72 # escape parenthesis in fields in order to not messa up the regexp
73 fixed_fields = dict([(k, v.replace('(', r'\(').replace(')', r'\)')) for k, v in kwargs.items()])
74 str_fields.update(fixed_fields)
75 tag_re = re.compile(tag_name.format(**str_fields))
76
77 # Parse fields from tags
78 revs = []
79 for tag in tags:
80 m = tag_re.match(tag)
81 groups = m.groupdict()
82 revs.append([groups[f] for f in undef_fields] + [tag])
83
84 # Return field names and a sorted list of revs
85 return undef_fields, sorted(revs)
86
87def list_test_revs(repo, tag_name, verbosity, **kwargs): 47def list_test_revs(repo, tag_name, verbosity, **kwargs):
88 """Get list of all tested revisions""" 48 """Get list of all tested revisions"""
89 valid_kwargs = dict([(k, v) for k, v in kwargs.items() if v is not None]) 49 valid_kwargs = dict([(k, v) for k, v in kwargs.items() if v is not None])
90 50
91 fields, revs = get_test_runs(repo, tag_name, **valid_kwargs) 51 fields, revs = gitarchive.get_test_runs(log, repo, tag_name, **valid_kwargs)
92 ignore_fields = ['tag_number'] 52 ignore_fields = ['tag_number']
93 if verbosity < 2: 53 if verbosity < 2:
94 extra_fields = ['COMMITS', 'TEST RUNS'] 54 extra_fields = ['COMMITS', 'TEST RUNS']
@@ -133,36 +93,6 @@ def list_test_revs(repo, tag_name, verbosity, **kwargs):
133 93
134 print_table(rows) 94 print_table(rows)
135 95
136def get_test_revs(repo, tag_name, **kwargs):
137 """Get list of all tested revisions"""
138 fields, runs = get_test_runs(repo, tag_name, **kwargs)
139
140 revs = {}
141 commit_i = fields.index('commit')
142 commit_num_i = fields.index('commit_number')
143 for run in runs:
144 commit = run[commit_i]
145 commit_num = run[commit_num_i]
146 tag = run[-1]
147 if not commit in revs:
148 revs[commit] = TestedRev(commit, commit_num, [tag])
149 else:
150 assert commit_num == revs[commit].commit_number, "Commit numbers do not match"
151 revs[commit].tags.append(tag)
152
153 # Return in sorted table
154 revs = sorted(revs.values(), key=attrgetter('commit_number'))
155 log.debug("Found %d tested revisions:\n %s", len(revs),
156 "\n ".join(['{} ({})'.format(rev.commit_number, rev.commit) for rev in revs]))
157 return revs
158
159def rev_find(revs, attr, val):
160 """Search from a list of TestedRev"""
161 for i, rev in enumerate(revs):
162 if getattr(rev, attr) == val:
163 return i
164 raise ValueError("Unable to find '{}' value '{}'".format(attr, val))
165
166def is_xml_format(repo, commit): 96def is_xml_format(repo, commit):
167 """Check if the commit contains xml (or json) data""" 97 """Check if the commit contains xml (or json) data"""
168 if repo.rev_parse(commit + ':results.xml'): 98 if repo.rev_parse(commit + ':results.xml'):
@@ -576,11 +506,11 @@ def main(argv=None):
576 if not args.hostname: 506 if not args.hostname:
577 auto_args(repo, args) 507 auto_args(repo, args)
578 508
579 revs = get_test_revs(repo, args.tag_name, hostname=args.hostname, 509 revs = gitarchive.get_test_revs(log, repo, args.tag_name, hostname=args.hostname,
580 branch=args.branch, machine=args.machine) 510 branch=args.branch, machine=args.machine)
581 if args.branch2: 511 if args.branch2:
582 revs2 = get_test_revs(repo, args.tag_name, hostname=args.hostname, 512 revs2 = gitarchive.get_test_revs(log, repo, args.tag_name, hostname=args.hostname,
583 branch=args.branch2, machine=args.machine) 513 branch=args.branch2, machine=args.machine)
584 if not len(revs2): 514 if not len(revs2):
585 log.error("No revisions found to compare against") 515 log.error("No revisions found to compare against")
586 return 1 516 return 1
@@ -596,9 +526,9 @@ def main(argv=None):
596 if args.commit: 526 if args.commit:
597 if args.commit_number: 527 if args.commit_number:
598 log.warning("Ignoring --commit-number as --commit was specified") 528 log.warning("Ignoring --commit-number as --commit was specified")
599 index1 = rev_find(revs, 'commit', args.commit) 529 index1 = gitarchive.rev_find(revs, 'commit', args.commit)
600 elif args.commit_number: 530 elif args.commit_number:
601 index1 = rev_find(revs, 'commit_number', args.commit_number) 531 index1 = gitarchive.rev_find(revs, 'commit_number', args.commit_number)
602 else: 532 else:
603 index1 = len(revs) - 1 533 index1 = len(revs) - 1
604 534
@@ -610,9 +540,9 @@ def main(argv=None):
610 if args.commit2: 540 if args.commit2:
611 if args.commit_number2: 541 if args.commit_number2:
612 log.warning("Ignoring --commit-number2 as --commit2 was specified") 542 log.warning("Ignoring --commit-number2 as --commit2 was specified")
613 index2 = rev_find(revs, 'commit', args.commit2) 543 index2 = gitarchive.rev_find(revs, 'commit', args.commit2)
614 elif args.commit_number2: 544 elif args.commit_number2:
615 index2 = rev_find(revs, 'commit_number', args.commit_number2) 545 index2 = gitarchive.rev_find(revs, 'commit_number', args.commit_number2)
616 else: 546 else:
617 if index1 > 0: 547 if index1 > 0:
618 index2 = index1 - 1 548 index2 = index1 - 1