• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

pantsbuild / pants / 21552830208

31 Jan 2026 11:40PM UTC coverage: 80.277% (-0.05%) from 80.324%
21552830208

Pull #23062

github

web-flow
Merge 808a9786c into 2c4dcf9cf
Pull Request #23062: Remove support for Get

18 of 25 new or added lines in 4 files covered. (72.0%)

17119 existing lines in 541 files now uncovered.

78278 of 97510 relevant lines covered (80.28%)

3.36 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

100.0
/src/python/pants/backend/python/lint/flake8/rules_integration_test.py
1
# Copyright 2019 Pants project contributors (see CONTRIBUTORS.md).
2
# Licensed under the Apache License, Version 2.0 (see LICENSE).
3

4
from __future__ import annotations
3✔
5

6
from typing import Any
3✔
7

8
import pytest
3✔
9

10
from pants.backend.python import target_types_rules
3✔
11
from pants.backend.python.lint.flake8.rules import Flake8Request
3✔
12
from pants.backend.python.lint.flake8.rules import rules as flake8_rules
3✔
13
from pants.backend.python.lint.flake8.subsystem import Flake8FieldSet
3✔
14
from pants.backend.python.lint.flake8.subsystem import rules as flake8_subsystem_rules
3✔
15
from pants.backend.python.target_types import PythonSourcesGeneratorTarget
3✔
16
from pants.backend.python.util_rules import python_sources
3✔
17
from pants.core.goals.lint import LintResult, Partitions
3✔
18
from pants.core.util_rules import config_files
3✔
19
from pants.engine.addresses import Address
3✔
20
from pants.engine.fs import EMPTY_DIGEST, DigestContents
3✔
21
from pants.engine.target import Target
3✔
22
from pants.testutil.python_interpreter_selection import all_major_minor_python_versions
3✔
23
from pants.testutil.python_rule_runner import PythonRuleRunner
3✔
24
from pants.testutil.rule_runner import QueryRule
3✔
25
from pants.util.resources import read_sibling_resource
3✔
26

27

28
@pytest.fixture
3✔
29
def rule_runner() -> PythonRuleRunner:
3✔
30
    return PythonRuleRunner(
3✔
31
        rules=[
32
            *flake8_rules(),
33
            *flake8_subsystem_rules(),
34
            *python_sources.rules(),
35
            *config_files.rules(),
36
            *target_types_rules.rules(),
37
            QueryRule(Partitions, [Flake8Request.PartitionRequest]),
38
            QueryRule(LintResult, [Flake8Request.Batch]),
39
        ],
40
        target_types=[PythonSourcesGeneratorTarget],
41
    )
42

43

44
GOOD_FILE = "print('Nothing suspicious here..')\n"
3✔
45
BAD_FILE = "import typing\n"  # Unused import.
3✔
46

47

48
def run_flake8(
3✔
49
    rule_runner: PythonRuleRunner, targets: list[Target], *, extra_args: list[str] | None = None
50
) -> tuple[LintResult, ...]:
51
    rule_runner.set_options(
3✔
52
        ["--backend-packages=pants.backend.python.lint.flake8", *(extra_args or ())],
53
        env_inherit={"PATH", "PYENV_ROOT", "HOME"},
54
    )
55
    partitions = rule_runner.request(
3✔
56
        Partitions[Flake8FieldSet, Any],
57
        [Flake8Request.PartitionRequest(tuple(Flake8FieldSet.create(tgt) for tgt in targets))],
58
    )
59
    results = []
3✔
60
    for partition in partitions:
3✔
61
        result = rule_runner.request(
3✔
62
            LintResult,
63
            [Flake8Request.Batch("", partition.elements, partition.metadata)],
64
        )
65
        results.append(result)
3✔
66
    return tuple(results)
3✔
67

68

69
def assert_success(
3✔
70
    rule_runner: PythonRuleRunner, target: Target, *, extra_args: list[str] | None = None
71
) -> None:
72
    result = run_flake8(rule_runner, [target], extra_args=extra_args)
3✔
73
    assert len(result) == 1
3✔
74
    assert result[0].exit_code == 0
3✔
75
    assert result[0].stdout.strip() == ""
3✔
76
    assert result[0].report == EMPTY_DIGEST
3✔
77

78

79
@pytest.mark.platform_specific_behavior
3✔
80
@pytest.mark.parametrize(
3✔
81
    "major_minor_interpreter",
82
    all_major_minor_python_versions(["CPython>=3.9,<3.15"]),
83
)
84
def test_passing(rule_runner: PythonRuleRunner, major_minor_interpreter: str) -> None:
3✔
85
    rule_runner.write_files({"f.py": GOOD_FILE, "BUILD": "python_sources(name='t')"})
3✔
86
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
3✔
87
    assert_success(
3✔
88
        rule_runner,
89
        tgt,
90
        extra_args=[f"--python-interpreter-constraints=['=={major_minor_interpreter}.*']"],
91
    )
92

93

94
def test_failing(rule_runner: PythonRuleRunner) -> None:
3✔
UNCOV
95
    rule_runner.write_files({"f.py": BAD_FILE, "BUILD": "python_sources(name='t')"})
1✔
UNCOV
96
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
1✔
UNCOV
97
    result = run_flake8(rule_runner, [tgt])
1✔
UNCOV
98
    assert len(result) == 1
1✔
UNCOV
99
    assert result[0].exit_code == 1
1✔
UNCOV
100
    assert "f.py:1:1: F401" in result[0].stdout
1✔
UNCOV
101
    assert result[0].report == EMPTY_DIGEST
1✔
102

103

104
def test_multiple_targets(rule_runner: PythonRuleRunner) -> None:
3✔
UNCOV
105
    rule_runner.write_files(
1✔
106
        {"good.py": GOOD_FILE, "bad.py": BAD_FILE, "BUILD": "python_sources(name='t')"}
107
    )
UNCOV
108
    tgts = [
1✔
109
        rule_runner.get_target(Address("", target_name="t", relative_file_path="good.py")),
110
        rule_runner.get_target(Address("", target_name="t", relative_file_path="bad.py")),
111
    ]
UNCOV
112
    result = run_flake8(rule_runner, tgts)
1✔
UNCOV
113
    assert len(result) == 1
1✔
UNCOV
114
    assert result[0].exit_code == 1
1✔
UNCOV
115
    assert "good.py" not in result[0].stdout
1✔
UNCOV
116
    assert "bad.py:1:1: F401" in result[0].stdout
1✔
117

118

119
@pytest.mark.parametrize(
3✔
120
    "config_path,extra_args",
121
    ([".flake8", []], ["custom_config.ini", ["--flake8-config=custom_config.ini"]]),
122
)
123
def test_config_file(
3✔
124
    rule_runner: PythonRuleRunner, config_path: str, extra_args: list[str]
125
) -> None:
UNCOV
126
    rule_runner.write_files(
1✔
127
        {
128
            "f.py": BAD_FILE,
129
            "BUILD": "python_sources(name='t')",
130
            config_path: "[flake8]\nignore = F401\n",
131
        }
132
    )
UNCOV
133
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
1✔
UNCOV
134
    assert_success(rule_runner, tgt, extra_args=extra_args)
1✔
135

136

137
def test_passthrough_args(rule_runner: PythonRuleRunner) -> None:
3✔
UNCOV
138
    rule_runner.write_files({"f.py": BAD_FILE, "BUILD": "python_sources(name='t')"})
1✔
UNCOV
139
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
1✔
UNCOV
140
    assert_success(rule_runner, tgt, extra_args=["--flake8-args='--ignore=F401'"])
1✔
141

142

143
def test_skip(rule_runner: PythonRuleRunner) -> None:
3✔
UNCOV
144
    rule_runner.write_files({"f.py": BAD_FILE, "BUILD": "python_sources(name='t')"})
1✔
UNCOV
145
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
1✔
UNCOV
146
    result = run_flake8(rule_runner, [tgt], extra_args=["--flake8-skip"])
1✔
UNCOV
147
    assert not result
1✔
148

149

150
def test_3rdparty_plugin(rule_runner: PythonRuleRunner) -> None:
3✔
151
    # Test extra_files option.
UNCOV
152
    rule_runner.write_files(
1✔
153
        {
154
            "f.py": "assert 1 == 1\n",
155
            ".bandit": "[bandit]\nskips: B101\n",
156
            "BUILD": "python_sources(name='t')",
157
            "flake8.lock": read_sibling_resource(__name__, "flake8_plugin_test.lock"),
158
        }
159
    )
UNCOV
160
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
1✔
UNCOV
161
    result = run_flake8(
1✔
162
        rule_runner,
163
        [tgt],
164
        extra_args=[
165
            "--python-resolves={'flake8':'flake8.lock'}",
166
            "--flake8-install-from-resolve=flake8",
167
            "--flake8-extra-files=['.bandit']",
168
        ],
169
    )
UNCOV
170
    assert len(result) == 1
1✔
UNCOV
171
    assert result[0].exit_code == 0, result[0].stderr
1✔
172

173

174
def test_report_file(rule_runner: PythonRuleRunner) -> None:
3✔
UNCOV
175
    rule_runner.write_files({"f.py": BAD_FILE, "BUILD": "python_sources(name='t')"})
1✔
UNCOV
176
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
1✔
UNCOV
177
    result = run_flake8(
1✔
178
        rule_runner, [tgt], extra_args=["--flake8-args='--output-file=reports/foo.txt'"]
179
    )
UNCOV
180
    assert len(result) == 1
1✔
UNCOV
181
    assert result[0].exit_code == 1
1✔
UNCOV
182
    assert result[0].stdout.strip() == ""
1✔
UNCOV
183
    report_files = rule_runner.request(DigestContents, [result[0].report])
1✔
UNCOV
184
    assert len(report_files) == 1
1✔
UNCOV
185
    assert "f.py:1:1: F401" in report_files[0].content.decode()
1✔
186

187

188
def test_type_stubs(rule_runner: PythonRuleRunner) -> None:
3✔
UNCOV
189
    rule_runner.write_files(
1✔
190
        {"f.pyi": BAD_FILE, "f.py": GOOD_FILE, "BUILD": "python_sources(name='t')"}
191
    )
UNCOV
192
    tgts = [
1✔
193
        rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py")),
194
        rule_runner.get_target(Address("", target_name="t", relative_file_path="f.pyi")),
195
    ]
UNCOV
196
    result = run_flake8(rule_runner, tgts)
1✔
UNCOV
197
    assert len(result) == 1
1✔
UNCOV
198
    assert result[0].exit_code == 1
1✔
UNCOV
199
    assert "f.py:" not in result[0].stdout
1✔
UNCOV
200
    assert "f.pyi:1:1: F401" in result[0].stdout
1✔
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc