Exemplo n.º 1
0
        public void PostInternationalPassport_ShoulAddInternationalPassport()
        {
            var passportsTestData = new List <EmployeeInternationalPassport>()
            {
                new EmployeeInternationalPassport {
                    Id = 1, EmployeeId = 2
                },
                new EmployeeInternationalPassport {
                    Id = 2, Deleted = true, EmployeeId = 2
                },
                new EmployeeInternationalPassport {
                    Id = 3, EmployeeId = 3
                }
            };
            var passports = MockHelper.MockDbSet(passportsTestData);

            passports.Setup(d => d.Find(It.IsAny <object>())).Returns <object[]>((keyValues) => { return(passports.Object.SingleOrDefault(product => product.Id == (int)keyValues.Single())); });
            passports.Setup(d => d.Add(It.IsAny <EmployeeInternationalPassport>())).Returns <EmployeeInternationalPassport>((contact) =>
            {
                passportsTestData.Add(contact);
                passports = MockHelper.MockDbSet(passportsTestData);
                return(contact);
            });

            var dbContext = new Mock <IAppDbContext>();

            dbContext.Setup(m => m.EmployeeInternationalPassports).Returns(passports.Object);
            dbContext.Setup(d => d.Set <EmployeeInternationalPassport>()).Returns(passports.Object);

            dbContext.Setup(d => d.ExecuteStoredProcedure <int>(It.IsAny <string>(), It.IsAny <object[]>()))
            .Returns <string, object[]>((query, parameters) =>
            {
                List <int> list = new List <int>();
                if (query.Contains("NewTableId"))
                {
                    int i = passports.Object.Max(d => d.Id) + 1;
                    list.Add(i);
                }
                else
                {
                    list.Add(0);
                }
                return(list);
            });

            var factory = new Mock <IDbContextFactory>();

            factory.Setup(m => m.CreateDbContext()).Returns(dbContext.Object);

            EmployeeInternationalPassport passport = new EmployeeInternationalPassport {
                Id = 0, EmployeeId = 3, IssuedBy = "Wow"
            };
            var controller = new EmployeeInternationalPassportsController(factory.Object);
            var result     = controller.PostEmployeeInternationalPassport(passport.ToDTO()) as CreatedAtRouteNegotiatedContentResult <EmployeeInternationalPassportDTO>;

            Assert.IsNotNull(result);
            Assert.AreEqual(4, result.Content.Id);
            Assert.AreEqual(3, result.Content.EmployeeId);
            Assert.AreEqual("Wow", result.Content.IssuedBy);
        }
Exemplo n.º 2
0
 public IHttpActionResult PostEmployeeInternationalPassport(EmployeeInternationalPassportDTO employeeInternationalPassport)
 {
     if (employeeInternationalPassport == null || !ModelState.IsValid)
     {
         return(BadRequest(ModelState));
     }
     try
     {
         EmployeeInternationalPassport passport = employeeInternationalPassport.FromDTO();
         UnitOfWork unitOfWork = new UnitOfWork(factory);
         passport.Id = passport.NewId(unitOfWork);
         unitOfWork.EmployeeInternationalPassportsRepository.Insert(passport);
         unitOfWork.Save();
         EmployeeInternationalPassportDTO dto = passport.ToDTO();
         return(CreatedAtRoute("GetEmployeeInternationalPassport", new { id = dto.Id }, dto));
     }
     catch (NotFoundException nfe)
     {
         return(NotFound());
     }
     catch (ConflictException ce)
     {
         return(Conflict());
     }
     catch (Exception e)
     {
         return(BadRequest(e.Message));
     }
 }
Exemplo n.º 3
0
 public IHttpActionResult DeleteEmployeeInternationalPassport(int id)
 {
     try
     {
         UnitOfWork unitOfWork = new UnitOfWork(factory);
         EmployeeInternationalPassport passport = unitOfWork.EmployeeInternationalPassportsRepository.GetByID(id);
         passport.Deleted = true;
         unitOfWork.EmployeeInternationalPassportsRepository.Update(passport);
         unitOfWork.Save();
         EmployeeInternationalPassportDTO dto = passport.ToDTO();
         return(Ok(dto));
     }
     catch (NotFoundException nfe)
     {
         return(NotFound());
     }
     catch (ConflictException ce)
     {
         return(Conflict());
     }
     catch (Exception e)
     {
         return(BadRequest(e.Message));
     }
 }
Exemplo n.º 4
0
 public IHttpActionResult PutEmployeeInternationalPassport(int id, EmployeeInternationalPassportDTO employeeInternationalPassport)
 {
     if (employeeInternationalPassport == null || !ModelState.IsValid)
     {
         return(BadRequest(ModelState));
     }
     if (id != employeeInternationalPassport.Id)
     {
         return(BadRequest());
     }
     try
     {
         EmployeeInternationalPassport passport = employeeInternationalPassport.FromDTO();
         UnitOfWork unitOfWork = new UnitOfWork(factory);
         unitOfWork.EmployeeInternationalPassportsRepository.Update(passport);
         unitOfWork.Save();
         EmployeeInternationalPassportDTO dto = passport.ToDTO();
         return(Ok(dto));
     }
     catch (NotFoundException nfe)
     {
         return(NotFound());
     }
     catch (ConflictException ce)
     {
         return(Conflict());
     }
     catch (Exception e)
     {
         return(BadRequest(e.Message));
     }
 }
Exemplo n.º 5
0
        public void DeleteInternationalPassport_ShouldDeleteAndReturnOk()
        {
            var passportsTestData = new List <EmployeeInternationalPassport>()
            {
                new EmployeeInternationalPassport {
                    Id = 1, EmployeeId = 2
                },
                new EmployeeInternationalPassport {
                    Id = 2, Deleted = true, EmployeeId = 2
                },
                new EmployeeInternationalPassport {
                    Id = 3, EmployeeId = 3
                }
            };
            var passports = MockHelper.MockDbSet(passportsTestData);

            passports.Setup(d => d.Find(It.IsAny <object>())).Returns <object[]>((keyValues) => { return(passports.Object.SingleOrDefault(product => product.Id == (int)keyValues.Single())); });

            var dbContext = new Mock <IAppDbContext>();

            dbContext.Setup(m => m.EmployeeInternationalPassports).Returns(passports.Object);
            dbContext.Setup(d => d.Set <EmployeeInternationalPassport>()).Returns(passports.Object);


            var factory = new Mock <IDbContextFactory>();

            factory.Setup(m => m.CreateDbContext()).Returns(dbContext.Object);

            EmployeeInternationalPassport passport = new EmployeeInternationalPassport {
                Id = 3, EmployeeId = 3, IssuedBy = "Wow"
            };
            var controller = new EmployeeInternationalPassportsController(factory.Object);
            var result     = controller.DeleteEmployeeInternationalPassport(3) as OkNegotiatedContentResult <EmployeeInternationalPassportDTO>;

            Assert.IsNotNull(result);
            Assert.AreEqual(3, result.Content.Id);
            Assert.AreEqual(3, result.Content.EmployeeId);
        }