config/check_source_count.py
author B2G Bumper Bot <release+b2gbumper@mozilla.com>
Wed, 17 Jun 2015 04:40:28 -0700
changeset 279976 9a0e53e7fcbf4510f20be2404b3b34c6107a8558
parent 133841 8f83edc05fa4d458d82668a95853c907544d0b8d
child 473816 fba6f974041a3d3c22ef95c44f6e4262e8e5c52f
permissions -rwxr-xr-x
Bumping gaia.json for 4 gaia revision(s) a=gaia-bump ======== https://hg.mozilla.org/integration/gaia-central/rev/40a9c300245a Author: Martijn <martijn.martijn@gmail.com> Desc: Merge pull request #30572 from mwargers/1112141_2 Bug 1112141 - Intermittent test_homescreen_delete_app_packaged.py TestDeleteApp.test_delete_app | StaleElementException: 2nd attempt ======== https://hg.mozilla.org/integration/gaia-central/rev/97f32c0e6764 Author: Martijn Wargers <mwargers@mozilla.com> Desc: Bug 1112141 - Intermittent test_homescreen_delete_app_packaged.py TestDeleteApp.test_delete_app | StaleElementException: 2nd attempt ======== https://hg.mozilla.org/integration/gaia-central/rev/79e9f8f0db20 Author: Borja Salguero <borjasalguero@users.noreply.github.com> Desc: Merge pull request #30515 from jpruden92/bug1173097-contacts Bug 1173097 - [Contacts][NGA] Extract 'goToSelectTag' functionality to it own .js class ======== https://hg.mozilla.org/integration/gaia-central/rev/b1608faec400 Author: jpruden92 <jorgepruden@gmail.com> Desc: Bug 1173097 - [Contacts][NGA] Extract 'goToSelectTag' functionality to it own .js class

#!/usr/bin/env python
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.


# 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.
from __future__ import print_function
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 {0} | {1}"
          .format(search_string, expected_count))

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

    print("Expected: {0}; found: {1}".format(expected_count, count))
    for k in sorted(details):
        print("Found {0} occurences in {1}".format(details[k],k))
    sys.exit(-1)