testing/tests/l10n/scripts/compare-locales
author Dave Camp <dcamp@mozilla.com>
Tue, 19 Aug 2008 22:54:37 -0700
changeset 17127 2053bab906dc548240c7d3e279af04ffcac48843
parent 4885 f2bb468eab2fe9e9f2bb0d9ee7e4156691922997
permissions -rwxr-xr-x
Backed out changeset bbaf0d5fef61 (bug 442803)

#! python
# ***** BEGIN LICENSE BLOCK *****
# Version: MPL 1.1/GPL 2.0/LGPL 2.1
#
# The contents of this file are subject to the Mozilla Public License Version
# 1.1 (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
# http://www.mozilla.org/MPL/
#
# Software distributed under the License is distributed on an "AS IS" basis,
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
# for the specific language governing rights and limitations under the
# License.
#
# The Original Code is l10n test automation.
#
# The Initial Developer of the Original Code is
# Mozilla Foundation
# Portions created by the Initial Developer are Copyright (C) 2006
# the Initial Developer. All Rights Reserved.
#
# Contributor(s):
#	Axel Hecht <l10n@mozilla.com>
#
# Alternatively, the contents of this file may be used under the terms of
# either the GNU General Public License Version 2 or later (the "GPL"), or
# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
# in which case the provisions of the GPL or the LGPL are applicable instead
# of those above. If you wish to allow use of your version of this file only
# under the terms of either the GPL or the LGPL, and not to allow others to
# use your version of this file under the terms of the MPL, indicate your
# decision by deleting the provisions above and replace them with the notice
# and other provisions required by the GPL or the LGPL. If you do not delete
# the provisions above, a recipient may use your version of this file under
# the terms of any one of the MPL, the GPL or the LGPL.
#
# ***** END LICENSE BLOCK *****


import logging
from optparse import OptionParser
from pprint import pprint

from Mozilla import Paths, CompareLocales

usage = 'usage: %prog [options] language1 [language2 ...]'
parser = OptionParser(usage=usage)

parser.add_option('-a', '--application', default='browser',
                  help='compare localizations for the specified application'+
                  ' [default: browser]')
parser.add_option('-v', '--verbose', action='count', dest='v', default=0,
                  help='Make more noise')
parser.add_option('-q', '--quiet', action='count', dest='q', default=0,
                  help='Make more noise')

(options, args) = parser.parse_args()
if len(args) == 0:
  parser.error('At least one language required')

# log as verbose or quiet as we want, warn by default
logging.basicConfig(level=(logging.WARNING - (options.v - options.q)*10))

# import Paths loaded all-locales for both browser and mail, we overwrite
# that with our settings before calling into CompareLocales
locales = {options.application: args}

# actually compare the localizations
res = CompareLocales.compare(testLocales=locales)

# helper class to merge all the lists into more consice
# dicts
class Separator:
  def __init__(self, apps):
    self.components = Paths.Components(apps)
    pass
  def getDetails(self, res, locale):
    dic = {}
    res[locale]['tested'].sort()
    self.collectList('missing', res[locale], dic)
    self.collectList('obsolete', res[locale], dic)
    return dic
  def collectList(self, name, res, dic):
    dic[name] = {}
    if name not in res:
      res[name] = []
    counts = dict([(mod,0) for mod in res['tested']])
    counts['total'] = len(res[name])
    for mod, path, key in res[name]:
      counts[self.components[mod]] +=1
      if mod not in  dic[name]:
        dic[name][mod] = {path:[key]}
        continue
      if path not in dic[name][mod]:
        dic[name][mod][path] = [key]
      else:
        dic[name][mod][path].append(key)
    res[name] = counts
    name += 'Files'
    dic[name] = {}
    if name not in res:
      res[name] = []
    counts = dict([(mod,0) for mod in res['tested']])
    counts['total'] = len(res[name])
    for mod, path in res[name]:
      counts[self.components[mod]] +=1
      if mod not in dic[name]:
        dic[name][mod] = [path]
      else:
        dic[name][mod].append(path)
    res[name] = counts

s = Separator([options.application])

# pretty print results for all localizations
for loc in args:
  print(loc + ':')
  pprint(s.getDetails(res, loc))
  result = res[loc]
  pprint(result)
  rate = result['changed']*100/ \
         (result['changed'] + result['unchanged'] + \
          result['missing']['total'])
  print('%d%% of entries changed' % rate)