You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
TL;DR: Trying to build a multi stage Docker build with using a <image>[@<digest>] instead of <image>[:<tag>] results in a pants error. There is a workaround though, see "Additional info" below.
I have a Dockerfile with the following FROM stages:
❯ grep FROM src/docker/u21repr/Dockerfile
FROM golang:1.23-bookworm AS builder
FROM gcr.io/distroless/python3-debian12@sha256:8e432c787b5c0697dfbfd783120351d90fd5f23ba9fff29532bbdbb87bc13160 AS runtime
FROM gcr.io/distroless/python3-debian12:debug AS upstream_debug
FROM runtime AS debug
FROM debug AS smoke_tests
❯
Trying to build this with pants results in the following error:
❯ pants --docker-build-verbose package src/docker/u21repr:runtime
09:08:08.03 [ERROR] 1 Exception encountered:
Engine traceback:
in `package` goal
DockerBuildTargetStageError: The 'target_stage' field in `docker_image` src/docker/u21repr:runtime was set to 'runtime', but there is no such stage in `src/docker/u21repr/Dockerfile`. Available stages: builder, debug, smoke_tests, upstream_debug.
❯
The docker_image() target in the BUILD file looks like:
@huonw did show me a workaround that I didn't know works with Docker. Apparently, if you insert a tag and then the sha digest, Docker ignores the tag and pulls the image with sha digest. This works for docker pull as well as in the pants build.
If I change the line FROM gcr.io/distroless/python3-debian12@sha256:8e432c787b5c0697dfbfd783120351d90fd5f23ba9fff29532bbdbb87bc13160 AS runtime
to FROM gcr.io/distroless/python3-debian12:totally_made_up_not_a_real_tag@sha256:8e432c787b5c0697dfbfd783120351d90fd5f23ba9fff29532bbdbb87bc13160 AS runtime, the build works again.
The text was updated successfully, but these errors were encountered:
Looks like this is an oversight in our parser. It only lists stages that have a tag. (I think the logic is that if it can't find a tag, it's an image reference. We just didn't consider references without a tag but with a sha).
As far as I can tell, the only place that we use the version tags is to get the stage tags, splitting the {stage} {tag} formatting to get just {stage}:
As such, I wonder if we can/should refactor the parsing code to just extract the stages, and not bother with the tags (since that seems to be unused anyway), and then this "automatically" works.
Describe the bug
TL;DR: Trying to build a multi stage Docker build with using a
<image>[@<digest>]
instead of<image>[:<tag>]
results in a pants error. There is a workaround though, see "Additional info" below.I have a Dockerfile with the following
FROM
stages:Trying to build this with pants results in the following error:
The
docker_image()
target in theBUILD
file looks like:runtime
FROM
line works.runtime
tofoobar
in both theBUILD
andDockerfile
results in the same error (but it can't findfoobar
instead ofruntime
)Pants version
2.23.1
OS
Tested on macOS.
Additional info
Workaround
@huonw did show me a workaround that I didn't know works with Docker. Apparently, if you insert a tag and then the sha digest, Docker ignores the tag and pulls the image with sha digest. This works for
docker pull
as well as in the pants build.If I change the line
FROM gcr.io/distroless/python3-debian12@sha256:8e432c787b5c0697dfbfd783120351d90fd5f23ba9fff29532bbdbb87bc13160 AS runtime
to
FROM gcr.io/distroless/python3-debian12:totally_made_up_not_a_real_tag@sha256:8e432c787b5c0697dfbfd783120351d90fd5f23ba9fff29532bbdbb87bc13160 AS runtime
, the build works again.The text was updated successfully, but these errors were encountered: