2016-09-28 08:12:54 +03:00
|
|
|
# vim: set ts=8 sts=4 et sw=4 tw=99:
|
|
|
|
# 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/.
|
|
|
|
|
2018-05-22 16:22:46 +03:00
|
|
|
# ----------------------------------------------------------------------------
|
2016-09-28 08:12:54 +03:00
|
|
|
# This script checks encoding of the files that define JSErrorFormatStrings.
|
|
|
|
#
|
|
|
|
# JSErrorFormatString.format member should be in ASCII encoding.
|
2018-05-22 16:22:46 +03:00
|
|
|
# ----------------------------------------------------------------------------
|
2016-09-28 08:12:54 +03:00
|
|
|
|
|
|
|
from __future__ import print_function
|
|
|
|
|
|
|
|
import os
|
|
|
|
import sys
|
2017-05-19 02:06:49 +03:00
|
|
|
|
|
|
|
from mozversioncontrol import get_repository_from_env
|
|
|
|
|
2016-09-28 08:12:54 +03:00
|
|
|
|
2018-05-22 01:01:01 +03:00
|
|
|
scriptname = os.path.basename(__file__)
|
2016-09-28 08:12:54 +03:00
|
|
|
expected_encoding = 'ascii'
|
|
|
|
|
|
|
|
# The following files don't define JSErrorFormatString.
|
|
|
|
ignore_files = [
|
|
|
|
'dom/base/domerr.msg',
|
|
|
|
'js/xpconnect/src/xpc.msg',
|
|
|
|
]
|
|
|
|
|
2018-05-22 01:01:01 +03:00
|
|
|
|
2016-09-28 08:12:54 +03:00
|
|
|
def log_pass(filename, text):
|
|
|
|
print('TEST-PASS | {} | {} | {}'.format(scriptname, filename, text))
|
|
|
|
|
2018-05-22 01:01:01 +03:00
|
|
|
|
2016-09-28 08:12:54 +03:00
|
|
|
def log_fail(filename, text):
|
|
|
|
print('TEST-UNEXPECTED-FAIL | {} | {} | {}'.format(scriptname, filename,
|
|
|
|
text))
|
|
|
|
|
2018-05-22 01:01:01 +03:00
|
|
|
|
2016-09-28 08:12:54 +03:00
|
|
|
def check_single_file(filename):
|
|
|
|
with open(filename, 'rb') as f:
|
|
|
|
data = f.read()
|
|
|
|
try:
|
|
|
|
data.decode(expected_encoding)
|
2018-05-22 16:22:46 +03:00
|
|
|
except Exception:
|
2016-09-28 08:12:54 +03:00
|
|
|
log_fail(filename, 'not in {} encoding'.format(expected_encoding))
|
|
|
|
|
|
|
|
log_pass(filename, 'ok')
|
|
|
|
return True
|
|
|
|
|
2018-05-22 01:01:01 +03:00
|
|
|
|
2016-09-28 08:12:54 +03:00
|
|
|
def check_files():
|
|
|
|
result = True
|
|
|
|
|
2017-08-24 01:21:16 +03:00
|
|
|
with get_repository_from_env() as repo:
|
|
|
|
root = repo.path
|
|
|
|
|
|
|
|
for filename in repo.get_files_in_working_directory():
|
|
|
|
if filename.endswith('.msg'):
|
|
|
|
if filename not in ignore_files:
|
|
|
|
if not check_single_file(os.path.join(root, filename)):
|
|
|
|
result = False
|
2016-09-28 08:12:54 +03:00
|
|
|
|
|
|
|
return result
|
|
|
|
|
2018-05-22 01:01:01 +03:00
|
|
|
|
2016-09-28 08:12:54 +03:00
|
|
|
def main():
|
|
|
|
if not check_files():
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
sys.exit(0)
|
|
|
|
|
2018-05-22 01:01:01 +03:00
|
|
|
|
2016-09-28 08:12:54 +03:00
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|