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

pantsbuild / pants / 19015773527

02 Nov 2025 05:33PM UTC coverage: 17.872% (-62.4%) from 80.3%
19015773527

Pull #22816

github

web-flow
Merge a12d75757 into 6c024e162
Pull Request #22816: Update Pants internal Python to 3.14

4 of 5 new or added lines in 3 files covered. (80.0%)

28452 existing lines in 683 files now uncovered.

9831 of 55007 relevant lines covered (17.87%)

0.18 hits per line

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

0.0
/src/python/pants/backend/docker/util_rules/docker_build_args.py
1
# Copyright 2021 Pants project contributors (see CONTRIBUTORS.md).
2
# Licensed under the Apache License, Version 2.0 (see LICENSE).
3

UNCOV
4
from __future__ import annotations
×
5

UNCOV
6
from dataclasses import dataclass
×
7

UNCOV
8
from pants.backend.docker.subsystems.docker_options import DockerOptions
×
UNCOV
9
from pants.backend.docker.target_types import DockerImageBuildArgsField
×
UNCOV
10
from pants.backend.docker.utils import KeyValueSequenceUtil
×
UNCOV
11
from pants.engine.rules import collect_rules, rule
×
UNCOV
12
from pants.engine.target import Target
×
13

14

UNCOV
15
class DockerBuildArgs(KeyValueSequenceUtil):
×
16
    """Collection of arguments to pass to a Docker build."""
17

UNCOV
18
    def nonempty(self) -> dict[str, str]:
×
19
        return {k: v for k, v in self.to_dict().items() if v}
×
20

UNCOV
21
    def with_overrides(self, overrides: DockerBuildArgs) -> DockerBuildArgs:
×
22
        """Override the values in this collection.
23

24
        Will not extend with keys in overrides which do not exist in this collection.
25
        """
26
        overrides_dict = overrides.to_dict()
×
27
        return DockerBuildArgs.from_dict(
×
28
            {k: overrides_dict.get(k, v) for k, v in self.to_dict().items()}
29
        )
30

UNCOV
31
    def extended(self, more: DockerBuildArgs | list[str]) -> DockerBuildArgs:
×
32
        """Create a new DockerBuildArgs out of this and a list of strs to add."""
33
        if isinstance(more, DockerBuildArgs):
×
34
            return DockerBuildArgs.from_strings(*self, *more)
×
35
        else:
36
            return DockerBuildArgs.from_strings(*self, *more)
×
37

38

UNCOV
39
@dataclass(frozen=True)
×
UNCOV
40
class DockerBuildArgsRequest:
×
UNCOV
41
    target: Target
×
42

43

UNCOV
44
@rule
×
UNCOV
45
async def docker_build_args(
×
46
    request: DockerBuildArgsRequest, docker_options: DockerOptions
47
) -> DockerBuildArgs:
48
    return DockerBuildArgs.from_strings(
×
49
        *docker_options.build_args,
50
        *(request.target.get(DockerImageBuildArgsField).value or ()),
51
    )
52

53

UNCOV
54
def rules():
×
UNCOV
55
    return collect_rules()
×
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