Ich schreibe eine UnitTest, die die FillInventory-Methode aufrufen, die in dieser Methode etwas in der Datenbank aktualisiert werden und in der Unit-Test möchte ich etwas überprüfen Daten vor und nach dem Aktualisieren in der DB durch Aufrufen der FillInventory-Methode und Überprüfen ihrer Eingaben.Mocking-Methode Abhängigkeit von Art von context.Database.ExecuteSqlCommand im Komponententest
In meinem Dienst:
public void FillInventory(InventoryViewModel invViewModel)
{
long roomServiceId = invViewModel.RoomServiceId;
var roomService = _unitOfWork.RoomServiceRepository.GetByID(roomServiceId);
var placeId = roomService.Room.PlaceId;
var capacity = roomService.Room.Capacity + roomService.ExtraCapacity;
for (DateTime date = invViewModel.StartDate; date.Date < invViewModel.EndDate; date = date.AddDays(1))
{
var inv = _unitOfWork.InventoryRepository.GetByKey(invViewModel.RoomServiceId, date);
if (inv != null)
{
inv.Price =(invViewModel.isUpdatingPrice)? invViewModel.Price:inv.Price;
inv.BoardPrice = (invViewModel.isUpdatingBoardPrice) ? invViewModel.BoardPrice : inv.BoardPrice;
inv.CertainAvailability = (invViewModel.isUpdatingCertainAvailability) ? invViewModel.CertainAvailability : inv.CertainAvailability;
inv.FloatAvailability = (invViewModel.isUpdatingFloatAvailability) ? invViewModel.FloatAvailability : inv.FloatAvailability;
inv.setWebServices(invViewModel.SellableWebServices.Select(sw => sw.Key).ToList());
}
else
{
var price = (invViewModel.isUpdatingPrice) ? invViewModel.Price : 0;
var boardPrice = (invViewModel.isUpdatingBoardPrice) ? invViewModel.BoardPrice : 0;
var certainAvailability = (invViewModel.isUpdatingCertainAvailability) ? invViewModel.CertainAvailability : 0;
var floatAvailability = (invViewModel.isUpdatingFloatAvailability) ? invViewModel.FloatAvailability : 0;
inv = new Jabama.Core.DataLayer.Models.Inventory(roomService, date, floatAvailability, certainAvailability,
price, boardPrice);
_unitOfWork.InventoryRepository.Insert(inv);
}
}
_unitOfWork.Save();
_unitOfWork.PlaceInfoRepository.UpdatePlaceInfos(placeId, capacity, invViewModel.StartDate, invViewModel.EndDate);
}
In meinem Repository
public class PlaceInfoRepository : GenericRepository<PlaceInfo>
{
public PlaceInfoRepository(JabamaContext context):base(context)
{ }
public void UpdatePlaceInfos(long placeId, int capacity, DateTime startDate, DateTime endDate)
{
var cmd = context.Database.Connection.CreateCommand();
List<SqlParameter> p = new List<SqlParameter>();
p.Add(new SqlParameter("@placeId", placeId));
p.Add(new SqlParameter("@capacity",capacity));
p.Add(new SqlParameter("@startDate", startDate.Date.ToString("yyyy -MM-dd")));
p.Add(new SqlParameter("@endDate", endDate.Date.ToString("yyyy-MM-dd")));
context.Database.ExecuteSqlCommand("exec UpdatePlaceInfo @placeId, @capacity, @startDate, @endDate", p.ToArray());
}
}
Ich habe alles, was Unit-Test, aber jetzt zu verspotten benötigte verspottet gibt es ein Problem, wenn Repository will mit context.Database.ExecuteSqlCommand
Daten aktualisieren.
Wie kann ich es verspotten?