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

pantsbuild / pants / 18252174847

05 Oct 2025 01:36AM UTC coverage: 43.382% (-36.9%) from 80.261%
18252174847

push

github

web-flow
run tests on mac arm (#22717)

Just doing the minimal to pull forward the x86_64 pattern.

ref #20993

25776 of 59416 relevant lines covered (43.38%)

1.3 hits per line

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

54.08
/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,<4"]),
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✔
95
    rule_runner.write_files({"f.py": BAD_FILE, "BUILD": "python_sources(name='t')"})
×
96
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
×
97
    result = run_flake8(rule_runner, [tgt])
×
98
    assert len(result) == 1
×
99
    assert result[0].exit_code == 1
×
100
    assert "f.py:1:1: F401" in result[0].stdout
×
101
    assert result[0].report == EMPTY_DIGEST
×
102

103

104
def test_multiple_targets(rule_runner: PythonRuleRunner) -> None:
3✔
105
    rule_runner.write_files(
×
106
        {"good.py": GOOD_FILE, "bad.py": BAD_FILE, "BUILD": "python_sources(name='t')"}
107
    )
108
    tgts = [
×
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
    ]
112
    result = run_flake8(rule_runner, tgts)
×
113
    assert len(result) == 1
×
114
    assert result[0].exit_code == 1
×
115
    assert "good.py" not in result[0].stdout
×
116
    assert "bad.py:1:1: F401" in result[0].stdout
×
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:
126
    rule_runner.write_files(
×
127
        {
128
            "f.py": BAD_FILE,
129
            "BUILD": "python_sources(name='t')",
130
            config_path: "[flake8]\nignore = F401\n",
131
        }
132
    )
133
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
×
134
    assert_success(rule_runner, tgt, extra_args=extra_args)
×
135

136

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

142

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

149

150
def test_3rdparty_plugin(rule_runner: PythonRuleRunner) -> None:
3✔
151
    # Test extra_files option.
152
    rule_runner.write_files(
×
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
    )
160
    tgt = rule_runner.get_target(Address("", target_name="t", relative_file_path="f.py"))
×
161
    result = run_flake8(
×
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
    )
170
    assert len(result) == 1
×
171
    assert result[0].exit_code == 0, result[0].stderr
×
172

173

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

187

188
def test_type_stubs(rule_runner: PythonRuleRunner) -> None:
3✔
189
    rule_runner.write_files(
×
190
        {"f.pyi": BAD_FILE, "f.py": GOOD_FILE, "BUILD": "python_sources(name='t')"}
191
    )
192
    tgts = [
×
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
    ]
196
    result = run_flake8(rule_runner, tgts)
×
197
    assert len(result) == 1
×
198
    assert result[0].exit_code == 1
×
199
    assert "f.py:" not in result[0].stdout
×
200
    assert "f.pyi:1:1: F401" in result[0].stdout
×
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

© 2025 Coveralls, Inc