-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMySqlCollection.cs
63 lines (50 loc) · 1.66 KB
/
MySqlCollection.cs
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
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
using DotNet.Testcontainers.Builders;
using DotNet.Testcontainers.Containers;
using IntegrationTests.Helpers;
using static IntegrationTests.Helpers.DockerFileHelper;
namespace IntegrationTests;
[CollectionDefinition(Name)]
public class MySqlCollection : ICollectionFixture<MySqlFixture>
{
public const string Name = nameof(MySqlCollection);
}
public class MySqlFixture : IAsyncLifetime
{
private const int MySqlPort = 3306;
private static readonly string MySqlImage = ReadImageFrom("mysql.Dockerfile");
private IContainer? _container;
public MySqlFixture()
{
Port = TcpPortProvider.GetOpenPort();
}
public int Port { get; }
public async Task InitializeAsync()
{
_container = await LaunchMySqlContainerAsync(Port);
}
public async Task DisposeAsync()
{
if (_container != null)
{
await ShutdownMySqlContainerAsync(_container);
}
}
private static async Task<IContainer> LaunchMySqlContainerAsync(int port)
{
var containersBuilder = new ContainerBuilder()
.WithImage(MySqlImage)
.WithName($"mysql-{port}")
.WithPortBinding(port, MySqlPort)
.WithEnvironment("MYSQL_ALLOW_EMPTY_PASSWORD", "true")
.WithWaitStrategy(Wait.ForUnixContainer().UntilPortIsAvailable(MySqlPort));
var container = containersBuilder.Build();
await container.StartAsync();
return container;
}
private static async Task ShutdownMySqlContainerAsync(IContainer container)
{
await container.DisposeAsync();
}
}