我正在对一个异步函数进行单元测试,该函数将 IFormFile 列表转换为我自己的任意数据库文件类列表。
将文件数据转换为字节数组的方法是:
internal async Task<List<File>> ConvertFormFilesToFiles(ICollection<IFormFile> formFiles)
{
var file = new File
{
InsertDateTime = DateTime.Now,
LastChangeDateTime = DateTime.Now
};
if (formFile.Length > 0)
{
using (var memoryStream = new MemoryStream())
{
await formFile.CopyToAsync(memoryStream, CancellationToken.None);
file.FileData = memoryStream.ToArray();
}
}
// ...
}
该函数接收 IFormFiles 的 ICollection,因此它是可模拟的。
现在我有这样的测试代码:
//Arrange
var fileConverter = new FilesConverter();
using (var fileStream = new FileStream("Files/uploadme.txt", FileMode.Open, FileAccess.Read))
{
using (var memoryStream = new MemoryStream())
{
var newMemoryStream = new MemoryStream();
fileStream.CopyTo(memoryStream);
FormFileMock.Setup(f => f.CopyToAsync(newMemoryStream, CancellationToken.None)).Returns(Task.CompletedTask);
// some other setups
//Act
var result = await fileConverter.ConvertFormFilesToFiles(new List<IFormFile> { FormFileMock.Object });
//Assert
Assert.IsTrue(result.Any());
}
}
创建 newMemoryStream 变量是因为该函数使用新的空内存流调用 CopyToAsync 方法(我不确定这是否有必要)。
问题是等待 formFile.CopyToAsync(memoryStream, CancellationToken.None)不将任何数据复制到内存流。
我知道这可能不受欢迎,因为使用模拟框架现在已经完全“流行”了,但为什么不简单地将框架保留为框架并采用简单、容易的方法呢?您可以创建一个FormFile
没有任何嘲笑。真正的交易:
var fileConverter = new FilesConverter(FilesConverterLoggerMock.Object, FileDataMock.Object);
// access to a real file should really not be in a "unit" test, but anyway:
using (var stream = new MemoryStream(File.ReadAllBytes("Files/uploadme.txt"))
{
// create a REAL form file
var formFile = new FormFile(stream , 0, stream.Length, "name", "filename");
//Act
var result = await fileConverter.ConvertFormFilesToFiles(new List<IFormFile> { formFile });
//Assert
Assert.IsTrue(result.Any());
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)