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

pantsbuild / pants / 21552830208

31 Jan 2026 11:40PM UTC coverage: 80.277% (-0.05%) from 80.324%
21552830208

Pull #23062

github

web-flow
Merge 808a9786c into 2c4dcf9cf
Pull Request #23062: Remove support for Get

18 of 25 new or added lines in 4 files covered. (72.0%)

17119 existing lines in 541 files now uncovered.

78278 of 97510 relevant lines covered (80.28%)

3.36 hits per line

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

100.0
/src/python/pants/backend/docker/lint/hadolint/rules_integration_test.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
3✔
5

6
from textwrap import dedent
3✔
7
from typing import Any
3✔
8

9
import pytest
3✔
10

11
from pants.backend.docker.lint.hadolint.rules import HadolintFieldSet, HadolintRequest
3✔
12
from pants.backend.docker.lint.hadolint.rules import rules as hadolint_rules
3✔
13
from pants.backend.docker.rules import rules as docker_rules
3✔
14
from pants.backend.docker.target_types import DockerImageTarget
3✔
15
from pants.core.goals import package
3✔
16
from pants.core.goals.lint import LintResult, Partitions
3✔
17
from pants.core.util_rules import config_files, external_tool, source_files
3✔
18
from pants.engine.addresses import Address
3✔
19
from pants.engine.target import Target
3✔
20
from pants.testutil.rule_runner import QueryRule, RuleRunner
3✔
21

22

23
@pytest.fixture
3✔
24
def rule_runner() -> RuleRunner:
3✔
25
    return RuleRunner(
3✔
26
        rules=[
27
            *config_files.rules(),
28
            *docker_rules(),
29
            *external_tool.rules(),
30
            *hadolint_rules(),
31
            *package.rules(),
32
            *source_files.rules(),
33
            QueryRule(Partitions, [HadolintRequest.PartitionRequest]),
34
            QueryRule(LintResult, [HadolintRequest.Batch]),
35
        ],
36
        target_types=[DockerImageTarget],
37
    )
38

39

40
GOOD_FILE = "FROM python:3.8"
3✔
41
BAD_FILE = "FROM python"
3✔
42

43

44
def run_hadolint(
3✔
45
    rule_runner: RuleRunner, targets: list[Target], *, extra_args: list[str] | None = None
46
) -> tuple[LintResult, ...]:
47
    rule_runner.set_options(
3✔
48
        extra_args or (),
49
        env_inherit={"PATH"},
50
    )
51
    partitions = rule_runner.request(
3✔
52
        Partitions[HadolintFieldSet, Any],
53
        [HadolintRequest.PartitionRequest(tuple(HadolintFieldSet.create(tgt) for tgt in targets))],
54
    )
55
    results = []
3✔
56
    for partition in partitions:
3✔
57
        result = rule_runner.request(
3✔
58
            LintResult,
59
            [HadolintRequest.Batch("", partition.elements, partition.metadata)],
60
        )
61
        results.append(result)
3✔
62
    return tuple(results)
3✔
63

64

65
def assert_success(
3✔
66
    rule_runner: RuleRunner, target: Target, *, extra_args: list[str] | None = None
67
) -> None:
UNCOV
68
    result = run_hadolint(rule_runner, [target], extra_args=extra_args)
1✔
UNCOV
69
    assert len(result) == 1
1✔
UNCOV
70
    assert result[0].exit_code == 0
1✔
UNCOV
71
    assert not result[0].stdout
1✔
UNCOV
72
    assert not result[0].stderr
1✔
73

74

75
def test_passing(rule_runner: RuleRunner) -> None:
3✔
UNCOV
76
    rule_runner.write_files({"Dockerfile": GOOD_FILE, "BUILD": "docker_image(name='t')"})
1✔
UNCOV
77
    tgt = rule_runner.get_target(Address("", target_name="t"))
1✔
UNCOV
78
    assert_success(rule_runner, tgt)
1✔
79

80

81
@pytest.mark.platform_specific_behavior
3✔
82
def test_failing(rule_runner: RuleRunner) -> None:
3✔
83
    rule_runner.write_files({"Dockerfile": BAD_FILE, "BUILD": "docker_image(name='t')"})
3✔
84
    tgt = rule_runner.get_target(Address("", target_name="t"))
3✔
85
    result = run_hadolint(rule_runner, [tgt])
3✔
86
    assert len(result) == 1
3✔
87
    assert result[0].exit_code == 1
3✔
88
    assert "Dockerfile:1 " in result[0].stdout
3✔
89

90

91
def test_multiple_targets(rule_runner: RuleRunner) -> None:
3✔
UNCOV
92
    rule_runner.write_files(
1✔
93
        {
94
            "Dockerfile.good": GOOD_FILE,
95
            "Dockerfile.bad": BAD_FILE,
96
            "BUILD": dedent(
97
                """
98
                docker_image(name="good", source="Dockerfile.good")
99
                docker_image(name="bad", source="Dockerfile.bad")
100
                """
101
            ),
102
        }
103
    )
UNCOV
104
    tgts = [
1✔
105
        rule_runner.get_target(
106
            Address("", target_name="good", relative_file_path="Dockerfile.good")
107
        ),
108
        rule_runner.get_target(Address("", target_name="bad", relative_file_path="Dockerfile.bad")),
109
    ]
UNCOV
110
    result = run_hadolint(rule_runner, tgts)
1✔
UNCOV
111
    assert len(result) == 1
1✔
UNCOV
112
    assert result[0].exit_code == 1
1✔
UNCOV
113
    assert "Dockerfile.good" not in result[0].stdout
1✔
UNCOV
114
    assert "Dockerfile.bad:1 " in result[0].stdout
1✔
115

116

117
def test_config_files(rule_runner: RuleRunner) -> None:
3✔
UNCOV
118
    rule_runner.write_files(
1✔
119
        {
120
            ".hadolint.yaml": "ignored: [DL3006, DL3061, DL3011]",
121
            "a/Dockerfile": BAD_FILE,
122
            "a/BUILD": "docker_image()",
123
            "b/Dockerfile": BAD_FILE,
124
            "b/BUILD": "docker_image()",
125
            "c/BUILD": "docker_image()",
126
            "c/Dockerfile": "EXPOSE 123456",
127
        }
128
    )
UNCOV
129
    tgts = [
1✔
130
        rule_runner.get_target(Address("a")),
131
        rule_runner.get_target(Address("b")),
132
    ]
UNCOV
133
    result = run_hadolint(rule_runner, tgts)
1✔
UNCOV
134
    assert len(result) == 1
1✔
UNCOV
135
    assert result[0].exit_code == 0
1✔
UNCOV
136
    assert "a/Dockerfile" not in result[0].stdout
1✔
UNCOV
137
    assert "b/Dockerfile " not in result[0].stdout
1✔
138

UNCOV
139
    tgt = rule_runner.get_target(Address("c"))
1✔
UNCOV
140
    assert_success(rule_runner, tgt, extra_args=["--hadolint-config=.hadolint.yaml"])
1✔
141

142

143
def test_passthrough_args(rule_runner: RuleRunner) -> None:
3✔
UNCOV
144
    rule_runner.write_files({"Dockerfile": BAD_FILE, "BUILD": "docker_image(name='t')"})
1✔
UNCOV
145
    tgt = rule_runner.get_target(Address("", target_name="t"))
1✔
UNCOV
146
    assert_success(rule_runner, tgt, extra_args=["--hadolint-args=--ignore DL3006"])
1✔
147

148

149
def test_skip(rule_runner: RuleRunner) -> None:
3✔
UNCOV
150
    rule_runner.write_files({"Dockerfile": BAD_FILE, "BUILD": "docker_image(name='t')"})
1✔
UNCOV
151
    tgt = rule_runner.get_target(Address("", target_name="t"))
1✔
UNCOV
152
    result = run_hadolint(rule_runner, [tgt], extra_args=["--hadolint-skip"])
1✔
UNCOV
153
    assert not result
1✔
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