function testMultiplePayStubAccruals() { //Test all parts of multiple pay stubs that span a year boundary. //Start 6 pay periods from the last one. Should be beginning/end of December, //Its the TRANSACTION date that counts $start_pay_period_id = count($this->pay_period_objs) - 8; Debug::text('Starting Pay Period: ' . TTDate::getDate('DATE+TIME', $this->pay_period_objs[$start_pay_period_id]->getStartDate()), __FILE__, __LINE__, __METHOD__, 10); // // First Pay Stub // //Test UnUsed YTD entries... $pay_stub = new PayStubFactory(); $pay_stub->setUser($this->user_id); $pay_stub->setCurrency($pay_stub->getUserObject()->getCurrency()); $pay_stub->setPayPeriod($this->pay_period_objs[$start_pay_period_id]->getId()); $pay_stub->setStatus('NEW'); $pay_stub->setDefaultDates(); $pay_stub->loadPreviousPayStub(); $pse_accounts = array('regular_time' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Regular Time'), 'over_time_1' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Over Time 1'), 'vacation_accrual_release' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Vacation Accrual Release'), 'federal_income_tax' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 20, 'Federal Income Tax'), 'state_income_tax' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 20, 'State Income Tax'), 'medicare' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 30, 'Medicare'), 'state_unemployment' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 30, 'State Unemployment Ins.'), 'vacation_accrual' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 50, 'Vacation Accrual')); $pay_stub->addEntry($pse_accounts['regular_time'], 100.01); $pay_stub->addEntry($pse_accounts['regular_time'], 10.01); $pay_stub->addEntry($pse_accounts['over_time_1'], 100.02); //Adjust YTD balance, emulating a YTD PS amendment $pay_stub->addEntry($pse_accounts['vacation_accrual'], -340.38, NULL, NULL, 'Vacation Accrual YTD adjustment', -1, 0, 0); $pay_stub->addEntry($pse_accounts['vacation_accrual_release'], 6.13); $pay_stub->addEntry($pse_accounts['federal_income_tax'], 50.01); $pay_stub->addEntry($pse_accounts['state_income_tax'], 25.04); $pay_stub->addEntry($pse_accounts['medicare'], 10.01); $pay_stub->addEntry($pse_accounts['state_unemployment'], 15.05); $pay_stub->addEntry($pse_accounts['vacation_accrual'], 60.03); $pay_stub->setEnableProcessEntries(TRUE); $pay_stub->processEntries(); if ($pay_stub->isValid() == TRUE) { Debug::text('Pay Stub is valid, final save.', __FILE__, __LINE__, __METHOD__, 10); $pay_stub_id = $pay_stub->Save(); } $pse_arr = $this->getPayStubEntryArray($pay_stub_id); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][0]['amount'], '100.01'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][0]['ytd_amount'], '0.00'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][1]['amount'], '10.01'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][1]['ytd_amount'], '110.02'); $this->assertEquals($pse_arr[$pse_accounts['over_time_1']][0]['amount'], '100.02'); $this->assertEquals($pse_arr[$pse_accounts['over_time_1']][0]['ytd_amount'], '100.02'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual_release']][0]['amount'], '6.13'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual_release']][0]['ytd_amount'], '6.13'); $this->assertEquals($pse_arr[$pse_accounts['federal_income_tax']][0]['amount'], '50.01'); $this->assertEquals($pse_arr[$pse_accounts['federal_income_tax']][0]['ytd_amount'], '50.01'); $this->assertEquals($pse_arr[$pse_accounts['state_income_tax']][0]['amount'], '25.04'); $this->assertEquals($pse_arr[$pse_accounts['state_income_tax']][0]['ytd_amount'], '25.04'); $this->assertEquals($pse_arr[$pse_accounts['medicare']][0]['amount'], '10.01'); $this->assertEquals($pse_arr[$pse_accounts['medicare']][0]['ytd_amount'], '10.01'); $this->assertEquals($pse_arr[$pse_accounts['state_unemployment']][0]['amount'], '15.05'); $this->assertEquals($pse_arr[$pse_accounts['state_unemployment']][0]['ytd_amount'], '15.05'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][0]['amount'], '-340.38'); //YTD adjustment $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][0]['ytd_amount'], '0.00'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][1]['amount'], '-6.13'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][1]['ytd_amount'], '0.00'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][2]['amount'], '60.03'); //YTD adjustment $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][2]['ytd_amount'], '-286.48'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_gross']][0]['amount'], '216.17'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_gross']][0]['ytd_amount'], '216.17'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_deductions']][0]['amount'], '75.05'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_deductions']][0]['ytd_amount'], '75.05'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['net_pay']][0]['amount'], '141.12'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['net_pay']][0]['ytd_amount'], '141.12'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['employer_contribution']][0]['amount'], '25.06'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['employer_contribution']][0]['ytd_amount'], '25.06'); unset($pse_arr, $pay_stub_id, $pay_stub); // // // //Second Pay Stub // // // $pay_stub = new PayStubFactory(); $pay_stub->setUser($this->user_id); $pay_stub->setCurrency($pay_stub->getUserObject()->getCurrency()); $pay_stub->setPayPeriod($this->pay_period_objs[$start_pay_period_id + 1]->getId()); $pay_stub->setStatus('NEW'); $pay_stub->setDefaultDates(); $pay_stub->loadPreviousPayStub(); $pse_accounts = array('regular_time' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Regular Time'), 'over_time_1' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Over Time 1'), 'vacation_accrual_release' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Vacation Accrual Release'), 'federal_income_tax' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 20, 'Federal Income Tax'), 'state_income_tax' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 20, 'State Income Tax'), 'medicare' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 30, 'Medicare'), 'state_unemployment' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 30, 'State Unemployment Ins.'), 'vacation_accrual' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 50, 'Vacation Accrual')); $pay_stub->addEntry($pse_accounts['regular_time'], 198.01); $pay_stub->addEntry($pse_accounts['regular_time'], 12.01); //$pay_stub->addEntry( $pse_accounts['over_time_1'], 111.02 ); //$pay_stub->addEntry( $pse_accounts['vacation_accrual_release'], 1.03 ); $pay_stub->addEntry($pse_accounts['federal_income_tax'], 53.01); $pay_stub->addEntry($pse_accounts['state_income_tax'], 27.04); $pay_stub->addEntry($pse_accounts['medicare'], 13.04); $pay_stub->addEntry($pse_accounts['state_unemployment'], 16.09); $pay_stub->addEntry($pse_accounts['vacation_accrual'], 240.01); $pay_stub->setEnableProcessEntries(TRUE); $pay_stub->processEntries(); if ($pay_stub->isValid() == TRUE) { Debug::text('Pay Stub is valid, final save.', __FILE__, __LINE__, __METHOD__, 10); $pay_stub_id = $pay_stub->Save(); } $pse_arr = $this->getPayStubEntryArray($pay_stub_id); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][0]['amount'], '198.01'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][0]['ytd_amount'], '0.00'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][1]['amount'], '12.01'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][1]['ytd_amount'], '320.04'); $this->assertEquals($pse_arr[$pse_accounts['over_time_1']][0]['amount'], '0.00'); $this->assertEquals($pse_arr[$pse_accounts['over_time_1']][0]['ytd_amount'], '100.02'); //$this->assertEquals( $pse_arr[$pse_accounts['vacation_accrual_release']][0]['amount'], '1.03' ); //$this->assertEquals( $pse_arr[$pse_accounts['vacation_accrual_release']][0]['ytd_amount'], '2.03' ); $this->assertEquals($pse_arr[$pse_accounts['federal_income_tax']][0]['amount'], '53.01'); $this->assertEquals($pse_arr[$pse_accounts['federal_income_tax']][0]['ytd_amount'], '103.02'); $this->assertEquals($pse_arr[$pse_accounts['state_income_tax']][0]['amount'], '27.04'); $this->assertEquals($pse_arr[$pse_accounts['state_income_tax']][0]['ytd_amount'], '52.08'); $this->assertEquals($pse_arr[$pse_accounts['medicare']][0]['amount'], '13.04'); $this->assertEquals($pse_arr[$pse_accounts['medicare']][0]['ytd_amount'], '23.05'); $this->assertEquals($pse_arr[$pse_accounts['state_unemployment']][0]['amount'], '16.09'); $this->assertEquals($pse_arr[$pse_accounts['state_unemployment']][0]['ytd_amount'], '31.14'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][0]['amount'], '240.01'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][0]['ytd_amount'], '-46.47'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_gross']][0]['amount'], '210.02'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_gross']][0]['ytd_amount'], '426.19'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_deductions']][0]['amount'], '80.05'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_deductions']][0]['ytd_amount'], '155.10'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['net_pay']][0]['amount'], '129.97'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['net_pay']][0]['ytd_amount'], '271.09'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['employer_contribution']][0]['amount'], '29.13'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['employer_contribution']][0]['ytd_amount'], '54.19'); unset($pse_arr, $pay_stub_id, $pay_stub); // // Third Pay Stub // //Test UnUsed YTD entries... $pay_stub = new PayStubFactory(); $pay_stub->setUser($this->user_id); $pay_stub->setCurrency($pay_stub->getUserObject()->getCurrency()); $pay_stub->setPayPeriod($this->pay_period_objs[$start_pay_period_id + 2]->getId()); $pay_stub->setStatus('NEW'); $pay_stub->setDefaultDates(); $pay_stub->loadPreviousPayStub(); $pse_accounts = array('regular_time' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Regular Time'), 'over_time_1' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Over Time 1'), 'vacation_accrual_release' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 10, 'Vacation Accrual Release'), 'federal_income_tax' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 20, 'Federal Income Tax'), 'state_income_tax' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 20, 'State Income Tax'), 'medicare' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 30, 'Medicare'), 'state_unemployment' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 30, 'State Unemployment Ins.'), 'vacation_accrual' => CompanyDeductionFactory::getPayStubEntryAccountByCompanyIDAndTypeAndFuzzyName($this->company_id, 50, 'Vacation Accrual')); $pay_stub->addEntry($pse_accounts['regular_time'], 100.01); $pay_stub->addEntry($pse_accounts['regular_time'], 10.01); $pay_stub->addEntry($pse_accounts['over_time_1'], 100.02); $pay_stub->addEntry($pse_accounts['vacation_accrual_release'], 1.0); $pay_stub->addEntry($pse_accounts['federal_income_tax'], 50.01); $pay_stub->addEntry($pse_accounts['state_income_tax'], 25.04); $pay_stub->addEntry($pse_accounts['medicare'], 10.01); $pay_stub->addEntry($pse_accounts['state_unemployment'], 15.05); $pay_stub->addEntry($pse_accounts['vacation_accrual'], 65.01000000000001); $pay_stub->setEnableProcessEntries(TRUE); $pay_stub->processEntries(); if ($pay_stub->isValid() == TRUE) { $pay_stub_id = $pay_stub->Save(); Debug::text('Pay Stub is valid, final save, ID: ' . $pay_stub_id, __FILE__, __LINE__, __METHOD__, 10); } $pse_arr = $this->getPayStubEntryArray($pay_stub_id); // // IN NEW YEAR, YTD amounts are zero'd! // $this->assertEquals($pse_arr[$pse_accounts['regular_time']][0]['amount'], '100.01'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][0]['ytd_amount'], '0.00'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][1]['amount'], '10.01'); $this->assertEquals($pse_arr[$pse_accounts['regular_time']][1]['ytd_amount'], '430.06'); $this->assertEquals($pse_arr[$pse_accounts['over_time_1']][0]['amount'], '100.02'); $this->assertEquals($pse_arr[$pse_accounts['over_time_1']][0]['ytd_amount'], '200.04'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual_release']][0]['amount'], '1.00'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual_release']][0]['ytd_amount'], '7.13'); $this->assertEquals($pse_arr[$pse_accounts['federal_income_tax']][0]['amount'], '50.01'); $this->assertEquals($pse_arr[$pse_accounts['federal_income_tax']][0]['ytd_amount'], '153.03'); $this->assertEquals($pse_arr[$pse_accounts['state_income_tax']][0]['amount'], '25.04'); $this->assertEquals($pse_arr[$pse_accounts['state_income_tax']][0]['ytd_amount'], '77.12'); $this->assertEquals($pse_arr[$pse_accounts['medicare']][0]['amount'], '10.01'); $this->assertEquals($pse_arr[$pse_accounts['medicare']][0]['ytd_amount'], '33.06'); $this->assertEquals($pse_arr[$pse_accounts['state_unemployment']][0]['amount'], '15.05'); $this->assertEquals($pse_arr[$pse_accounts['state_unemployment']][0]['ytd_amount'], '46.19'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][0]['amount'], '-1.00'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][0]['ytd_amount'], '0.00'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][1]['amount'], '65.01'); $this->assertEquals($pse_arr[$pse_accounts['vacation_accrual']][1]['ytd_amount'], '17.54'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_gross']][0]['amount'], '211.04'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_gross']][0]['ytd_amount'], '637.23'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_deductions']][0]['amount'], '75.05'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['total_deductions']][0]['ytd_amount'], '230.15'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['net_pay']][0]['amount'], '135.99'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['net_pay']][0]['ytd_amount'], '407.08'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['employer_contribution']][0]['amount'], '25.06'); $this->assertEquals($pse_arr[$this->pay_stub_account_link_arr['employer_contribution']][0]['ytd_amount'], '79.25'); unset($pse_arr, $pay_stub_id, $pay_stub); return TRUE; }