forked from mozilla/gecko-dev
-
Notifications
You must be signed in to change notification settings - Fork 1
/
check_js_msg_encoding.py
69 lines (47 loc) · 1.78 KB
/
check_js_msg_encoding.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# 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/.
# ----------------------------------------------------------------------------
# This script checks encoding of the files that define JSErrorFormatStrings.
#
# JSErrorFormatString.format member should be in ASCII encoding.
# ----------------------------------------------------------------------------
import os
import sys
from mozversioncontrol import get_repository_from_env
scriptname = os.path.basename(__file__)
expected_encoding = "ascii"
# The following files don't define JSErrorFormatString.
ignore_files = [
"dom/base/domerr.msg",
"js/xpconnect/src/xpc.msg",
]
def log_pass(filename, text):
print("TEST-PASS | {} | {} | {}".format(scriptname, filename, text))
def log_fail(filename, text):
print("TEST-UNEXPECTED-FAIL | {} | {} | {}".format(scriptname, filename, text))
def check_single_file(filename):
with open(filename, "rb") as f:
data = f.read()
try:
data.decode(expected_encoding)
except Exception:
log_fail(filename, "not in {} encoding".format(expected_encoding))
log_pass(filename, "ok")
return True
def check_files():
result = True
with get_repository_from_env() as repo:
root = repo.path
for filename, _ in repo.get_tracked_files_finder().find("**/*.msg"):
if filename not in ignore_files:
if not check_single_file(os.path.join(root, filename)):
result = False
return result
def main():
if not check_files():
sys.exit(1)
sys.exit(0)
if __name__ == "__main__":
main()