如何解决最小起订量,测试方法返回错误-System.ArgumentNullException:值不能为null 参数“源” DocumentTypeService类测试再次使用GetAll()方法 GetAllDocumentTypes()方法返回的错误
我有以下服务:
DocumentTypeService
类
public partial class DocumentTypeService : IDocumentTypeService
{
private readonly IRepository<DocumentType> _documentTypeRepository;
private readonly IMediator _mediator;
public DocumentTypeService(IRepository<DocumentType> documentTypeRepository,IMediator mediator)
{
_documentTypeRepository = documentTypeRepository;
_mediator = mediator;
}
public virtual async Task<IList<DocumentType>> GetAll()
{
var query = from t in _documentTypeRepository.Table
orderby t.displayOrder
select t;
return await query.ToListAsync();
}
}
测试再次使用GetAll()
方法
[TestClass()]
public class DocumentTypeServiceTests
{
private Mock<IRepository<DocumentType>> _documentTypeRepositoryMock;
private DocumentTypeService _documentTypeService;
private Mock<IMediator> _mediatorMock;
[Testinitialize()]
public void Init()
{
_mediatorMock = new Mock<IMediator>();
_documentTypeRepositoryMock = new Mock<IRepository<DocumentType>>();
_documentTypeService = new DocumentTypeService(_documentTypeRepositoryMock.Object,_mediatorMock.Object);
}
[TestMethod()]
public async Task GetAllDocumentTypes()
{
await _documentTypeService.GetAll();
_documentTypeRepositoryMock.Verify(c => c.Table,Times.Once);
}
}
GetAllDocumentTypes()
方法返回的错误
测试方法Grand.Services.Tests.Documents.DocumentTypeServiceTests.GetAllDocumentTypes引发异常:
System.ArgumentNullException:值不能为null。 (参数“源”)
堆栈跟踪:
Queryable.OrderBy [TSource,TKey](IQueryable'1源,Expression'1 keySelector)
MongoQueryable.OrderBy [TSource,TKey](IMongoQueryable'1 source,Expression'1 keySelector)
更新:
/// <summary>
/// MongoDB repository
/// </summary>
public partial class Repository<T> : IRepository<T> where T : BaseEntity
{
/// <summary>
/// Gets a table
/// </summary>
public virtual IMongoQueryable<T> Table
{
get { return _collection.AsQueryable(); }
}
}
解决方法
您应该模拟以下方法调用:
_documentTypeRepository.Table
具体来说,您需要这样的东西:
_documentTypeRepositoryMock = new Mock<IRepository<DocumentType>>();
var mongoQueryableMock = new Mock<IMongoQueryable<DocumentType>>();
_documentTypeRepositoryMock.Setup(x=>x.Table).Returns(mongoQueryableMock);
这样做,当调用_documentTypeRepository.Table
时将返回DocumentType
的空列表,并且不需要调用OrderBy。默认行为是,因为您不模拟此调用,所以_documentTypeRepository.Table
返回null。因此,稍后会出现空指针异常。
为了理解后一个参数,您应该了解查询语法如何在编译方式下工作。查询语法只是语法糖。编译代码时,首先将其替换为等效的(“ LINQ”)方法调用,并生成相应的IL代码。所以您的查询:
from t in _documentTypeRepository.Table
orderby t.DisplayOrder
select t;
将首先在如下查询中转换:
_documentTypeRepository.Table
.OrderBy(x=>x)
.Select(x=>x)
,随后将根据后一个查询生成相应的IL代码。
因此,如果_documentTypeRepository.Table
返回null,则调用OrderBy
将引发null指针异常。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。