From f64521477f3ebb6fd479dc123346e5574a899f02 Mon Sep 17 00:00:00 2001 From: Vlastimil Kaluza <42292717+vlaskal@users.noreply.github.com> Date: Sun, 6 Nov 2022 09:27:07 +0100 Subject: [PATCH] fix(#640): CopyResourceMappingContainerTest IOException on Windows (cannot access same file stream in the same process) --- .../Unix/CopyResourceMappingContainerTest.cs | 22 +++++++++++++------ 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/tests/Testcontainers.Tests/Unit/Containers/Unix/CopyResourceMappingContainerTest.cs b/tests/Testcontainers.Tests/Unit/Containers/Unix/CopyResourceMappingContainerTest.cs index 308a361cc..b9dc7cf60 100644 --- a/tests/Testcontainers.Tests/Unit/Containers/Unix/CopyResourceMappingContainerTest.cs +++ b/tests/Testcontainers.Tests/Unit/Containers/Unix/CopyResourceMappingContainerTest.cs @@ -14,7 +14,7 @@ public sealed class CopyResourceMappingContainerTest : IAsyncLifetime, IDisposab { private const string ResourceMappingContent = "👋"; - private readonly FileStream fileStream = new(Path.Combine(Path.GetTempPath(), Path.GetTempFileName()), FileMode.Create, FileAccess.Write, FileShare.Read, ResourceMappingContent.Length, FileOptions.DeleteOnClose); + private readonly string filePath = Path.Combine(Path.GetTempPath(), Path.GetTempFileName()); private readonly string fileResourceMappingFilePath = Path.Combine("/tmp", Path.GetTempFileName()); @@ -27,22 +27,30 @@ public CopyResourceMappingContainerTest() this.container = new TestcontainersBuilder() .WithImage("alpine") .WithEntrypoint(KeepTestcontainersUpAndRunning.Command) - .WithResourceMapping(this.fileStream.Name, this.fileResourceMappingFilePath) + .WithResourceMapping(this.filePath, this.fileResourceMappingFilePath) .WithResourceMapping(Encoding.Default.GetBytes(ResourceMappingContent), this.binaryResourceMappingFilePath) .Build(); } public Task InitializeAsync() { - this.fileStream.Write(Encoding.Default.GetBytes(ResourceMappingContent)); - this.fileStream.Flush(); + using (var fileStream = File.Create(this.filePath)) + { + fileStream.Write(Encoding.Default.GetBytes(ResourceMappingContent)); + fileStream.Flush(); + } + return this.container.StartAsync(); } - public Task DisposeAsync() + public async Task DisposeAsync() { - this.fileStream.Dispose(); - return this.container.DisposeAsync().AsTask(); + await this.container.DisposeAsync(); + + if (File.Exists(this.filePath)) + { + File.Delete(this.filePath); + } } public void Dispose()