public void Test_CountryDelete()
        {
            var value = new CountryDelete(
                new Country
                {
                    Id = 1,
                    Title = "test"
                }
            );

            Assert.AreEqual(1, value.Id, "Id");
            Assert.AreEqual("test", value.Title, "Title");
        }
        public void Test_CountryController_Delete_Post()
        {
            PrincipalHelper.Create();

            var value = new CountryDelete { Id = 0 };
            var notFoundResult = this.CountryController.Delete(value) as HttpNotFoundResult;

            Assert.IsNotNull(notFoundResult, "HttpNotFoundResult");

            value.Id = 1;

            var redirectToRouteResult = this.CountryController.Delete(value) as RedirectToRouteResult;

            Assert.IsNotNull(redirectToRouteResult, "RedirectToRouteResult");
            Assert.AreEqual(AdministrationRoutes.CountryIndex, redirectToRouteResult.RouteName, "RouteName");

            PrincipalHelper.Clear();

            var notAuthorizedResult = this.CountryController.Delete(value) as NotAuthorizedResult;

            Assert.IsNotNull(notAuthorizedResult, "NotAuthorizedResult");
        }
        public ActionResult Delete(CountryDelete value)
        {
            if (value == null)
            {
                throw new ArgumentNullException("value");
            }

            var country = this.CountryService.GetById(value.Id);

            if (country == null)
            {
                return HttpNotFound();
            }

            var privilege = new CountryPrivilege();

            if (!privilege.CanDelete(country))
            {
                return NotAuthorized();
            }

            this.CountryService.Delete(country);

            return base.RedirectToRoute(AdministrationRoutes.CountryIndex);
        }