feat(template-folder): rename folder with sibling uniqueness check
This commit is contained in:
@@ -67,4 +67,44 @@ public class TemplateFolderServiceTests
|
||||
Assert.True(result.IsFailure);
|
||||
Assert.Contains("not found", result.Error);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task RenameFolder_ValidInput_ReturnsSuccess()
|
||||
{
|
||||
var folder = new TemplateFolder("Old") { Id = 1, ParentFolderId = null };
|
||||
_repoMock.Setup(r => r.GetFolderByIdAsync(1, It.IsAny<CancellationToken>())).ReturnsAsync(folder);
|
||||
_repoMock.Setup(r => r.GetAllFoldersAsync(It.IsAny<CancellationToken>()))
|
||||
.ReturnsAsync(new List<TemplateFolder> { folder });
|
||||
|
||||
var result = await _sut.RenameFolderAsync(1, "New", "admin");
|
||||
|
||||
Assert.True(result.IsSuccess);
|
||||
Assert.Equal("New", result.Value.Name);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task RenameFolder_NotFound_ReturnsFailure()
|
||||
{
|
||||
_repoMock.Setup(r => r.GetFolderByIdAsync(99, It.IsAny<CancellationToken>()))
|
||||
.ReturnsAsync((TemplateFolder?)null);
|
||||
|
||||
var result = await _sut.RenameFolderAsync(99, "New", "admin");
|
||||
|
||||
Assert.True(result.IsFailure);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task RenameFolder_DuplicateSibling_ReturnsFailure()
|
||||
{
|
||||
var folder = new TemplateFolder("Old") { Id = 1, ParentFolderId = null };
|
||||
var sibling = new TemplateFolder("Other") { Id = 2, ParentFolderId = null };
|
||||
_repoMock.Setup(r => r.GetFolderByIdAsync(1, It.IsAny<CancellationToken>())).ReturnsAsync(folder);
|
||||
_repoMock.Setup(r => r.GetAllFoldersAsync(It.IsAny<CancellationToken>()))
|
||||
.ReturnsAsync(new List<TemplateFolder> { folder, sibling });
|
||||
|
||||
var result = await _sut.RenameFolderAsync(1, "Other", "admin");
|
||||
|
||||
Assert.True(result.IsFailure);
|
||||
Assert.Contains("already exists", result.Error);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user