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

pantsbuild / pants / 22248361083

21 Feb 2026 02:10AM UTC coverage: 84.582% (+4.2%) from 80.369%
22248361083

Pull #22816

github

web-flow
Merge da0a2d128 into 2317206eb
Pull Request #22816: Update Pants internal Python to 3.14

41 of 41 new or added lines in 7 files covered. (100.0%)

4284 existing lines in 182 files now uncovered.

69299 of 81931 relevant lines covered (84.58%)

2.8 hits per line

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

90.91
/src/python/pants/core/goals/resolves.py
1
# Copyright 2024 Pants project contributors (see CONTRIBUTORS.md).
2
# Licensed under the Apache License, Version 2.0 (see LICENSE).
3
from __future__ import annotations
7✔
4

5
from enum import Enum
7✔
6
from typing import TypeVar
7✔
7

8
from pants.engine.unions import UnionMembership, union
7✔
9
from pants.util.strutil import softwrap
7✔
10

11
T = TypeVar("T", bound="ExportableTool")
7✔
12

13

14
class ExportMode(Enum):
7✔
15
    """How this tool should be exported.
16

17
    resolve: in a language-based resolve
18
    binary: as a single binary
19
    """
20

21
    resolve = "resolve"
7✔
22
    binary = "binary"
7✔
23

24

25
@union
7✔
26
class ExportableTool:
7✔
27
    """Mark a subsystem as exportable.
28

29
    Using this class has 2 parts:
30
    - The tool class should subclass this.
31
      This can be done at the language-backend level, for example, `PythonToolRequirementsBase`.
32
      The help message can be extended with instructions specific to that tool or language backend
33
    - Each exportable tool should have a `UnionRule` to `ExportableTool`.
34
      This `UnionRule` is what ties the class into the export machinery.
35
    """
36

37
    options_scope: str
7✔
38
    export_mode: ExportMode = ExportMode.resolve
7✔
39

40
    @classmethod
7✔
41
    def help_for_generate_lockfile_with_default_location(cls, resolve_name: str):
7✔
42
        """If this tool is configured to use the default lockfile, but a user requests to regenerate
43
        it, this help text will be shown to the user."""
44

UNCOV
45
        resolve = resolve_name
×
UNCOV
46
        return softwrap(
×
47
            f"""
48
            You requested to generate a lockfile for {resolve} because
49
            you included it in `--generate-lockfiles-resolve`, but
50
            {resolve} is a tool using its default lockfile.
51
        """
52
        )
53

54
    @staticmethod
7✔
55
    def filter_for_subclasses(
7✔
56
        union_membership: UnionMembership, parent_class: type[T]
57
    ) -> dict[str, type[T]]:
58
        """Find all ExportableTools that are members of `parent_class`.
59

60
        Language backends can use this to obtain all tools they can export.
61
        """
62
        exportable_tools = union_membership.get(ExportableTool)
4✔
63
        relevant_tools: dict[str, type[T]] = {
4✔
64
            e.options_scope: e  # type: ignore # mypy isn't narrowing with `issubclass`
65
            for e in exportable_tools
66
            if issubclass(e, parent_class)
67
        }
68
        return relevant_tools
4✔
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