diff --git a/src/EvoSC.Common/Services/MapService.cs b/src/EvoSC.Common/Services/MapService.cs index 349599bd7..ebc1f0c16 100644 --- a/src/EvoSC.Common/Services/MapService.cs +++ b/src/EvoSC.Common/Services/MapService.cs @@ -96,6 +96,26 @@ public async Task> AddMapsAsync(List mapStreams) public async Task RemoveMapAsync(long mapId) { await _mapRepository.RemoveMapAsync(mapId); + var map = await this.GetMapByIdAsync(mapId); + + if (map == null) return; + + var filePath = Path.Combine(_config.Path.Maps, "EvoSC", map.FilePath); + if (!File.Exists(filePath)) + { + _logger.LogWarning("Tried to delete map which doesn't exists on the filesystem: {filePath}", filePath); + return; + } + + try + { + File.Delete(filePath); + } + catch (Exception e) + { + _logger.LogError(e, "An exception occurred while trying to delete a map file."); + throw; + } } public async Task AddCurrentMapListAsync() diff --git a/tests/EvoSC.Common.Tests/Services/MapServiceTests.cs b/tests/EvoSC.Common.Tests/Services/MapServiceTests.cs index 6e48ca9c3..b2f1a3df3 100644 --- a/tests/EvoSC.Common.Tests/Services/MapServiceTests.cs +++ b/tests/EvoSC.Common.Tests/Services/MapServiceTests.cs @@ -338,10 +338,12 @@ public async Task Remove_Map_Removes_Map() Id = 123, ExternalId = "1337", Name = "snippens dream", - Uid = "Uid" + Uid = "Uid", + FilePath = "FilePath" }; _mapRepository.Setup(m => m.GetMapByIdAsync(It.IsAny())) .Returns(Task.FromResult((IMap?)map)); + _config.SetupGet(config => config.Path.Maps).Returns("MapPath"); await _mapService.RemoveMapAsync(123);