Exemple #1
0
        public void EditExperience(ResumesExperienceDTO experienceDTO)
        {
            if (experienceDTO == null)
            {
                throw new ArgumentNullException(nameof(experienceDTO));
            }

            ResumesExperience experience = Database.ResumesExperiences.Get(experienceDTO.Id);

            if (experience == null)
            {
                throw new ArgumentOutOfRangeException("Not found experience");
            }

            Resume resume = Database.Resumes.Get(experienceDTO.ResumeId);

            if (resume == null)
            {
                throw new ArgumentOutOfRangeException("Invalid argument ResumeId");
            }

            experience.ResumeId   = experienceDTO.ResumeId;
            experience.Company    = experienceDTO.Company;
            experience.Position   = experienceDTO.Position;
            experience.StartDate  = experienceDTO.StartDate;
            experience.FinishDate = experienceDTO.FinishDate;
            experience.Resume     = resume;

            Database.ResumesExperiences.Update(experience);
            Database.Save();
        }
Exemple #2
0
        public void GetExperiencesExperienceById_TryToGetValue_ShouldReturnSomeValue()
        {
            var ResumesExperience = new ResumesExperience {
                Id = It.IsAny <int>(), ResumeId = It.IsAny <int>()
            };

            uow.Setup(x => x.ResumesExperiences.Get(It.IsAny <int>())).Returns(ResumesExperience);

            // act & assert
            NUnit.Framework.Assert.IsNotNull(expService.GetExperienceById(It.IsAny <int>()));
        }
        public void RemoveExperience(int resumeId, int experienceId)
        {
            Resume resume = Database.Resumes.Get(resumeId);

            if (resume == null)
            {
                throw new ArgumentOutOfRangeException("Not found resume");
            }

            ResumesExperience experience = resume.ResumesExperiences.Where(x => x.Id == experienceId).First();

            if (experience == null)
            {
                throw new ArgumentOutOfRangeException("Not found experience");
            }

            resume.ResumesExperiences.Remove(experience);
            Database.Resumes.Update(resume);
            Database.Save();
        }
        protected override void Seed(WorkBaseContext context)
        {
            base.Seed(context);

            #region Roles

            ApplicationRole rolAdmin = new ApplicationRole {
                Name = "admin"
            };
            ApplicationRole role1 = new ApplicationRole {
                Name = "employer"
            };
            ApplicationRole role2 = new ApplicationRole {
                Name = "worker"
            };

            ApplicationRoleManager roleManager = new ApplicationRoleManager(new RoleStore <ApplicationRole>(context));
            roleManager.Create(rolAdmin);
            roleManager.Create(role1);
            roleManager.Create(role2);
            #endregion

            #region Users

            var userAdmin = new ApplicationUser {
                Email = "*****@*****.**", UserName = "******"
            };
            var userEmployer = new ApplicationUser {
                Email = "*****@*****.**", UserName = "******"
            };
            var userWorker = new ApplicationUser {
                Email = "*****@*****.**", UserName = "******"
            };
            var userWorker2 = new ApplicationUser {
                Email = "*****@*****.**", UserName = "******"
            };
            var userWorker3 = new ApplicationUser {
                Email = "*****@*****.**", UserName = "******"
            };

            ApplicationUserManager userManager = new ApplicationUserManager(new UserStore <ApplicationUser>(context));
            userManager.Create(userAdmin, "adminpassword");
            userManager.Create(userEmployer, "employerpassword");
            userManager.Create(userWorker, "workerpassword");
            userManager.Create(userWorker2, "workerpassword");
            userManager.Create(userWorker3, "workerpassword");

            userManager.AddToRole(userAdmin.Id, "admin");
            userManager.AddToRole(userEmployer.Id, "employer");
            userManager.AddToRole(userWorker.Id, "worker");
            userManager.AddToRole(userWorker2.Id, "worker");
            userManager.AddToRole(userWorker3.Id, "worker");

            var profileAdmin = new User {
                Id = userAdmin.Id, Surname = "AdminSurname", Name = "AdminName"
            };
            var profileEmployer = new User {
                Id = userEmployer.Id, Surname = "EmployerSurname", Name = "EmployerName"
            };
            var profileWorker = new User {
                Id = userWorker.Id, Surname = "WorkerSurname", Name = "WorkerName"
            };
            var profileWorker2 = new User {
                Id = userWorker2.Id, Surname = "Worker2Surname", Name = "Worker2Name"
            };
            var profileWorker3 = new User {
                Id = userWorker3.Id, Surname = "Worker3Surname", Name = "Worker3Name"
            };

            context.UsersProfiles.Add(profileAdmin);
            context.UsersProfiles.Add(profileEmployer);
            context.UsersProfiles.Add(profileWorker);
            context.UsersProfiles.Add(profileWorker2);
            context.UsersProfiles.Add(profileWorker3);
            #endregion

            #region Rubrics

            var rubric1 = new Rubric {
                Id = 1, Name = "IT"
            };
            var rubric2 = new Rubric {
                Id = 2, Name = "HR специалисты - Бизнес-тренеры"
            };
            var rubric3 = new Rubric {
                Id = 3, Name = "Автобизнес - Сервисное обслуживание"
            };
            var rubric4 = new Rubric {
                Id = 4, Name = "Административный персонал - Водители - Курьеры"
            };
            var rubric5 = new Rubric {
                Id = 5, Name = "Банки - Инвестиции - Лизинг"
            };

            context.Rubrics.Add(rubric1);
            context.Rubrics.Add(rubric2);
            context.Rubrics.Add(rubric3);
            context.Rubrics.Add(rubric4);
            context.Rubrics.Add(rubric5);
            #endregion

            #region Resumes

            var resume1 = new Resume
            {
                Id              = 1,
                Title           = "Junior QA Engineer",
                Surname         = "ДА подавись ты своим полем",
                Name            = "Алексей",
                MiddleName      = "И этим тоже",
                Birthday        = new DateTime(1990, 1, 10),
                Gender          = 0,
                City            = "Kiev",
                Phone           = "256-587-1546",
                Email           = "*****@*****.**",
                Skype           = "KarenMDeberry",
                Portfolio       = "https://github.com/xiaoshi316",
                DesiredPosition = "Junior QA Engineer",
                Payment         = "400$",
                Skills          = "Programming languages: Java, C++, Visual Basic.\nDevelopment environment: IntelliJ IDEA, UIPath, AutomationAnywhere\n\nFrameWork: Selenium\n\nVCS : Git",
                UserId          = profileWorker.Id,
                RubricId        = rubric1.Id,
            };
            var resume2 = new Resume
            {
                Id              = 2,
                Title           = "Junior Software Engineer, Support Engineer",
                Surname         = "RuslanS",
                Name            = "Ruslan",
                MiddleName      = "RuslanMN",
                Birthday        = new DateTime(1995, 5, 10),
                Gender          = 0,
                City            = "Kiev",
                Phone           = "205-324-5857",
                Email           = "*****@*****.**",
                Skype           = "NikitaVagin",
                Portfolio       = "https://github.com/javlonsodikov",
                DesiredPosition = "Junior",
                Payment         = "800$",
                Skills          = "За время работы на ЗМК \"Запорожсталь\" приобрел солидный опыт написания и оптимизации SQL-запросов СУБД Oracle, также есть много разработок клиент-серверного ПО на Delphi под СУБД Interbase (Fierbird/Yaffi - полная разработка БД с нуля с написанием хранимых процедур, функций, триггеров и т.п.), большой опыт использования c модифицированным мною кодом FastReport, есть опыт создания своих Delphi-компонент для IDE Delphi, также большой опыт в написании VB-скриптов в MS-Excel и MS-Word  с использованием ADO/ODBC (СУБД Oracle/IB). Опыт работы с приложением Toad. Также был админом SQL-серверов Yaffil/Firebird, других специализированных серверов предприятия.",
                UserId          = profileWorker.Id,
                RubricId        = rubric2.Id,
            };
            var resume3 = new Resume
            {
                Id              = 3,
                Title           = "Программист С++, JS, PHP, Delphi, SQL",
                Surname         = "Фамилия чела",
                Name            = "Вячеслав",
                MiddleName      = "Анатольевич",
                Birthday        = new DateTime(1990, 1, 10),
                Gender          = 0,
                City            = "Kiev",
                Phone           = "256-587-1546",
                Email           = "*****@*****.**",
                Skype           = "KarenMDeberry",
                Portfolio       = "https://github.com/xiaoshi316",
                DesiredPosition = "Junior QA Engineer",
                Payment         = "400$",
                Skills          = "Programming languages: Java, C++, Visual Basic.\nDevelopment environment: IntelliJ IDEA, UIPath, AutomationAnywhere\n\nFrameWork: Selenium\n\nVCS : Git",
                UserId          = profileWorker2.Id,
                RubricId        = rubric3.Id,
            };

            context.Resumes.Add(resume1);
            context.Resumes.Add(resume2);
            context.Resumes.Add(resume3);
            #endregion

            #region ResumesExperience

            var experience1 = new ResumesExperience
            {
                Id        = 1,
                Company   = "Playtech",
                Position  = "Java/javascript developer",
                StartDate = new DateTime(2013, 10, 1),
                ResumeId  = resume1.Id,
            };
            var experience2 = new ResumesExperience
            {
                Id         = 2,
                Company    = "IT company",
                Position   = "C# developer ",
                StartDate  = new DateTime(2011, 03, 1),
                FinishDate = new DateTime(2013, 10, 1),
                ResumeId   = resume1.Id,
            };
            var experience3 = new ResumesExperience
            {
                Id         = 3,
                Company    = "Private enterprise",
                Position   = "PHP programmer",
                StartDate  = new DateTime(2007, 04, 1),
                FinishDate = new DateTime(2010, 06, 1),
                ResumeId   = resume2.Id,
            };

            context.ResumesExperiences.Add(experience1);
            context.ResumesExperiences.Add(experience2);
            context.ResumesExperiences.Add(experience3);
            #endregion

            #region Careers

            var career1 = new Career
            {
                Id           = 1,
                Title        = "QA Engineer",
                Company      = "Codeminders",
                City         = "Киев",
                ContactName  = "Codeminders",
                ContactPhone = "207-698-2959",
                Site         = "http://www.codeminders.com/",
                Desctiption  = "Based in the US since 2004,Codeminders develops software products for high-tech companies located predominantly in the Silicon Valley of California. While we specialize in a broad range of applications, our primary focus is on modern technologies such as social networks, mobile applications, video conference systems, cloud computing, etc. We have a constantly growing team of top-level specialists with proven ability to professionally design and deliver a diverse spectrum of projects. Codemindersis not a typical outsourcing company. Our clients select us primarily because we master the most challenging and diverse projects delivering them successfully and on schedule.",
                RubricId     = rubric1.Id,
                UserId       = profileEmployer.Id,
            };
            var career2 = new Career
            {
                Id           = 2,
                Title        = "C++ Developper",
                Company      = "CompanyName",
                City         = "Черкассы",
                ContactName  = "ContactName",
                ContactPhone = "207-698-2959",
                Site         = "http://www.companysite.com/",
                Desctiption  = "Based in the US since 2004,Codeminders develops software products for high-tech companies located predominantly in the Silicon Valley of California. While we specialize in a broad range of applications, our primary focus is on modern technologies such as social networks, mobile applications, video conference systems, cloud computing, etc. We have a constantly growing team of top-level specialists with proven ability to professionally design and deliver a diverse spectrum of projects. Codemindersis not a typical outsourcing company. Our clients select us primarily because we master the most challenging and diverse projects delivering them successfully and on schedule.",
                RubricId     = rubric1.Id,
                UserId       = profileEmployer.Id,
            };

            context.Careers.Add(career1);
            context.Careers.Add(career2);
            #endregion

            #region Offers

            var offer1 = new Offer
            {
                Id       = 1,
                ResumeId = resume1.Id,
                CareerId = career1.Id,
                DateSend = new DateTime(2018, 5, 15),
                Viewed   = false
            };
            var offer2 = new Offer
            {
                Id       = 2,
                ResumeId = resume1.Id,
                CareerId = career2.Id,
                DateSend = new DateTime(2018, 5, 10),
                Viewed   = false
            };

            context.Offers.Add(offer1);
            context.Offers.Add(offer2);
            #endregion

            context.SaveChanges();
        }