Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

--getProperty:GeneratedContainerConfiguration no longer returns a value in SDK 9.0.102 when running dotnet publish #46176

Closed
sgtwilko opened this issue Jan 21, 2025 · 4 comments
Assignees
Labels
Area-NetSDK untriaged Request triage from a team member

Comments

@sgtwilko
Copy link

Describe the bug

when running dotnet publish /t:PublishContainer --getProperty:GeneratedContainerConfiguration in SDK version 9.0.102 we no longer get the Generated Container Confioguration.

To Reproduce

This is a project that I created via Visual Studio, first by creating a new ".NET Aspire Empty App", then by adding a new "ASP.NET Core Web API"

They were created with the defaults.

Image

The main branch on this Repo has the issue, the branch than pins the SDK to 9.0.100 works:
https://github.com/sgtwilko/AspirePublishFail

Navigate to the API folder then run dotnet publish /t:PublishContainer --getProperty:GeneratedContainerConfiguration.
The expected result is that this should create the container and output the GeneratedContainerConfiguration JSON.

e.g.,
{"config":{"ExposedPorts":{"8081/tcp":{},"8080/tcp":{}},"Labels":{"org.opencontainers.image.created":"2025-01-21T20:07:29.9464506Z","org.opencontainers.artifact.created":"2025-01-21T20:07:29.9464506Z","org.opencontainers.image.authors":"API","org.opencontainers.image.version":"1.0.0","org.opencontainers.image.base.name":"mcr.microsoft.com/dotnet/aspnet:9.0","net.dot.runtime.majorminor":"9.0","net.dot.sdk.version":"9.0.100","org.opencontainers.image.base.digest":"sha256:7727802f88bca73801af5893aae427bfb224aa0aee548a2f11d0588a7c8051b0"},"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","APP_UID=1654","ASPNETCORE_HTTP_PORTS=8080","DOTNET_RUNNING_IN_CONTAINER=true","DOTNET_VERSION=9.0.1","ASPNET_VERSION=9.0.1"],"WorkingDir":"/app/","Entrypoint":["dotnet","/app/API.dll"],"User":"1654"},"created":"2025-01-21T20:07:34.8710169Z","rootfs":{"type":"layers","diff_ids":["sha256:f5fe472da25334617e6e6467c7ebce41e0ae5580e5bd0ecbf0d573bacd560ecb","sha256:3b245d6409b15cc3cdbf18f27a61f750658af563e84b12f56a8b6598e86d8f80","sha256:d54764d9a8e78543560e1955621562a2faa3e96d5416c7fd142ba361d8cf3b8b","sha256:5479f1788e9874e467fa5511631e14a7587d238ba96f021a2e20c91c3ea84d17","sha256:c9aaa778af8e50ea31b20382c73765cc9c35aad88390a113d0926c75f8b8049b","sha256:064dc71a19783132de5df1a206094f1079a5613b2bcf09e70b7e98f06fd7f870","sha256:50e5dbf7ccd0ece4be241688ed0624eaa52490f54214badf266a8e3e0465df72"]},"architecture":"amd64","os":"linux","history":[{"comment":"debuerreotype 0.15","created":"2025-01-13T00:00:00.0000000Z","created_by":"# debian.sh --arch \u0027amd64\u0027 out/ \u0027bookworm\u0027 \u0027@1736726400\u0027"},{"comment":"buildkit.dockerfile.v0","created":"2025-01-14T19:01:04.3623446Z","created_by":"ENV APP_UID=1654 ASPNETCORE_HTTP_PORTS=8080 DOTNET_RUNNING_IN_CONTAINER=true","empty_layer":true},{"comment":"buildkit.dockerfile.v0","created":"2025-01-14T19:01:04.3623446Z","created_by":"RUN /bin/sh -c apt-get update     \u0026\u0026 apt-get install -y --no-install-recommends         ca-certificates                 libc6         libgcc-s1         libicu72         libssl3         libstdc\u002B\u002B6         tzdata     \u0026\u0026 rm -rf /var/lib/apt/lists/* # buildkit"},{"comment":"buildkit.dockerfile.v0","created":"2025-01-14T19:01:05.6634383Z","created_by":"RUN /bin/sh -c groupadd         --gid=$APP_UID         app     \u0026\u0026 useradd -l         --uid=$APP_UID         --gid=$APP_UID         --create-home         app # buildkit"},{"comment":"buildkit.dockerfile.v0","created":"2025-01-14T19:01:13.1156164Z","created_by":"ENV DOTNET_VERSION=9.0.1","empty_layer":true},{"comment":"buildkit.dockerfile.v0","created":"2025-01-14T19:01:13.1156164Z","created_by":"COPY /dotnet /usr/share/dotnet # buildkit"},{"comment":"buildkit.dockerfile.v0","created":"2025-01-14T19:01:13.9707628Z","created_by":"RUN /bin/sh -c ln -s /usr/share/dotnet/dotnet /usr/bin/dotnet # buildkit"},{"comment":"buildkit.dockerfile.v0","created":"2025-01-14T19:01:23.2680816Z","created_by":"ENV ASPNET_VERSION=9.0.1","empty_layer":true},{"comment":"buildkit.dockerfile.v0","created":"2025-01-14T19:01:23.2680816Z","created_by":"COPY /shared/Microsoft.AspNetCore.App /usr/share/dotnet/shared/Microsoft.AspNetCore.App # buildkit"},{"author":".NET SDK","created":"2025-01-21T20:07:34.8709659Z","created_by":".NET SDK Container Tooling, version 9.0.100-rtm.24529.9\u002B59db016f11bb27d359336cf37524b863d77e7fea"}]}
On the latest 9.0.102 the command finishes running without erroring, but fails return the `GeneratedContainerConfiguration` JSON.

This will cause azd up, azd deploy to fail.

If you use SDK 9.0.100 (see the sdk9.0.100 branch) this works and returns the JSON that is expected from GeneratedContainerConfiguration.
I haven't tried 9.0.101, so not sure it was introduced in 101, or 102.

Exceptions (if any)

Further technical details

  • Include the output of dotnet --info
.NET SDK:
 Version:           9.0.100
 Commit:            59db016f11
 Workload version:  9.0.100-manifests.4a54b1a6
 MSBuild version:   17.12.7+5b8665660

Runtime Environment:
 OS Name:     Windows
 OS Version:  10.0.22631
 OS Platform: Windows
 RID:         win-x64
 Base Path:   C:\Program Files\dotnet\sdk\9.0.100\

.NET workloads installed:
 [aspire]
   Installation Source: VS 17.12.35707.178
   Manifest Version:    8.2.2/8.0.100
   Manifest Path:       C:\Program Files\dotnet\sdk-manifests\8.0.100\microsoft.net.sdk.aspire\8.2.2\WorkloadManifest.json
   Install Type:              Msi

Configured to use loose manifests when installing new manifests.

Host:
  Version:      9.0.1
  Architecture: x64
  Commit:       c8acea2262

.NET SDKs installed:
  6.0.321 [C:\Program Files\dotnet\sdk]
  8.0.112 [C:\Program Files\dotnet\sdk]
  8.0.206 [C:\Program Files\dotnet\sdk]
  8.0.308 [C:\Program Files\dotnet\sdk]
  8.0.405 [C:\Program Files\dotnet\sdk]
  9.0.100 [C:\Program Files\dotnet\sdk]
  9.0.102 [C:\Program Files\dotnet\sdk]

.NET runtimes installed:
  Microsoft.AspNetCore.App 3.1.32 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.AspNetCore.App 5.0.17 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.AspNetCore.App 6.0.26 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.AspNetCore.App 6.0.36 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.AspNetCore.App 7.0.20 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.AspNetCore.App 8.0.6 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.AspNetCore.App 8.0.12 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.AspNetCore.App 9.0.0 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.AspNetCore.App 9.0.1 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.NETCore.App 3.1.32 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 5.0.17 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 6.0.15 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 6.0.26 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 6.0.36 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 7.0.20 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 8.0.6 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 8.0.12 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 9.0.0 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.NETCore.App 9.0.1 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.WindowsDesktop.App 3.1.32 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 5.0.17 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 6.0.15 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 6.0.26 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 6.0.36 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 7.0.20 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 8.0.6 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 8.0.12 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 9.0.0 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
  Microsoft.WindowsDesktop.App 9.0.1 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]

Other architectures found:
  x86   [C:\Program Files (x86)\dotnet]
    registered at [HKLM\SOFTWARE\dotnet\Setup\InstalledVersions\x86\InstallLocation]

Environment variables:
  Not set

global.json file:
  C:\Users\Ian.Wilkinson\GitHub\AspirePublishIssue\AspireSampleVS\AspireApp1\global.json

Learn more:
  https://aka.ms/dotnet/info

Download .NET:
  https://aka.ms/dotnet/download
  • The IDE (VS / VS Code/ VS4Mac) you're running on, and its version
    Visual Studio 17.12.4
@dotnet-issue-labeler dotnet-issue-labeler bot added Area-NetSDK untriaged Request triage from a team member labels Jan 21, 2025
@baronfel
Copy link
Member

I see your repro project has RuntimeIdentifiers instead of RuntimeIdentifier, so I suspect you are hitting #46053 - there's a bug in 9.0.102 that is making the container tooling always publish for multiple RuntimeIdentifiers if RuntimeIdentifiers is present, regardless of if RuntimeIdentifier is set. When publishing multiple containers, the GeneratedContainerConfiguration Property is no longer present - instead the GeneratedContainers Item is provided that contains much of the same information.

For now, I would suggest pinning to 9.0.101 at the latest - we expect 9.0.103 in February to fix this regression.

@sgtwilko
Copy link
Author

Hi @baronfel

Thanks that makes sense.
I did spot the multiple containers being generated, and thought that might have something to do with it.
The repo project is just using the VS defaults for Aspire, so had thought it to be fairly safe.

Just as an FYI, #46053 is causing Azure/azure-dev#4713 as azd is no longer able to publish due to the missing GeneratedContainerConfiguration

@Forgind
Copy link
Member

Forgind commented Jan 28, 2025

Looks like baronfel fixed this already, so this can be closed as completed?

@baronfel
Copy link
Member

yep!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area-NetSDK untriaged Request triage from a team member
Projects
None yet
Development

No branches or pull requests

3 participants