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

pantsbuild / pants / 18827312341

27 Oct 2025 01:50AM UTC coverage: 65.106% (-15.2%) from 80.279%
18827312341

Pull #22806

github

web-flow
Merge 082bdd4c2 into 170094e99
Pull Request #22806: Updated Javascript dependencies and re-locked

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

8118 existing lines in 291 files now uncovered.

48695 of 74793 relevant lines covered (65.11%)

1.81 hits per line

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

70.83
/src/python/pants/backend/nfpm/fields/scripts.py
1
# Copyright 2023 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
3✔
7
from typing import ClassVar
3✔
8

9
from pants.engine.internals.native_engine import Address
3✔
10
from pants.engine.target import AsyncFieldMixin, DictStringToStringField, InvalidFieldException
3✔
11
from pants.util.frozendict import FrozenDict
3✔
12

13

14
class NfpmPackageScriptsField(AsyncFieldMixin, DictStringToStringField):
3✔
15
    nfpm_alias = ""  # maps to more than one nfpm.yaml field
3✔
16
    alias: ClassVar[str] = "scripts"
3✔
17
    # The keys of nfpm_aliases are the only valid keys of this field.
18
    nfpm_aliases: ClassVar[FrozenDict[str, str]] = FrozenDict(
3✔
19
        {
20
            # The general scripts common to all packager types
21
            "preinstall": "scripts.preinstall",
22
            "postinstall": "scripts.postinstall",
23
            "preremove": "scripts.preremove",
24
            "postremove": "scripts.postremove",
25
        }
26
    )
27

28
    @classmethod
3✔
29
    def compute_value(
3✔
30
        cls, raw_value: dict[str, str] | None, address: Address
31
    ) -> FrozenDict[str, str] | None:
32
        value_or_default = super().compute_value(raw_value, address)
1✔
33
        if value_or_default:
1✔
UNCOV
34
            invalid_keys = value_or_default.keys() - cls.nfpm_aliases.keys()
×
UNCOV
35
            if invalid_keys:
×
36
                raise InvalidFieldException(
×
37
                    f"Each key for the '{cls.alias}' field in target {address} must be one of"
38
                    f"{repr(tuple(cls.nfpm_aliases.keys()))}, but {repr(invalid_keys)} was provided.",
39
                )
40
        return value_or_default
1✔
41

42
    @property
3✔
43
    def normalized_value(self) -> FrozenDict[str, str]:
3✔
UNCOV
44
        value = self.value
×
UNCOV
45
        if not value:
×
46
            return FrozenDict()
×
UNCOV
47
        return FrozenDict(
×
48
            {
49
                script_type: os.path.join(self.address.spec_path, script_src)
50
                for script_type, script_src in value.items()
51
            }
52
        )
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