-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSqlServerCollection.cs
107 lines (88 loc) · 3 KB
/
SqlServerCollection.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
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
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
using DotNet.Testcontainers.Builders;
using DotNet.Testcontainers.Containers;
using IntegrationTests.Helpers;
using IntegrationTests.Helpers.TestContainers;
using Microsoft.Data.SqlClient;
using static IntegrationTests.Helpers.DockerFileHelper;
namespace IntegrationTests;
[CollectionDefinition(Name)]
public class SqlServerCollection : ICollectionFixture<SqlServerFixture>
{
public const string Name = nameof(SqlServerCollection);
}
public class SqlServerFixture : IAsyncLifetime
{
private const int DatabasePort = 1433;
private static readonly string DatabaseImage = ReadImageFrom("sql-server.Dockerfile");
private IContainer? _container;
public SqlServerFixture()
{
if (IsCurrentArchitectureSupported)
{
Port = TcpPortProvider.GetOpenPort();
}
}
public string Password { get; } = $"@{Guid.NewGuid().ToString("N")}";
public int Port { get; }
public bool IsCurrentArchitectureSupported { get; } = EnvironmentTools.IsX64();
public async Task InitializeAsync()
{
if (!IsCurrentArchitectureSupported)
{
return;
}
_container = await LaunchSqlServerContainerAsync();
}
public async Task DisposeAsync()
{
if (_container != null)
{
await ShutdownSqlServerContainerAsync(_container);
}
}
public void SkipIfUnsupportedPlatform()
{
if (!IsCurrentArchitectureSupported)
{
throw new SkipException("SQL Server is supported only on AMD64.");
}
}
private static async Task ShutdownSqlServerContainerAsync(IContainer container)
{
await container.DisposeAsync();
}
private async Task<IContainer> LaunchSqlServerContainerAsync()
{
var databaseContainersBuilder = new ContainerBuilder()
.WithImage(DatabaseImage)
.WithName($"sql-server-{Port}")
.WithPortBinding(Port, DatabasePort)
.WithEnvironment("SA_PASSWORD", Password)
.WithEnvironment("ACCEPT_EULA", "Y")
.WithWaitStrategy(Wait.ForUnixContainer().UntilPortIsAvailable(DatabasePort))
.WithWaitStrategy(Wait.ForUnixContainer().AddCustomWaitStrategy(new UntilAsyncOperationIsSucceeded(DatabaseLoginOperation, 15)));
var container = databaseContainersBuilder.Build();
await container.StartAsync();
return container;
}
private async Task<bool> DatabaseLoginOperation()
{
try
{
string connectionString = $"Server=127.0.0.1,{Port};User=sa;Password={Password};TrustServerCertificate=True;";
using (var connection = new SqlConnection(connectionString))
{
connection.Open();
return true;
}
}
catch
{
// Slow down next connection attempt
await Task.Delay(TimeSpan.FromSeconds(2));
return false;
}
}
}