public void Delete_WithRequiredSubEntitiesAndRequiredUsedEntities_Succeeds() { //Arrange var repository = new EFRepositoryTester(); repository.Initialize(); var addingDate = DateTime.UtcNow; var manager = new Manager() { Director = director, ManagerTrackers = new List <ManagerTracker>() { new ManagerTracker() }, Office = office1, Computer = new Computer() { Data = "data", Admin = admin }, Data = "data" }; repository.Add(new AddOperationParameters <Manager>() { Entity = manager, OperationDateTime = addingDate }); //Act var deletingDate = DateTime.UtcNow; repository.Delete(new DeleteOperationParameters() { PrimaryKeys = new object[] { manager.Id }, OperationDateTime = deletingDate }); //Assert var context = new EFContext(); var managers = context.Managers.ToArray(); var computers = context.Computers.ToArray(); AssertUsingEntities(); AssertSecondLevelUsedEntities(); //Sub entities AssertComputers(addingDate, deletingDate, "data", true); //Main entity Assert.AreEqual(0, managers.Length); //First level used entities AssertOffices(); }
public void Delete_EntityNotExists_Succeeds() { //Arrange var repository = new EFRepositoryTester(); //Act //Assert repository.Initialize(); repository.Delete(new DeleteOperationParameters() { PrimaryKeys = new object[] { 10000L } }); }
public void GetTotalCount_EntitiesExist_ReturnsEntitiesCount() { //Arrange var repository = new EFRepositoryTester(); repository.Initialize(); var addingDate = DateTime.UtcNow; var manager1 = new Manager() { Director = director, ManagerTrackers = new List <ManagerTracker>() { new ManagerTracker() }, Office = office1, Computer = new Computer() { Data = "data", Admin = admin }, Things = new List <Thing>() { new Thing() { Id = 1, Admin = admin, Data = "data" }, new Thing() { Id = 2, Admin = admin, Data = "data" } }, Description = new Description() { Data = "data" }, Data = "data", Car = car1, Projects = new List <Project>() { project1 } }; var manager2 = new Manager() { Director = director, ManagerTrackers = new List <ManagerTracker>() { new ManagerTracker() }, Office = office2, Computer = new Computer() { Data = "data", Admin = admin }, Things = new List <Thing>() { new Thing() { Id = 1, Admin = admin, Data = "data" }, new Thing() { Id = 2, Admin = admin, Data = "data" } }, Description = new Description() { Data = "data" }, Data = "data", Car = car2, Projects = new List <Project>() { project2 } }; repository.Add(new AddOperationParameters <Manager>() { Entity = manager1, OperationDateTime = addingDate }); repository.Add(new AddOperationParameters <Manager>() { Entity = manager2, OperationDateTime = addingDate }); repository.Delete(new DeleteOperationParameters() { OperationDateTime = DateTime.UtcNow, PrimaryKeys = new object[] { manager2.Id } }); //Act var result = repository.GetTotalCount(new OperationParameters()); //Assert Assert.AreEqual(1, result); }
public void Get_ByFilterWhenDeletedEntitiesExist_ReturnsNotDeletedEntities() { //Arrange var repository = new EFRepositoryTester(); repository.Initialize(); Add10Managers(); var entitiesToDelete = repository.Get(new GetOperationParameters()); repository.Delete(new DeleteOperationParameters() { PrimaryKeys = new object[] { entitiesToDelete[0].Id } }); repository.Delete(new DeleteOperationParameters() { PrimaryKeys = new object[] { entitiesToDelete[1].Id } }); repository.Delete(new DeleteOperationParameters() { PrimaryKeys = new object[] { entitiesToDelete[2].Id } }); //Act var entities = repository.Get(new GetOperationParameters() { QueryParameters = new QueryParameters() { Filter = new OrOperator() { LeftOperand = new ContainsCondition() { Property = ReflectionHelper.GetPropertyName <Manager, string>(e => e.Data), Value = "data9" }, RightOperand = new OrOperator() { LeftOperand = new EqualsCondition() { Property = ReflectionHelper.GetPropertyName <Manager, string>(e => e.Data), Value = "data1" }, RightOperand = new EqualsCondition() { Property = ReflectionHelper.GetPropertyName <Manager, string>(e => e.Data), Value = "data2" } } } } }); //Assert Assert.AreEqual(1, entities.Length); foreach (var entity in entities) { Assert.AreEqual("data9", entity.Data); } }
public void Delete_WithAllSubEntitiesAndAllUsedEntities_Succeeds() { //Arrange var repository = new EFRepositoryTester(); repository.Initialize(); var addingDate = DateTime.UtcNow; var manager = new Manager() { Director = director, ManagerTrackers = new List <ManagerTracker>() { new ManagerTracker() }, Office = office1, Computer = new Computer() { Data = "data", Admin = admin }, Things = new List <Thing>() { new Thing() { Id = 1, Admin = admin, Data = "data" }, new Thing() { Id = 2, Admin = admin, Data = "data" } }, Description = new Description() { Data = "data" }, Data = "data", Car = car1, Projects = new List <Project>() { project1, project2 } }; repository.Add(new AddOperationParameters <Manager>() { Entity = manager, OperationDateTime = addingDate }); //Act var deletingDate = DateTime.UtcNow; repository.Delete(new DeleteOperationParameters() { PrimaryKeys = new object[] { manager.Id }, OperationDateTime = deletingDate }); //Assert var context = new EFContext(); var managers = context.Managers.ToArray(); var things = context.Things.ToArray(); AssertUsingEntities(); AssertSecondLevelUsedEntities(); //Sub entities AssertComputers(addingDate, deletingDate, "data", true); AssertDescriptions(addingDate, deletingDate, "data", true); Assert.AreEqual(0, things.Length); //Main entity Assert.AreEqual(0, managers.Length); //First level used entities AssertOffices(); AssertCars(); AssertProjects(null, null); }