• 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

83.64
/src/python/pants/backend/python/subsystems/pytest.py
1
# Copyright 2016 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
import os.path
3✔
7
from collections.abc import Iterable
3✔
8
from dataclasses import dataclass
3✔
9

10
from pants.backend.python.subsystems.python_tool_base import PythonToolBase
3✔
11
from pants.backend.python.target_types import (
3✔
12
    ConsoleScript,
13
    InterpreterConstraintsField,
14
    PythonResolveField,
15
    PythonTestsBatchCompatibilityTagField,
16
    PythonTestsExtraEnvVarsField,
17
    PythonTestSourceField,
18
    PythonTestsTimeoutField,
19
    PythonTestsXdistConcurrencyField,
20
    SkipPythonTestsField,
21
)
22
from pants.core.environments.target_types import EnvironmentField
3✔
23
from pants.core.goals.resolves import ExportableTool
3✔
24
from pants.core.goals.test import RuntimePackageDependenciesField, TestFieldSet
3✔
25
from pants.core.util_rules.config_files import ConfigFilesRequest
3✔
26
from pants.engine.rules import collect_rules
3✔
27
from pants.engine.target import Target
3✔
28
from pants.engine.unions import UnionRule
3✔
29
from pants.option.option_types import ArgsListOption, BoolOption, FileOption, SkipOption, StrOption
3✔
30
from pants.util.strutil import softwrap
3✔
31

32

33
@dataclass(frozen=True)
3✔
34
class PythonTestFieldSet(TestFieldSet):
3✔
35
    required_fields = (PythonTestSourceField,)
3✔
36

37
    source: PythonTestSourceField
3✔
38
    interpreter_constraints: InterpreterConstraintsField
3✔
39
    timeout: PythonTestsTimeoutField
3✔
40
    runtime_package_dependencies: RuntimePackageDependenciesField
3✔
41
    extra_env_vars: PythonTestsExtraEnvVarsField
3✔
42
    xdist_concurrency: PythonTestsXdistConcurrencyField
3✔
43
    batch_compatibility_tag: PythonTestsBatchCompatibilityTagField
3✔
44
    resolve: PythonResolveField
3✔
45
    environment: EnvironmentField
3✔
46

47
    @classmethod
3✔
48
    def opt_out(cls, tgt: Target) -> bool:
3✔
49
        return tgt.get(SkipPythonTestsField).value
×
50

51

52
class PyTest(PythonToolBase):
3✔
53
    options_scope = "pytest"
3✔
54
    name = "Pytest"
3✔
55
    help_short = "The pytest Python test framework (https://docs.pytest.org/)."
3✔
56

57
    default_requirements = [
3✔
58
        "pytest>=7,<9,!=7.1.0,!=7.1.1",
59
        "pytest-cov>=5,<7",
60
        "pytest-xdist>=3.6.1,<4",
61
    ]
62

63
    default_main = ConsoleScript("pytest")
3✔
64

65
    default_lockfile_resource = ("pants.backend.python.subsystems", "pytest.lock")
3✔
66

67
    args = ArgsListOption(example="-k test_foo --quiet", passthrough=True)
3✔
68
    junit_family = StrOption(
3✔
69
        default="xunit2",
70
        advanced=True,
71
        help=softwrap(
72
            """
73
            The format of generated junit XML files. See
74
            https://docs.pytest.org/en/latest/reference.html#confval-junit_family.
75
            """
76
        ),
77
    )
78
    execution_slot_var = StrOption(
3✔
79
        default=None,
80
        advanced=True,
81
        help=softwrap(
82
            """
83
            If a non-empty string, the process execution slot id (an integer) will be exposed
84
            to tests under this environment variable name.
85
            """
86
        ),
87
    )
88
    config = FileOption(
3✔
89
        default=None,
90
        advanced=True,
91
        help=lambda cls: softwrap(
92
            f"""
93
            Path to a config file understood by Pytest
94
            (https://docs.pytest.org/en/latest/reference/customize.html#configuration-file-formats).
95
            Setting this option will disable `[{cls.options_scope}].config_discovery`. Use
96
            this option if the config is located in a non-standard location.
97
            """
98
        ),
99
    )
100
    config_discovery = BoolOption(
3✔
101
        default=True,
102
        advanced=True,
103
        help=lambda cls: softwrap(
104
            f"""
105
            If true, Pants will include all relevant Pytest config files (e.g. `pytest.ini`)
106
            during runs. See
107
            https://docs.pytest.org/en/stable/customize.html#finding-the-rootdir for where
108
            config files should be located for Pytest to discover them.
109

110
            Use `[{cls.options_scope}].config` instead if your config is in a
111
            non-standard location.
112
            """
113
        ),
114
    )
115
    xdist_enabled = BoolOption(
3✔
116
        default=False,
117
        advanced=False,
118
        help=softwrap(
119
            """
120
            If true, Pants will use `pytest-xdist` (https://pytest-xdist.readthedocs.io/en/latest/)
121
            to parallelize tests within each `python_test` target.
122

123
            NOTE: Enabling `pytest-xdist` can cause high-level scoped fixtures (for example `session`)
124
            to execute more than once. See the `pytest-xdist` docs for more info:
125
            https://pypi.org/project/pytest-xdist/#making-session-scoped-fixtures-execute-only-once
126
            """
127
        ),
128
    )
129

130
    skip = SkipOption("test")
3✔
131

132
    def config_request(self, dirs: Iterable[str]) -> ConfigFilesRequest:
3✔
133
        # Refer to https://docs.pytest.org/en/stable/customize.html#finding-the-rootdir for how
134
        # config files are discovered.
135
        check_existence = []
×
136
        check_content = {}
×
137
        for d in ("", *dirs):
×
138
            check_existence.append(os.path.join(d, "pytest.ini"))
×
139
            check_content[os.path.join(d, "pyproject.toml")] = b"[tool.pytest.ini_options]"
×
140
            check_content[os.path.join(d, "tox.ini")] = b"[pytest]"
×
141
            check_content[os.path.join(d, "setup.cfg")] = b"[tool:pytest]"
×
142

143
        return ConfigFilesRequest(
×
144
            specified=self.config,
145
            specified_option_name=f"[{self.options_scope}].config",
146
            discovery=self.config_discovery,
147
            check_existence=check_existence,
148
            check_content=check_content,
149
        )
150

151

152
def rules():
3✔
153
    return (
3✔
154
        *collect_rules(),
155
        UnionRule(ExportableTool, PyTest),
156
    )
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