mirror of
https://gitea.com/Lydanne/buildx.git
synced 2025-10-24 20:53:49 +08:00

When running `--invoke` against images that have `Cmd` set, the interactions with `Entrypoint` start to cause issues like the following: /usr/local/bin/bash: /usr/local/bin/bash: cannot execute binary file Or: sh: can't open 'bash': No such file or directory This patch fixes those by explicitly setting `Cmd` to be empty if it is unspecified and `Entrypoint` is being set, which matches `docker`'s behavior: $ docker image inspect --format '{{ json .Config.Entrypoint }} + {{ json .Config.Cmd }}' bash ["docker-entrypoint.sh"] + ["bash"] $ docker create --name foo --entrypoint bash bash $ docker container inspect --format '{{ json .Config.Entrypoint }} + {{ json .Config.Cmd }}' foo ["bash"] + null $ docker rm foo $ docker create --name foo bash ls $ docker container inspect --format '{{ json .Config.Entrypoint }} + {{ json .Config.Cmd }}' foo ["docker-entrypoint.sh"] + ["ls"] (There are still some weird edge cases in the interaction between the `InvokeConfig` and the original image config, but this fixes the most irritating for me and the rest are going to be deeper changes that are possibly less acceptable. 😅) Signed-off-by: Tianon Gravi <admwiggin@gmail.com>