mirror of
https://github.com/facebook/sapling.git
synced 2024-10-11 09:17:30 +03:00
584656dff3
Summary: Turned on the auto formatter. Ran `arc lint --apply-patches --take BLACK **/*.py`. Then run `arc lint` again so some other autofixers like spellchecker etc. looked at the code base. Manually accept the changes whenever they make sense, or use a workaround (ex. changing "dict()" to "dict constructor") where autofix is false positive. Disabled linters on files that are hard (i18n/polib.py) to fix, or less interesting to fix (hgsubversion tests), or cannot be fixed without breaking OSS build (FBPYTHON4). Conflicted linters (test-check-module-imports.t, part of test-check-code.t, test-check-pyflakes.t) are removed or disabled. Duplicated linters (test-check-pyflakes.t, test-check-pylint.t) are removed. An issue of the auto-formatter is lines are no longer guarnateed to be <= 80 chars. But that seems less important comparing with the benefit auto-formatter provides. As we're here, also remove test-check-py3-compat.t, as it is currently broken if `PYTHON3=/bin/python3` is set. Reviewed By: wez, phillco, simpkins, pkaush, singhsrb Differential Revision: D8173629 fbshipit-source-id: 90e248ae0c5e6eaadbe25520a6ee42d32005621b
126 lines
2.9 KiB
Python
126 lines
2.9 KiB
Python
from __future__ import absolute_import, print_function
|
|
|
|
# isort:skip_file
|
|
|
|
from mercurial import demandimport
|
|
|
|
demandimport.enable()
|
|
|
|
import os
|
|
import subprocess
|
|
import sys
|
|
|
|
# Only run if demandimport is allowed
|
|
if subprocess.call(["python", "%s/hghave" % os.environ["TESTDIR"], "demandimport"]):
|
|
sys.exit(80)
|
|
|
|
if os.name != "nt":
|
|
try:
|
|
import distutils.msvc9compiler
|
|
|
|
print(
|
|
"distutils.msvc9compiler needs to be an immediate "
|
|
"importerror on non-windows platforms"
|
|
)
|
|
distutils.msvc9compiler
|
|
except ImportError:
|
|
pass
|
|
|
|
import re
|
|
|
|
rsub = re.sub
|
|
|
|
|
|
def f(obj):
|
|
l = repr(obj)
|
|
l = rsub("0x[0-9a-fA-F]+", "0x?", l)
|
|
l = rsub("from '.*'", "from '?'", l)
|
|
l = rsub("'<[a-z]*>'", "'<whatever>'", l)
|
|
return l
|
|
|
|
|
|
import os
|
|
|
|
print("os =", f(os))
|
|
print("os.system =", f(os.system))
|
|
print("os =", f(os))
|
|
|
|
from mercurial import util
|
|
|
|
print("util =", f(util))
|
|
print("util.system =", f(util.system))
|
|
print("util =", f(util))
|
|
print("util.system =", f(util.system))
|
|
|
|
from mercurial import hgweb
|
|
|
|
print("hgweb =", f(hgweb))
|
|
print("hgweb_mod =", f(hgweb.hgweb_mod))
|
|
print("hgweb =", f(hgweb))
|
|
|
|
import re as fred
|
|
|
|
print("fred =", f(fred))
|
|
|
|
import re as remod
|
|
|
|
print("remod =", f(remod))
|
|
|
|
import sys as re
|
|
|
|
print("re =", f(re))
|
|
|
|
print("fred =", f(fred))
|
|
print("fred.sub =", f(fred.sub))
|
|
print("fred =", f(fred))
|
|
|
|
remod.escape # use remod
|
|
print("remod =", f(remod))
|
|
|
|
print("re =", f(re))
|
|
print("re.stderr =", f(re.stderr))
|
|
print("re =", f(re))
|
|
|
|
# Test access to special attributes through demandmod proxy
|
|
from mercurial import pvec as pvecproxy
|
|
|
|
print("pvecproxy =", f(pvecproxy))
|
|
print("pvecproxy.__doc__ = %r" % (" ".join(pvecproxy.__doc__.split()[:3]) + " ..."))
|
|
print("pvecproxy.__name__ = %r" % pvecproxy.__name__)
|
|
# __name__ must be accessible via __dict__ so the relative imports can be
|
|
# resolved
|
|
print("pvecproxy.__dict__['__name__'] = %r" % pvecproxy.__dict__["__name__"])
|
|
print("pvecproxy =", f(pvecproxy))
|
|
|
|
import contextlib
|
|
|
|
print("contextlib =", f(contextlib))
|
|
try:
|
|
from contextlib import unknownattr
|
|
|
|
print(
|
|
"no demandmod should be created for attribute of non-package "
|
|
"module:\ncontextlib.unknownattr =",
|
|
f(unknownattr),
|
|
)
|
|
except ImportError as inst:
|
|
print("contextlib.unknownattr = ImportError: %s" % rsub(r"'", "", str(inst)))
|
|
|
|
# Unlike the import statement, __import__() function should not raise
|
|
# ImportError even if fromlist has an unknown item
|
|
# (see Python/import.c:import_module_level() and ensure_fromlist())
|
|
contextlibimp = __import__("contextlib", globals(), locals(), ["unknownattr"])
|
|
print("__import__('contextlib', ..., ['unknownattr']) =", f(contextlibimp))
|
|
print(
|
|
"hasattr(contextlibimp, 'unknownattr') =",
|
|
util.safehasattr(contextlibimp, "unknownattr"),
|
|
)
|
|
|
|
demandimport.disable()
|
|
os.environ["HGDEMANDIMPORT"] = "disable"
|
|
# this enable call should not actually enable demandimport!
|
|
demandimport.enable()
|
|
from mercurial import node
|
|
|
|
print("node =", f(node))
|