mirror of
https://github.com/kevinpapst/kimai2.git
synced 2025-04-19 11:39:48 +00:00
128 lines
4.6 KiB
PHP
128 lines
4.6 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Kimai time-tracking app.
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace App\Tests\Invoice\Calculator;
|
|
|
|
use App\Entity\Activity;
|
|
use App\Entity\Customer;
|
|
use App\Entity\InvoiceTemplate;
|
|
use App\Entity\Project;
|
|
use App\Entity\Timesheet;
|
|
use App\Entity\User;
|
|
use App\Invoice\Calculator\UserInvoiceCalculator;
|
|
use App\Invoice\CalculatorInterface;
|
|
use App\Repository\Query\InvoiceQuery;
|
|
use App\Tests\Invoice\DebugFormatter;
|
|
use App\Tests\Mocks\InvoiceModelFactoryFactory;
|
|
|
|
/**
|
|
* @covers \App\Invoice\Calculator\UserInvoiceCalculator
|
|
* @covers \App\Invoice\Calculator\AbstractMergedCalculator
|
|
* @covers \App\Invoice\Calculator\AbstractCalculator
|
|
*/
|
|
class UserInvoiceCalculatorTest extends AbstractCalculatorTestCase
|
|
{
|
|
protected function getCalculator(): CalculatorInterface
|
|
{
|
|
return new UserInvoiceCalculator();
|
|
}
|
|
|
|
public function testWithMultipleEntries(): void
|
|
{
|
|
$customer = new Customer('foo');
|
|
$template = new InvoiceTemplate();
|
|
$template->setVat(19);
|
|
|
|
$activity = new Activity();
|
|
$activity->setName('activity description');
|
|
|
|
$user1 = $this->getMockBuilder(User::class)->onlyMethods(['getId'])->disableOriginalConstructor()->getMock();
|
|
$user1->method('getId')->willReturn(1);
|
|
|
|
$user2 = $this->getMockBuilder(User::class)->onlyMethods(['getId'])->disableOriginalConstructor()->getMock();
|
|
$user2->method('getId')->willReturn(2);
|
|
|
|
$user3 = $this->getMockBuilder(User::class)->onlyMethods(['getId'])->disableOriginalConstructor()->getMock();
|
|
$user3->method('getId')->willReturn(3);
|
|
|
|
$timesheet = new Timesheet();
|
|
$timesheet->setBegin(new \DateTime('2018-11-29'));
|
|
$timesheet->setEnd(new \DateTime());
|
|
$timesheet->setDuration(3600);
|
|
$timesheet->setRate(293.27);
|
|
$timesheet->setUser($user1);
|
|
$timesheet->setActivity($activity);
|
|
$timesheet->setProject((new Project())->setName('bar'));
|
|
|
|
$timesheet2 = new Timesheet();
|
|
$timesheet2->setBegin(new \DateTime('2018-11-28'));
|
|
$timesheet2->setEnd(new \DateTime());
|
|
$timesheet2->setDuration(400);
|
|
$timesheet2->setRate(84.75);
|
|
$timesheet2->setUser($user2);
|
|
$timesheet2->setActivity($activity);
|
|
$timesheet2->setProject((new Project())->setName('bar'));
|
|
|
|
$timesheet3 = new Timesheet();
|
|
$timesheet3->setBegin(new \DateTime('2018-11-08'));
|
|
$timesheet3->setEnd(new \DateTime());
|
|
$timesheet3->setDuration(1800);
|
|
$timesheet3->setRate(111.11);
|
|
$timesheet3->setUser($user1);
|
|
$timesheet3->setActivity($activity);
|
|
$timesheet3->setProject((new Project())->setName('bar'));
|
|
|
|
$timesheet4 = new Timesheet();
|
|
$timesheet4->setBegin(new \DateTime('2018-11-28'));
|
|
$timesheet4->setEnd(new \DateTime());
|
|
$timesheet4->setDuration(400);
|
|
$timesheet4->setRate(1947.99);
|
|
$timesheet4->setUser($user2);
|
|
$timesheet4->setActivity($activity);
|
|
$timesheet4->setProject((new Project())->setName('bar'));
|
|
|
|
$timesheet5 = new Timesheet();
|
|
$timesheet5->setBegin(new \DateTime());
|
|
$timesheet5->setEnd(new \DateTime());
|
|
$timesheet5->setDuration(400);
|
|
$timesheet5->setRate(84);
|
|
$timesheet5->setUser($user3);
|
|
$timesheet5->setActivity($activity);
|
|
$timesheet5->setProject((new Project())->setName('bar'));
|
|
|
|
$entries = [$timesheet, $timesheet2, $timesheet3, $timesheet4, $timesheet5];
|
|
|
|
$query = new InvoiceQuery();
|
|
$query->addActivity($activity);
|
|
|
|
$model = (new InvoiceModelFactoryFactory($this))->create()->createModel(new DebugFormatter(), $customer, $template, $query);
|
|
$model->addEntries($entries);
|
|
|
|
$sut = $this->getCalculator();
|
|
$sut->setModel($model);
|
|
|
|
self::assertEquals('user', $sut->getId());
|
|
self::assertEquals(3000.13, $sut->getTotal());
|
|
self::assertEquals(19, $sut->getVat());
|
|
self::assertEquals('EUR', $model->getCurrency());
|
|
self::assertEquals(2521.12, $sut->getSubtotal());
|
|
self::assertEquals(6600, $sut->getTimeWorked());
|
|
|
|
$entries = $sut->getEntries();
|
|
self::assertCount(3, $entries);
|
|
self::assertEquals(404.38, $entries[0]->getRate());
|
|
self::assertEquals(2032.74, $entries[1]->getRate());
|
|
self::assertEquals(84, $entries[2]->getRate());
|
|
}
|
|
|
|
public function testDescriptionByTimesheet(): void
|
|
{
|
|
$this->assertDescription($this->getCalculator(), false, false);
|
|
}
|
|
}
|