Hacked By AnonymousFox
# Licensed under the GPL: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
# For details: https://github.com/PyCQA/pylint/blob/main/LICENSE
# Copyright (c) https://github.com/PyCQA/pylint/blob/main/CONTRIBUTORS.txt
from __future__ import annotations
import csv
import os
from _pytest.config import Config
from pylint.constants import PY38_PLUS
from pylint.testutils.functional.test_file import FunctionalTestFile
from pylint.testutils.lint_module_test import LintModuleTest, MessageCounter
from pylint.testutils.output_line import OutputLine
class LintModuleOutputUpdate(LintModuleTest):
"""Class to be used if expected output files should be updated instead of
checked.
"""
class TestDialect(csv.excel):
"""Dialect used by the csv writer."""
delimiter = ":"
lineterminator = "\n"
csv.register_dialect("test", TestDialect)
def __init__(
self, test_file: FunctionalTestFile, config: Config | None = None
) -> None:
if not PY38_PLUS:
raise RuntimeError(
"You need at least python 3.8 for the functional test updater to work. "
"This is because python 3.8 includes a new AST parser, which amongst others "
"returns the end line and end column of most nodes."
)
super().__init__(test_file, config)
def _check_output_text(
self,
_: MessageCounter,
expected_output: list[OutputLine],
actual_output: list[OutputLine],
) -> None:
"""Overwrite or remove the expected output file based on actual output."""
# Remove the file if no output is actually expected and a file exists
if not expected_output and not actual_output:
if os.path.exists(self._test_file.expected_output):
os.remove(self._test_file.expected_output)
return
# Write file with expected output
with open(self._test_file.expected_output, "w", encoding="utf-8") as f:
writer = csv.writer(f, dialect="test")
for line in actual_output:
writer.writerow(line.to_csv())
Hacked By AnonymousFox1.0, Coded By AnonymousFox