Add a script to check OWNERS file syntax.

* -v option to print found files and email addresses.
* -c option to check found email addresses.

Bug: 33166666
Test: ./checkowners.py -v -c `find . -name OWNERS`
Change-Id: I32f23f19e904055e421ddec713536c8a5c970af4
This commit is contained in:
Chih-Hung Hsieh 2017-02-22 16:14:48 -08:00
parent 557ce055e7
commit adaed14ff3
1 changed files with 76 additions and 0 deletions

76
tools/checkowners.py Executable file
View File

@ -0,0 +1,76 @@
#!/usr/bin/python
"""Parse and check syntax errors of a given OWNERS file."""
import argparse
import re
import sys
import urllib2
parser = argparse.ArgumentParser(description='Check OWNERS file syntax')
parser.add_argument('-v', '--verbose', dest='verbose',
action='store_true', default=False,
help='Verbose output to debug')
parser.add_argument('-c', '--check_address', dest='check_address',
action='store_true', default=False,
help='Check email addresses')
parser.add_argument(dest='owners', metavar='OWNERS', nargs='+',
help='Path to OWNERS file')
args = parser.parse_args()
gerrit_server = 'https://android-review.googlesource.com'
checked_addresses = {}
def echo(msg):
if args.verbose:
print msg
def find_address(address):
if address not in checked_addresses:
request = gerrit_server + '/accounts/?suggest&q=' + address
echo('Checking email address: ' + address)
result = urllib2.urlopen(request).read()
expected = '"email": "' + address + '"'
checked_addresses[address] = (result.find(expected) >= 0)
return checked_addresses[address]
def main():
# One regular expression to check all valid lines.
noparent = 'set +noparent'
email = '([^@ ]+@[^ @]+|\\*)'
directive = '(%s|%s)' % (email, noparent)
glob = '[a-zA-Z0-9_\\.\\-\\*\\?]+'
perfile = 'per-file +' + glob + ' *= *' + directive
pats = '(|%s|%s|%s)$' % (noparent, email, perfile)
patterns = re.compile(pats)
# One pattern to capture email address.
email_address = '.*(@| |=|^)([^@ =]+@[^ @]+)'
address_pattern = re.compile(email_address)
error = 0
for fname in args.owners:
echo('Checking file: ' + fname)
num = 0
for line in open(fname, 'r'):
num += 1
stripped_line = re.sub('#.*$', '', line).strip()
if not patterns.match(stripped_line):
error = 1
print('%s:%d: ERROR: unknown line [%s]'
% (fname, num, line.strip()))
elif args.check_address and address_pattern.match(stripped_line):
address = address_pattern.match(stripped_line).group(2)
if find_address(address):
echo('Found email address: ' + address)
else:
error = 1
print('%s:%d: ERROR: unknown email address: %s'
% (fname, num, address))
sys.exit(error)
if __name__ == '__main__':
main()