-
-
Notifications
You must be signed in to change notification settings - Fork 345
Expand file tree
/
Copy pathProtectDockerDaemonSocketTest.cs
More file actions
121 lines (98 loc) · 4.02 KB
/
ProtectDockerDaemonSocketTest.cs
File metadata and controls
121 lines (98 loc) · 4.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
namespace DotNet.Testcontainers.Tests.Unit
{
using System;
using System.Linq;
using System.Threading.Tasks;
using Docker.DotNet;
using DotNet.Testcontainers.Builders;
using DotNet.Testcontainers.Clients;
using DotNet.Testcontainers.Configurations;
using DotNet.Testcontainers.Tests.Fixtures;
using Microsoft.Extensions.Logging.Abstractions;
using Org.BouncyCastle.Crypto;
using Org.BouncyCastle.Crypto.Parameters;
using Xunit;
public static class ProtectDockerDaemonSocketTest
{
private static IDockerEndpointAuthenticationConfiguration GetAuthConfig(ProtectDockerDaemonSocket protectDockerDaemonSocket)
{
var customConfiguration = new PropertiesFileConfiguration(protectDockerDaemonSocket.CustomProperties.ToArray());
return new IDockerEndpointAuthenticationProvider[] { new MTlsEndpointAuthenticationProvider(customConfiguration), new TlsEndpointAuthenticationProvider(customConfiguration) }.First(authProvider => authProvider.IsApplicable()).GetAuthConfig();
}
public sealed class MTlsOpenSsl1_1_1 : IClassFixture<OpenSsl1_1_1Fixture>, IDockerEndpointAuthenticationConfiguration
{
private readonly ProtectDockerDaemonSocket _fixture;
private readonly IDockerEndpointAuthenticationConfiguration _authConfig;
public MTlsOpenSsl1_1_1(OpenSsl1_1_1Fixture dockerMTlsFixture)
{
_fixture = dockerMTlsFixture;
_authConfig = GetAuthConfig(dockerMTlsFixture);
}
// The outdated image isn't compatible with the default Docker Engine API version.
// For this test, we're overriding the version.
public Version Version
=> null;
public Uri Endpoint
=> _authConfig.Endpoint;
public Credentials Credentials
=> _authConfig.Credentials;
public DockerClientConfiguration GetDockerClientConfiguration(Guid sessionId = default)
=> _authConfig.GetDockerClientConfiguration(sessionId);
[Fact]
public async Task GetVersionReturnsVersion()
{
// Given
var client = new TestcontainersClient(Guid.Empty, this, NullLogger.Instance);
// When
var version = await client.System.GetVersionAsync(TestContext.Current.CancellationToken)
.ConfigureAwait(true);
// Then
Assert.StartsWith(version.Version, _fixture.Image.Tag);
Assert.IsType<AsymmetricCipherKeyPair>(_fixture.TlsKey);
}
}
public sealed class MTlsOpenSsl3_1 : IClassFixture<OpenSsl3_1Fixture>
{
private readonly ProtectDockerDaemonSocket _fixture;
private readonly IDockerEndpointAuthenticationConfiguration _authConfig;
public MTlsOpenSsl3_1(OpenSsl3_1Fixture dockerMTlsFixture)
{
_fixture = dockerMTlsFixture;
_authConfig = GetAuthConfig(dockerMTlsFixture);
}
[Fact]
public async Task GetVersionReturnsVersion()
{
// Given
var client = new TestcontainersClient(Guid.Empty, _authConfig, NullLogger.Instance);
// When
var version = await client.System.GetVersionAsync(TestContext.Current.CancellationToken)
.ConfigureAwait(true);
// Then
Assert.StartsWith(version.Version, _fixture.Image.Tag);
Assert.IsType<RsaPrivateCrtKeyParameters>(_fixture.TlsKey);
}
}
public sealed class Tls : IClassFixture<DockerTlsFixture>
{
private readonly ProtectDockerDaemonSocket _fixture;
private readonly IDockerEndpointAuthenticationConfiguration _authConfig;
public Tls(DockerTlsFixture dockerTlsFixture)
{
_fixture = dockerTlsFixture;
_authConfig = GetAuthConfig(dockerTlsFixture);
}
[Fact]
public async Task GetVersionReturnsVersion()
{
// Given
var client = new TestcontainersClient(Guid.Empty, _authConfig, NullLogger.Instance);
// When
var version = await client.System.GetVersionAsync(TestContext.Current.CancellationToken)
.ConfigureAwait(true);
// Then
Assert.StartsWith(version.Version, _fixture.Image.Tag);
}
}
}
}