From 74981a2315e6d78cda5f5f81615680f027df25d0 Mon Sep 17 00:00:00 2001 From: Julien Poissonnier Date: Mon, 16 Dec 2024 11:06:24 +0100 Subject: [PATCH] Add uv to images that include Python Now that the Pulumi CLI supports uv out of the box, include it in the docker images. Fixes https://github.com/pulumi/pulumi-docker-containers/issues/340 --- docker/pulumi/Dockerfile | 4 ++++ docker/python/Dockerfile | 5 +++++ docker/python/Dockerfile.ubi | 5 +++++ tests/containers_test.go | 10 +++++++++- 4 files changed, 23 insertions(+), 1 deletion(-) diff --git a/docker/pulumi/Dockerfile b/docker/pulumi/Dockerfile index e0be5192..0147a4cc 100644 --- a/docker/pulumi/Dockerfile +++ b/docker/pulumi/Dockerfile @@ -146,6 +146,10 @@ RUN ln -s /usr/local/share/pypoetry/bin/poetry /usr/local/bin/ # Set poetry to prefer the active python version so it interacts nicely with pyenv, otherwise # poetry will create virtual environments using the python version used by poetry itself. RUN poetry config virtualenvs.prefer-active-python true +# Install uv +RUN curl -LsSf https://astral.sh/uv/install.sh | XDG_BIN_HOME=/usr/local/share/uv bash -s -- --no-modify-path +RUN ln -s /usr/local/share/uv/uv /usr/local/bin/ +RUN ln -s /usr/local/share/uv/uvx /usr/local/bin/ # Install default nodejs versions and associated tools RUN curl -fsSL https://fnm.vercel.app/install | bash -s -- --install-dir "/usr/local/share/fnm" --skip-shell && \ diff --git a/docker/python/Dockerfile b/docker/python/Dockerfile index 136228a8..cd0fb80e 100644 --- a/docker/python/Dockerfile +++ b/docker/python/Dockerfile @@ -31,6 +31,11 @@ RUN apt-get update -y && \ RUN curl -sSL https://install.python-poetry.org | POETRY_HOME=/usr/local/share/pypoetry python3 - RUN ln -s /usr/local/share/pypoetry/bin/poetry /usr/local/bin/ +# Install uv +RUN curl -LsSf https://astral.sh/uv/install.sh | XDG_BIN_HOME=/usr/local/share/uv bash -s -- --no-modify-path +RUN ln -s /usr/local/share/uv/uv /usr/local/bin/ +RUN ln -s /usr/local/share/uv/uvx /usr/local/bin/ + # Uses the workdir, copies from pulumi interim container COPY --from=builder /root/.pulumi/bin/pulumi /pulumi/bin/pulumi COPY --from=builder /root/.pulumi/bin/*-python* /pulumi/bin/ diff --git a/docker/python/Dockerfile.ubi b/docker/python/Dockerfile.ubi index bf08119a..461cc833 100644 --- a/docker/python/Dockerfile.ubi +++ b/docker/python/Dockerfile.ubi @@ -49,6 +49,11 @@ RUN pyenv global ${LANGUAGE_VERSION} RUN curl -sSL https://install.python-poetry.org | POETRY_HOME=/usr/local/share/pypoetry python3 - RUN ln -s /usr/local/share/pypoetry/bin/poetry /usr/local/bin/ +# Install uv +RUN curl -LsSf https://astral.sh/uv/install.sh | XDG_BIN_HOME=/usr/local/share/uv bash -s -- --no-modify-path +RUN ln -s /usr/local/share/uv/uv /usr/local/bin/ +RUN ln -s /usr/local/share/uv/uvx /usr/local/bin/ + # Uses the workdir, copies from pulumi interim container COPY --from=builder /root/.pulumi/bin/pulumi /pulumi/bin/pulumi COPY --from=builder /root/.pulumi/bin/*-python* /pulumi/bin/ diff --git a/tests/containers_test.go b/tests/containers_test.go index a4b05a5c..8536300a 100644 --- a/tests/containers_test.go +++ b/tests/containers_test.go @@ -305,8 +305,16 @@ func TestEnvironment(t *testing.T) { poetryPath, err := exec.LookPath("poetry") require.NoError(t, err) require.Equal(t, expectedPoetryPath, poetryPath) - // Use bash `command` builtin to lookup the path to python + // Use bash `command` builtin to lookup the path to poetry requireOutputWithBash(t, expectedPoetryPath, "command", "-v", "poetry") + + // uvy should be available + expectedUvPath := "/usr/local/bin/uv" + uvPath, err := exec.LookPath("uv") + require.NoError(t, err) + require.Equal(t, expectedUvPath, uvPath) + // Use bash `command` builtin to lookup the path to uv + requireOutputWithBash(t, expectedPoetryPath, "command", "-v", "uv") }) t.Run("Node", func(t *testing.T) {