ho questo metodo:test EF metodi asincroni con i metodi di sincronizzazione con MOQ
public async Task DeleteUserAsync(Guid userId)
{
using (var context = this.contextFactory.Create())
{
var user = await context.Users.FirstOrDefaultAsync(x => x.Id.Equals(userId));
if (user == null)
{
throw new Exception("User doesn't exist");
}
context.Users.Remove(user);
await context.SaveChangesAsync();
}
}
voglio provarlo. Così ho creato il test:
[TestMethod]
public async Task DeleteUsersSuccessfulCallTest()
{
// Arrange
var id = Guid.NewGuid();
var user = new User() { Id = id };
var context = new Mock<IDashboardContext>();
var usersDbSet = DbSetQueryMocking.GenericSetupAsyncQueryableMockInterfaceSet(new List<User> { user }.AsQueryable());
context.Setup(x => x.Users).Returns(usersDbSet.Object);
context.Setup(x => x.Users.Remove(user)).Returns(user).Verifiable();
context.Setup(x => x.SaveChangesAsync()).ReturnsAsync(1).Verifiable();
this.contextFactory.Setup(x => x.Create()).Returns(context.Object);
// Act
await this.userService.DeleteUserAsync(id);
context.VerifyAll();
}
}
ho avuto questo metodo per creare me un set finto:
public static Mock<DbSet<T>> GenericSetupAsyncQueryableMockSet<T>(IQueryable<T> data) where T : class
{
var mockSet = new Mock<DbSet<T>>();
mockSet.As<IDbAsyncEnumerable<T>>().Setup(m => m.GetAsyncEnumerator()).Returns(new TestDbAsyncEnumerator<T>(data.GetEnumerator()));
mockSet.As<IQueryable<T>>().Setup(m => m.Provider).Returns(new TestDbAsyncQueryProvider<T>(data.Provider));
mockSet.As<IQueryable<T>>().Setup(m => m.Expression).Returns(data.Expression);
mockSet.As<IQueryable<T>>().Setup(m => m.ElementType).Returns(data.ElementType);
mockSet.As<IQueryable<T>>().Setup(m => m.GetEnumerator()).Returns(data.GetEnumerator());
return mockSet;
}
Tuttavia, perché la mia DeleteUserAsync
contiene i metodi di estensione asincroni e metodi di sincronizzazione standard, ricevo questo messaggio di errore :
System.InvalidOperationException: il provider per l'origine IQueryable non implementa IDbAsyncQueryProvider. Solo i provider che implementano IDbAsyncQueryProvider possono essere utilizzati per le operazioni asincrone di Entity Framework. Per maggiori dettagli vedi http://go.microsoft.com/fwlink/?LinkId=287068.
Ovviamente se ho appena impostato il DbSet<T>
con Queryable
deriso fuori allora si getterà la stessa eccezione.
proposito: la riga all'origine è:
context.Setup(x => x.Users.Remove(user)).Returns(user).Verifiable();
Con questa linea: errori
Senza di esso: una prova di successo.
Come posso risolvere questo problema?
Questo è probabilmente il problema della struttura di derisione e non ha nulla a che fare con EF o test. – Euphoric
Ho aggiornato la domanda per riflettere questo –
https://msdn.microsoft.com/en-us/data/dn314429#async – Ali