#!/usr/bin/python3 # # Copyright (C) 2014 Red Hat, Inc. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published # by the Free Software Foundation; either version 2.1 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with this program. If not, see . import os, re, sys # {'bad re': 'suggestion'} # (?i) makes the re case-insensitive bad_strings = {'(?i)bootloader': 'boot loader', '(?i)filesystem': 'file system', '(?i)username': 'user name', '[Vv]lan': 'VLAN', '(?i)hostname': 'host name', 'ZFCP': 'zFCP', 'zfcp': 'zFCP', 'BTRFS': 'Btrfs', 'btrfs': 'Btrfs', '[Cc]an not': 'cannot', '(?i)mountpoint': 'mount point', 'Ok': 'OK', # Find instances of "return" that are referring to a keyboard key '(?i)': '[Enter]', '(?i)press return': 'press Enter', # Make sure "Enter" is capitalized '': '[Enter]', '[Pp]ress enter': 'press Enter' } # Sometimes we need to use a bad string, or it's just too much of a pain to # write a more specific regex. List occurrences here. # {'filename': {'matched string', occurrences}} expected_badness = {'pyanaconda/bootloader.py': {'mountpoint': 1}, # format string specifier 'pyanaconda/kickstart.py': {'btrfs': 1}, # quoted filesystem type 'pyanaconda/network.py': {'vlan': 1}, # format string specifier 'pyanaconda/rescue.py': {'mountpoint': 1}, # format string specifier 'anaconda.py': {'HOSTNAME': 1}} # ssh to install@HOSTNAME # Use polib to parse anaconda.pot try: import polib except ImportError: print("You need to install the python-polib package to read anaconda.pot") # This return code tells the automake test driver that the test setup failed sys.exit(99) if "top_srcdir" not in os.environ: sys.stderr.write("$top_srcdir must be defined in the test environment\n") sys.exit(99) if "top_builddir" not in os.environ: sys.stderr.write("$top_builddir must be defined in the test environment\n") sys.exit(99) # Parse anaconda.pot and rearrange the POFile object into a dict of {msgid: POEntry} pofile = polib.pofile(os.environ['top_builddir'] + "/po/anaconda.pot") msgs = {e.msgid: e for e in pofile} # Look for each of the bad regexes success = True for badre in bad_strings.keys(): regex = re.compile(badre) for msg in msgs.keys(): # Remove underscores to avoid trouble with underline-based accelerators match = re.search(regex, msg.replace('_', '')) if match: # If this is something expected, decrement the occurrence count in expected_badness badstr = match.group(0) remainder = [] for occur in msgs[msg].occurrences: if occur[0] in expected_badness and badstr in expected_badness[occur[0]]: expected_badness[occur[0]][badstr] -= 1 if expected_badness[occur[0]][badstr] == 0: del expected_badness[occur[0]][badstr] if not expected_badness[occur[0]]: del expected_badness[occur[0]] else: remainder.append(occur) if remainder: print("Bad string %(bad)s found at %(occurrences)s. Try %(suggestion)s instead." % {"bad": badstr, "occurrences": " ".join(("%s:%s" % (o[0], o[1]) for o in remainder)), "suggestion": bad_strings[badre]}) success = False if expected_badness: for filename in expected_badness.keys(): for badstr in expected_badness[filename].keys(): print("Did not find %d occurrences of %s in %s" % (expected_badness[filename][badstr], badstr, filename)) success = False sys.exit(0 if success else 1)