zanata_stat.py: Support Zanata 3.9.6
Zanata 3.9.6 changes the format of statistics data. This commit updates the tool to support 3.9.6. The old format from the old Zanata used at translate.openstack.org is no longer supported. Closes-Bug: #1670638 Change-Id: I692a995142529c4df1e2664264afc19496bf71ed
This commit is contained in:
parent
8ae974d80e
commit
07d3753a7f
@ -111,9 +111,8 @@ def _make_user(user_id, language_code):
|
|||||||
return {
|
return {
|
||||||
'user_id': user_id,
|
'user_id': user_id,
|
||||||
'lang': language_code,
|
'lang': language_code,
|
||||||
'translated': 0,
|
'translation-stats': {},
|
||||||
'approved': 0,
|
'review-stats': {},
|
||||||
'rejected': 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -141,7 +140,8 @@ def read_language_team_yaml(translation_team_uri, lang_list):
|
|||||||
return language_teams
|
return language_teams
|
||||||
|
|
||||||
|
|
||||||
def get_zanata_stats(start_date, end_date, language_teams, project_list):
|
def get_zanata_stats(start_date, end_date, language_teams, project_list,
|
||||||
|
version_list, user_list):
|
||||||
print('Getting Zanata contributors statistics (from %s to %s) ...' %
|
print('Getting Zanata contributors statistics (from %s to %s) ...' %
|
||||||
(start_date, end_date))
|
(start_date, end_date))
|
||||||
zanataUtil = ZanataUtility()
|
zanataUtil = ZanataUtility()
|
||||||
@ -155,7 +155,11 @@ def get_zanata_stats(start_date, end_date, language_teams, project_list):
|
|||||||
project_list = zanataUtil.zanata_get_projects()
|
project_list = zanataUtil.zanata_get_projects()
|
||||||
for project_id in project_list:
|
for project_id in project_list:
|
||||||
for version in zanataUtil.zanata_get_project_versions(project_id):
|
for version in zanataUtil.zanata_get_project_versions(project_id):
|
||||||
|
if version_list and version not in version_list:
|
||||||
|
continue
|
||||||
for user_id in users:
|
for user_id in users:
|
||||||
|
if user_list and user_id not in user_list:
|
||||||
|
continue
|
||||||
user = users.get(user_id)
|
user = users.get(user_id)
|
||||||
print('Getting %(project_id)s %(version)s '
|
print('Getting %(project_id)s %(version)s '
|
||||||
'for user %(user_id)s %(user_lang)s'
|
'for user %(user_id)s %(user_lang)s'
|
||||||
@ -165,17 +169,49 @@ def get_zanata_stats(start_date, end_date, language_teams, project_list):
|
|||||||
'user_lang': user['lang']})
|
'user_lang': user['lang']})
|
||||||
statisticdata = zanataUtil.zanata_get_user_stats(
|
statisticdata = zanataUtil.zanata_get_user_stats(
|
||||||
project_id, version, user_id, start_date, end_date)
|
project_id, version, user_id, start_date, end_date)
|
||||||
|
print('Got: %s' % statisticdata)
|
||||||
if statisticdata:
|
if statisticdata:
|
||||||
user_contributes = statisticdata[user_id]
|
user_stats = parse_user_stat(statisticdata, user)
|
||||||
if (user['lang'] in user_contributes):
|
if user_stats:
|
||||||
user_stat = user_contributes[user['lang']]
|
user.update(user_stats)
|
||||||
user['translated'] += int(user_stat['translated'])
|
print('=> %s' % user)
|
||||||
user['approved'] += int(user_stat['approved'])
|
|
||||||
user['rejected'] += int(user_stat['rejected'])
|
|
||||||
|
|
||||||
return users
|
return users
|
||||||
|
|
||||||
|
|
||||||
|
def parse_user_stat(stats, user):
|
||||||
|
# data format (Zanata 3.9.6)
|
||||||
|
# {
|
||||||
|
# "username": "amotoki",
|
||||||
|
# "contributions": [
|
||||||
|
# {
|
||||||
|
# "locale": "ja",
|
||||||
|
# "translation-stats": {
|
||||||
|
# "translated": 7360,
|
||||||
|
# "needReview": 0,
|
||||||
|
# "approved": 152,
|
||||||
|
# "rejected": 0
|
||||||
|
# },
|
||||||
|
# "review-stats": {
|
||||||
|
# "approved": 220,
|
||||||
|
# "rejected": 0
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
# ]
|
||||||
|
# }
|
||||||
|
stat = [d for d in stats['contributions']
|
||||||
|
if d['locale'] == user['lang']]
|
||||||
|
if stat:
|
||||||
|
stat = stat[0]
|
||||||
|
if 'translation-stats' in stat:
|
||||||
|
stat['translation-stats']['total'] = \
|
||||||
|
sum(stat['translation-stats'].values())
|
||||||
|
if 'review-stats' in stat:
|
||||||
|
stat['review-stats']['total'] = \
|
||||||
|
sum(stat['review-stats'].values())
|
||||||
|
return stat
|
||||||
|
|
||||||
|
|
||||||
def write_stats_to_file(users, output_file, file_format,
|
def write_stats_to_file(users, output_file, file_format,
|
||||||
include_no_activities):
|
include_no_activities):
|
||||||
stats = [user for user in
|
stats = [user for user in
|
||||||
@ -191,7 +227,7 @@ def write_stats_to_file(users, output_file, file_format,
|
|||||||
def _needs_output(include_no_activities, user):
|
def _needs_output(include_no_activities, user):
|
||||||
if include_no_activities:
|
if include_no_activities:
|
||||||
return True
|
return True
|
||||||
elif user['translated'] or user['approved'] or user['rejected']:
|
elif user['translation-stats'] or user['review-stats']:
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
@ -200,12 +236,28 @@ def _needs_output(include_no_activities, user):
|
|||||||
def _write_stats_to_csvfile(stats, output_file):
|
def _write_stats_to_csvfile(stats, output_file):
|
||||||
with open(output_file, 'wb') as csvfile:
|
with open(output_file, 'wb') as csvfile:
|
||||||
writer = csv.writer(csvfile)
|
writer = csv.writer(csvfile)
|
||||||
writer.writerow(['user_id', 'lang',
|
writer.writerow(['user_id',
|
||||||
'translated', 'approved', 'rejected'])
|
'lang',
|
||||||
|
'translation-total',
|
||||||
|
'translated',
|
||||||
|
'needReview',
|
||||||
|
'approved',
|
||||||
|
'rejected',
|
||||||
|
'review-total',
|
||||||
|
'review-approved',
|
||||||
|
'review-rejected'])
|
||||||
for stat in stats:
|
for stat in stats:
|
||||||
writer.writerow([stat['user_id'], stat['lang'],
|
writer.writerow([stat['user_id'],
|
||||||
stat['translated'], stat['approved'],
|
stat['lang'],
|
||||||
stat['rejected']])
|
stat['translation-stats'].get('total', 0),
|
||||||
|
stat['translation-stats'].get('translated', 0),
|
||||||
|
stat['translation-stats'].get('needReview', 0),
|
||||||
|
stat['translation-stats'].get('approved', 0),
|
||||||
|
stat['translation-stats'].get('rejected', 0),
|
||||||
|
stat['review-stats'].get('total', 0),
|
||||||
|
stat['review-stats'].get('approved', 0),
|
||||||
|
stat['review-stats'].get('rejected', 0),
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
def _write_stats_to_jsonfile(stats, output_file):
|
def _write_stats_to_jsonfile(stats, output_file):
|
||||||
@ -245,6 +297,15 @@ def main():
|
|||||||
help=("Specify language(s). Comma-separated list. "
|
help=("Specify language(s). Comma-separated list. "
|
||||||
"Language code like zh-CN, ja needs to be used. "
|
"Language code like zh-CN, ja needs to be used. "
|
||||||
"Otherwise all languages are processed."))
|
"Otherwise all languages are processed."))
|
||||||
|
parser.add_argument("-t", "--target-version",
|
||||||
|
type=_comma_separated_list,
|
||||||
|
help=("Specify version(s). Comma-separated list. "
|
||||||
|
"Otherwise all available versions are "
|
||||||
|
"processed."))
|
||||||
|
parser.add_argument("-u", "--user",
|
||||||
|
type=_comma_separated_list,
|
||||||
|
help=("Specify user(s). Comma-separated list. "
|
||||||
|
"Otherwise all users are processed."))
|
||||||
parser.add_argument("--include-no-activities",
|
parser.add_argument("--include-no-activities",
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help=("If specified, stats for users with no "
|
help=("If specified, stats for users with no "
|
||||||
@ -260,8 +321,10 @@ def main():
|
|||||||
|
|
||||||
language_teams = read_language_team_yaml(options.user_yaml, options.lang)
|
language_teams = read_language_team_yaml(options.user_yaml, options.lang)
|
||||||
|
|
||||||
|
versions = [v.replace('/', '-') for v in options.target_version or []]
|
||||||
users = get_zanata_stats(options.start_date, options.end_date,
|
users = get_zanata_stats(options.start_date, options.end_date,
|
||||||
language_teams, options.project)
|
language_teams, options.project,
|
||||||
|
versions, options.user)
|
||||||
|
|
||||||
output_file = (options.output_file or
|
output_file = (options.output_file or
|
||||||
'zanata_stats_output.%s' % options.format)
|
'zanata_stats_output.%s' % options.format)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user