config/check_source_count.py
author Mounir Lamouri <mounir.lamouri@gmail.com>
Wed, 20 Apr 2011 22:26:06 +0200
changeset 68386 be6f4759e82736e21e24e46d22701e7d90a71f91
parent 64559 f949c8533aa03f15fb568d5b5ea2f2c7a9005e74
child 71856 2b09315d5f1655b7b5a86a93c4f8afc0a9634fb8
permissions -rwxr-xr-x
Backed out changeset c1a7c1bc1aeb due to busted build.

#!/usr/bin/env python

# Usage: check_source_count.py SEARCH_TERM COUNT ERROR_LOCATION REPLACEMENT [FILES...]
#   Checks that FILES contains exactly COUNT matches of SEARCH_TERM. If it does
#   not, an error message is printed, quoting ERROR_LOCATION, which should
#   probably be the filename and line number of the erroneous call to
#   check_source_count.py.

import sys
import os
import re

search_string = sys.argv[1]
expected_count = int(sys.argv[2])
error_location = sys.argv[3]
replacement = sys.argv[4]
files = sys.argv[5:]

details = {}

count = 0
for f in files:
    text = file(f).read()
    match = re.findall(search_string, text)
    if match:
        num = len(match)
        count += num
        details[f] = num

if count == expected_count:
    print "TEST-PASS | check_source_count.py %s | %d" % (search_string, expected_count)

else:
    print "TEST-UNEXPECTED-FAIL | check_source_count.py %s | " % (search_string),
    if count < expected_count:
        print "There are less occurences of /%s/ than expected. This may mean that you have removed some, but forgotten to account for it %s." % (search_string, error_location)
    else:
        print "There are more occurences of /%s/ than expected. We're trying to prevent an increase in the number of %s's, using %s if possible. If it in unavoidable, you should update the expected count %s." % (search_string, search_string, replacement, error_location)

    print "Expected: %d; found: %d" % (expected_count, count)
    for k in sorted(details):
        print "Found %d occurences in %s" % (details[k],k)
    sys.exit(-1)