mirror of
https://github.com/facebook/sapling.git
synced 2024-10-12 09:48:05 +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
76 lines
2.1 KiB
Python
76 lines
2.1 KiB
Python
# Helper module to use the Hypothesis tool in tests
|
|
#
|
|
# Copyright 2015 David R. MacIver
|
|
#
|
|
# For details see http://hypothesis.readthedocs.org
|
|
|
|
from __future__ import absolute_import, print_function
|
|
|
|
import os
|
|
import sys
|
|
import traceback
|
|
|
|
import hypothesis.strategies as st
|
|
from hypothesis import given
|
|
|
|
|
|
try:
|
|
# hypothesis 2.x
|
|
from hypothesis.configuration import set_hypothesis_home_dir
|
|
from hypothesis import settings
|
|
except ImportError:
|
|
# hypothesis 1.x
|
|
from hypothesis.settings import set_hypothesis_home_dir
|
|
from hypothesis import Settings as settings
|
|
|
|
# hypothesis store data regarding generate example and code
|
|
set_hypothesis_home_dir(os.path.join(os.getenv("TESTTMP"), ".hypothesis"))
|
|
|
|
|
|
def check(*args, **kwargs):
|
|
"""decorator to make a function a hypothesis test
|
|
|
|
Decorated function are run immediately (to be used doctest style)"""
|
|
|
|
def accept(f):
|
|
# Workaround for https://github.com/DRMacIver/hypothesis/issues/206
|
|
# Fixed in version 1.13 (released 2015 october 29th)
|
|
f.__module__ = "__anon__"
|
|
try:
|
|
with settings(max_examples=2000):
|
|
given(*args, **kwargs)(f)()
|
|
except Exception:
|
|
traceback.print_exc(file=sys.stdout)
|
|
sys.exit(1)
|
|
|
|
return accept
|
|
|
|
|
|
def roundtrips(data, decode, encode):
|
|
"""helper to tests function that must do proper encode/decode roundtripping
|
|
"""
|
|
|
|
@given(data)
|
|
def testroundtrips(value):
|
|
encoded = encode(value)
|
|
decoded = decode(encoded)
|
|
if decoded != value:
|
|
raise ValueError(
|
|
"Round trip failed: %s(%r) -> %s(%r) -> %r"
|
|
% (encode.__name__, value, decode.__name__, encoded, decoded)
|
|
)
|
|
|
|
try:
|
|
testroundtrips()
|
|
except Exception:
|
|
# heredoc swallow traceback, we work around it
|
|
traceback.print_exc(file=sys.stdout)
|
|
raise
|
|
print("Round trip OK")
|
|
|
|
|
|
# strategy for generating bytestring that might be an issue for Mercurial
|
|
bytestrings = (
|
|
st.builds(lambda s, e: s.encode(e), st.text(), st.sampled_from(["utf-8", "utf-16"]))
|
|
) | st.binary()
|