From 084df810aed51ae4a3de9b352a57a9890d5e967d Mon Sep 17 00:00:00 2001 From: Samruddhi Khandale Date: Mon, 4 Mar 2024 11:36:03 -0800 Subject: [PATCH] Oryx: Clean up additional installation of .NET (#892) --- src/oryx/devcontainer-feature.json | 2 +- src/oryx/install.sh | 14 +++++++++----- test/oryx/install_dotnet_and_oryx.sh | 3 +++ 3 files changed, 13 insertions(+), 6 deletions(-) diff --git a/src/oryx/devcontainer-feature.json b/src/oryx/devcontainer-feature.json index fe13e2fcb..a075096bf 100644 --- a/src/oryx/devcontainer-feature.json +++ b/src/oryx/devcontainer-feature.json @@ -1,6 +1,6 @@ { "id": "oryx", - "version": "1.3.0", + "version": "1.3.1", "name": "Oryx", "description": "Installs the oryx CLI", "documentationURL": "https://github.com/devcontainers/features/tree/main/src/oryx", diff --git a/src/oryx/install.sh b/src/oryx/install.sh index f4c547fb5..407406141 100755 --- a/src/oryx/install.sh +++ b/src/oryx/install.sh @@ -86,7 +86,6 @@ install_dotnet_with_script() DOTNET_BINARY="dotnet" export PATH="${PATH}:/usr/share/dotnet" - DOTNET_BINARY_INSTALLATION="/usr/share/dotnet/sdk/${version}" } install_dotnet_using_apt() { @@ -146,7 +145,6 @@ usermod -a -G oryx "${USERNAME}" # Required to decide if we want to clean up dotnet later. DOTNET_INSTALLATION_PACKAGE="" -DOTNET_BINARY_INSTALLATION="" DOTNET_BINARY="" if dotnet --version > /dev/null ; then @@ -156,6 +154,7 @@ fi MAJOR_VERSION_ID=$(echo $(dotnet --version) | cut -d . -f 1) PATCH_VERSION_ID=$(echo $(dotnet --version) | cut -d . -f 3) +PINNED_SDK_VERSION="" # Oryx needs to be built with .NET 8 if [[ "${DOTNET_BINARY}" = "" ]] || [[ $MAJOR_VERSION_ID != "8" ]] || [[ $MAJOR_VERSION_ID = "8" && ${PATCH_VERSION_ID} -ge "101" ]] ; then echo "'dotnet 8' was not detected. Attempting to install .NET 8 to build oryx." @@ -182,7 +181,7 @@ mkdir -p ${ORYX} git clone --depth=1 https://github.com/microsoft/Oryx $GIT_ORYX -if [[ "${DOTNET_BINARY_INSTALLATION}" != "" ]]; then +if [[ "${PINNED_SDK_VERSION}" != "" ]]; then cd $GIT_ORYX dotnet new globaljson --sdk-version ${PINNED_SDK_VERSION} fi @@ -234,9 +233,14 @@ if [[ "${DOTNET_INSTALLATION_PACKAGE}" != "" ]]; then apt purge -yq $DOTNET_INSTALLATION_PACKAGE fi -if [[ "${DOTNET_BINARY_INSTALLATION}" != "" ]]; then +if [[ "${PINNED_SDK_VERSION}" != "" ]]; then rm -f ${GIT_ORYX}/global.json - rm -rf ${DOTNET_BINARY_INSTALLATION} + rm -rf /usr/share/dotnet/sdk/$PINNED_SDK_VERSION + + # Extract the major, minor version and the first digit of the patch version + MAJOR_MINOR_PATCH1_VERSION=${PINNED_SDK_VERSION%??} + rm -rf /usr/share/dotnet/shared/Microsoft.NETCore.App/$MAJOR_MINOR_PATCH1_VERSION + rm -rf /usr/share/dotnet/shared/Microsoft.AspNetCore.App/$MAJOR_MINOR_PATCH1_VERSION fi diff --git a/test/oryx/install_dotnet_and_oryx.sh b/test/oryx/install_dotnet_and_oryx.sh index da0a9162d..670d7565a 100644 --- a/test/oryx/install_dotnet_and_oryx.sh +++ b/test/oryx/install_dotnet_and_oryx.sh @@ -5,6 +5,9 @@ set -e # Optional: Import test library source dev-container-features-test-lib +# Runtimes are listed twice due to 'Microsoft.NETCore.App' and 'Microsoft.AspNetCore.App' +check "two versions of dotnet runtimes are present" bash -c "[ $(dotnet --list-runtimes | wc -l) -eq 4 ]" + check "Oryx version" oryx --version check "Dotnet is not removed if it is not installed by the Oryx Feature" dotnet --version