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

pantsbuild / pants / 24068485941

07 Apr 2026 06:52AM UTC coverage: 75.981% (-16.9%) from 92.908%
24068485941

Pull #23227

github

web-flow
Merge 7f50667e7 into 542ca048d
Pull Request #23227: Fix uv PEX builder to use pex3 lock export

0 of 12 new or added lines in 1 file covered. (0.0%)

11082 existing lines in 400 files now uncovered.

54018 of 71094 relevant lines covered (75.98%)

2.32 hits per line

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

83.33
/src/python/pants/util/requirements.py
1
# Copyright 2023 Pants project contributors (see CONTRIBUTORS.md).
2
# Licensed under the Apache License, Version 2.0 (see LICENSE).
3
from collections.abc import Iterator
5✔
4

5
from pants.util.pip_requirement import PipRequirement
5✔
6

7

8
def parse_requirements_file(content: str, *, rel_path: str) -> Iterator[PipRequirement]:
5✔
9
    """Parse all `PipRequirement` objects from a requirements.txt-style file.
10

11
    This will safely ignore any options starting with `--` and will ignore comments. Any pip-style
12
    VCS requirements will fail, with a helpful error message describing how to use PEP 440.
13
    """
14
    for i, line in enumerate(content.splitlines(), start=1):
2✔
15
        line, _, _ = line.partition("--")
2✔
16
        line = line.strip().rstrip("\\")
2✔
17
        if not line or line.startswith(("#", "-")):
2✔
UNCOV
18
            continue
×
19

20
        # Strip comments which are otherwise on a valid requirement line.
21
        comment_pos = line.find("#")
2✔
22
        if comment_pos != -1:
2✔
UNCOV
23
            line = line[0:comment_pos].strip()
×
24

25
        yield PipRequirement.parse(line, description_of_origin=f"{rel_path} at line {i}")
2✔
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