public void PayPeriodTest()
        {
            var temp = PayPeriod.FindPayPeriod(new System.DateTime(2020, 7, 14));

            Assert.AreEqual(FirstHalfOfMonth, temp);
            temp = PayPeriod.FindPayPeriod(new System.DateTime(2020, 7, 16));
            Assert.AreEqual(SecondHalfOfMonth, temp);
        }
Esempio n. 2
0
        public static IEnumerable <EmployeeReport> GenerateReport(IEnumerable <PaymentModel> payments)
        {
            Dictionary <int, Dictionary <PayPeriod, EmployeeReport> > employees = new Dictionary <int, Dictionary <PayPeriod, EmployeeReport> >();

            foreach (var payment in payments)
            {
                if (!employees.ContainsKey(payment.EmployeeId))
                {
                    employees.Add(payment.EmployeeId, new Dictionary <PayPeriod, EmployeeReport>());
                }

                var employeePaymentPeriods = employees[payment.EmployeeId];
                var payPeriod = PayPeriod.FindPayPeriod(payment.Date);
                var salary    = PayScale.Payments[payment.JobGroup] * payment.HoursWorked;
                if (!employeePaymentPeriods.ContainsKey(payPeriod))
                {
                    employeePaymentPeriods.Add(payPeriod, new EmployeeReport
                    {
                        EmployeeID = payment.EmployeeId,
                        PayPeriod  = payPeriod
                    });
                }
                employeePaymentPeriods[payPeriod].AmountPaid  += salary;
                employeePaymentPeriods[payPeriod].HoursWorked += payment.HoursWorked;
            }

            var reports = new List <EmployeeReport>();

            foreach (var employee in employees.Values)
            {
                foreach (var report in employee.Values.OrderBy(x => x.PayPeriod))
                {
                    if (report.HoursWorked > OVERTIME_HOURS)
                    {
                        var overTimeReport = new EmployeeReport
                        {
                            EmployeeID = payment.EmployeeId,
                            PayPeriod  = payPeriod
                        };
                        overTimeReport.HoursWorked = report.HoursWorked - OVERTIME_HOURS;
                        overTimeReport.AmountPaid  = overTimeReport.HoursWorked * OVERTIME * PayScale.Payments[report.JobGroup];

                        reports.Add(overTimeReport);

                        report.HoursWorked = (double)OVERTIME;
                        report.AmountPaid  = report.HoursWorked * PayScale.Payments[report.JobGroup];

                        reports.Add(report);
                    }
                    else
                    {
                        reports.Add(report);
                    }
                }
            }

            return(reports);
        }