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

pantsbuild / pants / 25441711719

06 May 2026 02:31PM UTC coverage: 92.915%. Remained the same
25441711719

push

github

web-flow
use sha pin (with comment) format for generated actions (#23312)

Per the GitHub Action best practices we recently enabled at #23249, we
should pin each action to a SHA so that the reference is actually
immutable.

This will -- I hope -- knock out a large chunk of the 421 alerts we
currently get from zizmor. The next followup would then be upgrades and
harmonizing the generated and none-generated pins.

Notice: This idea was suggested by Claude while going over pinact output
and I was surprised to see that post processing the yaml wasn't too
gross.

92206 of 99237 relevant lines covered (92.91%)

4.04 hits per line

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

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

4
from __future__ import annotations
12✔
5

6
from dataclasses import dataclass
12✔
7

8
from pants.engine.fs import Digest, DigestSubset, FileDigest, FileEntry, PathGlobs
12✔
9
from pants.engine.intrinsics import digest_subset_to_digest, get_digest_entries
12✔
10
from pants.engine.rules import collect_rules, rule
12✔
11

12

13
@dataclass(frozen=True)
12✔
14
class ExtractFileDigest:
12✔
15
    digest: Digest
12✔
16
    file_path: str
12✔
17

18

19
@rule
12✔
20
async def digest_to_file_digest(request: ExtractFileDigest) -> FileDigest:
12✔
21
    digest = await digest_subset_to_digest(
12✔
22
        DigestSubset(request.digest, PathGlobs([request.file_path]))
23
    )
24
    digest_entries = await get_digest_entries(digest)
12✔
25

26
    if len(digest_entries) == 0:
12✔
27
        raise Exception(f"ExtractFileDigest: '{request.file_path}' not found in {request.digest}.")
1✔
28
    elif len(digest_entries) > 1:
12✔
29
        raise Exception(
1✔
30
            f"ExtractFileDigest: Unexpected error: '{request.file_path}' found multiple times in {request.digest}"
31
        )
32

33
    file_info = digest_entries[0]
12✔
34

35
    if not isinstance(file_info, FileEntry):
12✔
36
        raise AssertionError(
×
37
            f"Unexpected error: '{request.file_path}' refers to a directory, not a file."
38
        )
39

40
    return file_info.file_digest
12✔
41

42

43
def rules():
12✔
44
    return [*collect_rules()]
12✔
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