-
-
Notifications
You must be signed in to change notification settings - Fork 292
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
DockerImageNotFoundException to pull images #666
Comments
What does |
@HofmeisterAn "npipe://./pipe/docker_engine" |
We need the logs, to see if it picks up a Docker registry configuration and if it starts to pull an image at all (log level trace). |
Using this project https://github.com/lucasteles/nuke-testcontainers/tree/pull-bug ❯ dotnet run --project src
info: Program[0] *********** Begin Test **********
info: Program[0] Searching Docker registry credential in Auths
info: Program[0] Searching Docker registry credential in Auths
info: Program[0] Searching Docker registry credential in CredsStore
info: Program[0] Searching Docker registry credential in CredHelpers
info: Program[0] Docker registry credential index.docker.io found
info: Program[0] Docker image testcontainers/ryuk:0.3.4 created
Unhandled exception. Docker.DotNet.DockerImageNotFoundException: Docker API responded with status code=NotFound, response={"message":"No such image: testcontainers/ryuk:0.3.4"}
at Docker.DotNet.ContainerOperations.<>c.<.cctor>b__30_1(HttpStatusCode statusCode, String responseBody)
at Docker.DotNet.DockerClient.HandleIfErrorResponseAsync(HttpStatusCode statusCode, HttpResponseMessage response, IEnumerable`1 handlers)
at Docker.DotNet.DockerClient.MakeRequestAsync(IEnumerable`1 errorHandlers, HttpMethod method, String path, IQueryString queryString, IRequestContent body, IDictionary`2 headers, TimeSpan timeout, CancellationToken token)
at Docker.DotNet.ContainerOperations.CreateContainerAsync(CreateContainerParameters parameters, CancellationToken cancellationToken)
at DotNet.Testcontainers.Clients.DockerContainerOperations.RunAsync(ITestcontainersConfiguration configuration, CancellationToken ct)
at DotNet.Testcontainers.Clients.TestcontainersClient.RunAsync(ITestcontainersConfiguration configuration, CancellationToken ct)
at DotNet.Testcontainers.Containers.TestcontainersContainer.Create(CancellationToken ct)
at DotNet.Testcontainers.Containers.TestcontainersContainer.StartAsync(CancellationToken ct)
at DotNet.Testcontainers.Containers.ResourceReaper.GetAndStartNewAsync(Guid sessionId, IDockerEndpointAuthenticationConfiguration dockerEndpointAuthConfig, String ryukImage, TimeSpan initTimeout, CancellationToken ct)
at DotNet.Testcontainers.Containers.ResourceReaper.GetAndStartNewAsync(Guid sessionId, IDockerEndpointAuthenticationConfiguration dockerEndpointAuthConfig, String ryukImage, TimeSpan initTimeout, CancellationToken ct)
at DotNet.Testcontainers.Containers.ResourceReaper.GetAndStartDefaultAsync(IDockerEndpointAuthenticationConfiguration dockerEndpointAuthConfig, CancellationToken ct)
at DotNet.Testcontainers.Clients.TestcontainersClient.RunAsync(ITestcontainersConfiguration configuration, CancellationToken ct)
at DotNet.Testcontainers.Containers.TestcontainersContainer.Create(CancellationToken ct)
at DotNet.Testcontainers.Containers.TestcontainersContainer.StartAsync(CancellationToken ct)
at Program.<Main>$(String[] args) in /home/lucasteles/dev/nuke-testcontainers/src/Program.cs:line 33
at Program.<Main>(String[] args) after manually pulling ryuk ❯ dotnet run --project .\src\
info: Program[0] *********** Begin Test **********
info: Program[0] Docker container e368a2c7c04dfe29bd0948bd9561a32cfba86ef433d537b479b863e5077af1db created
info: Program[0] Start Docker container e368a2c7c04dfe29bd0948bd9561a32cfba86ef433d537b479b863e5077af1db
info: Program[0] Searching Docker registry credential in CredsStore
info: Program[0] Searching Docker registry credential in CredHelpers
info: Program[0] Searching Docker registry credential in Auths
info: Program[0] Searching Docker registry credential in Auths
info: Program[0] Docker registry credential index.docker.io found
info: Program[0] Docker image postgres:11.14 created
Unhandled exception. Docker.DotNet.DockerImageNotFoundException: Docker API responded with status code=NotFound, response={"message":"No such image: postgres:11.14"}
at Docker.DotNet.ContainerOperations.<>c.<.cctor>b__30_1(HttpStatusCode statusCode, String responseBody)
at Docker.DotNet.DockerClient.HandleIfErrorResponseAsync(HttpStatusCode statusCode, HttpResponseMessage response, IEnumerable`1 handlers)
at Docker.DotNet.DockerClient.MakeRequestAsync(IEnumerable`1 errorHandlers, HttpMethod method, String path, IQueryString queryString, IRequestContent body, IDictionary`2 headers, TimeSpan timeout, CancellationToken token)
at Docker.DotNet.ContainerOperations.CreateContainerAsync(CreateContainerParameters parameters, CancellationToken cancellationToken)
at DotNet.Testcontainers.Clients.DockerContainerOperations.RunAsync(ITestcontainersConfiguration configuration, CancellationToken ct)
at DotNet.Testcontainers.Clients.TestcontainersClient.RunAsync(ITestcontainersConfiguration configuration, CancellationToken ct)
at DotNet.Testcontainers.Containers.TestcontainersContainer.Create(CancellationToken ct)
at DotNet.Testcontainers.Containers.TestcontainersContainer.StartAsync(CancellationToken ct)
at Program.<Main>$(String[] args) in C:\d\nuke-testcontainers\src\Program.cs:line 33
at Program.<Main>(String[] args) Is I missing something to enable the |
Somehow it is not pulling images on your machine. Compare your log to my attached run: diagnostic.log. Unfortunately, the current Docker.DotNet version does not forward errors (building and pulling images). Can you run following test on your machine? using var dockerClientConfiguration = TestcontainersSettings.OS.DockerEndpointAuthConfig.GetDockerClientConfiguration(ResourceReaper.DefaultSessionId);
using var dockerClient = dockerClientConfiguration.CreateClient();
await dockerClient.Images.CreateImageAsync(new ImagesCreateParameters { FromImage = "postgres", Tag = "11.14" }, new AuthConfig(), new Progress())
.ConfigureAwait(false);
private sealed class Progress : IProgress<JSONMessage>
{
public void Report(JSONMessage value)
{
Debug.WriteLine(value.ProgressMessage);
}
} |
@HofmeisterAn Your code works, it was able to pull the image 🤔 |
Ah, I miss read your log - sorry.
Can you check which credentials Testcontainers for .NET picks up? Looks like you are logged into a registry. I guess Testcontainers cannot authenticate. |
@HofmeisterAn I see, If I log out of my docker hub account in Docker desktop it goes back to work |
Yep, can confirm. This looks like a bug. It picks up the Docker Hub credentials and probably tries to pull the image from the private Docker Hub registry. |
I know what is going "wrong", but I am not sure how to distinguish between private and public images yet (what is the correct approach for Docker Hub). I need to take a closer look at it. I won't make it today, expect a fix next week. |
Maybe this workaround helps in the meantime. Logout and then login via CLI ( |
Ok, I found the root cause. Docker.DotNet does not support the Docker Registry v2 Bearer token. Docker Desktop creates a JWT. Following test in Docker.DotNet works: diff --git a/src/Docker.DotNet/Endpoints/ImageOperations.cs b/src/Docker.DotNet/Endpoints/ImageOperations.cs
index e9412d5..3ccf460 100644
--- a/src/Docker.DotNet/Endpoints/ImageOperations.cs
+++ b/src/Docker.DotNet/Endpoints/ImageOperations.cs
@@ -307,15 +307,18 @@ namespace Docker.DotNet
{
return new Dictionary<string, string>
{
+ // {
+ // RegistryAuthHeaderKey,
+ // Convert.ToBase64String(
+ // Encoding.UTF8.GetBytes(
+ // this._client.JsonSerializer.SerializeObject(authConfig ?? new AuthConfig())))
+ // .Replace("/", "_").Replace("+", "-")
+ // // This is not documented in Docker API but from source code (https://github.com/docker/docker-ce/blob/10e40bd1548f69354a803a15fde1b672cc024b91/components/cli/cli/command/registry.go#L47)
+ // // and from multiple internet sources it has to be base64-url-safe.
+ // // See RFC 4648 Section 5. Padding (=) needs to be kept.
+ // },
{
- RegistryAuthHeaderKey,
- Convert.ToBase64String(
- Encoding.UTF8.GetBytes(
- this._client.JsonSerializer.SerializeObject(authConfig ?? new AuthConfig())))
- .Replace("/", "_").Replace("+", "-")
- // This is not documented in Docker API but from source code (https://github.com/docker/docker-ce/blob/10e40bd1548f69354a803a15fde1b672cc024b91/components/cli/cli/command/registry.go#L47)
- // and from multiple internet sources it has to be base64-url-safe.
- // See RFC 4648 Section 5. Padding (=) needs to be kept.
+ "Authorization", "Bearer " + authConfig.Password
}
};
} The suggested workaround in the previous comment will work. I need to double-check if we can add the bearer token support. |
We will keep |
…sktop instead of the CLI (#677)
…sktop instead of the CLI (#677)
Describe the bug
When I am trying to run Testcontainers and it needs to pull a new image it is giving me
Docker.DotNet.DockerImageNotFoundException : Docker API responded with status code=NotFound, response={"message":"No such image: testcontainers/ryuk:0.3.4"}
Stack trace:
I am trying to run a Postgres container with:
I am getting this with any image:
If I pull manually with
docker pull testcontainers/ryuk:0.3.4
from the terminal, It starts to give an error on the container image itselfSo, it works if I manually pull the
hello-world
orpostgres:11.14
.Desktop:
The text was updated successfully, but these errors were encountered: