Added some tests for important entity methods.

This commit is contained in:
Jan Böhmer 2019-11-09 00:31:42 +01:00
parent 0663a00df8
commit 89258bc102
18 changed files with 480 additions and 160 deletions

View file

@ -0,0 +1,38 @@
<?php
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony)
*
* Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*
*/
namespace App\Tests\Entity\Attachments;
use App\Entity\Attachments\AttachmentType;
use Doctrine\Common\Collections\Collection;
use PHPUnit\Framework\TestCase;
class AttachmentTypeTest extends TestCase
{
public function testEmptyState()
{
$attachment_type = new AttachmentType();
$this->assertInstanceOf(Collection::class, $attachment_type->getAttachmentsForType());
$this->assertEmpty($attachment_type->getFiletypeFilter());
}
}

View file

@ -1,101 +0,0 @@
<?php
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony)
*
* Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*
*/
namespace App\Tests\Entity;
use App\Entity\Parts\MeasurementUnit;
use App\Entity\Parts\Part;
use App\Entity\Parts\PartLot;
use PHPUnit\Framework\TestCase;
/**
* Here we test the instock related functions of part class (functions in InstockTrait)
* @package App\Tests\Entity
*/
class PartInstockTest extends TestCase
{
protected $float_unit;
protected $int_unit;
public function setUp()
{
parent::setUp(); // TODO: Change the autogenerated stub
$this->float_unit = new MeasurementUnit();
$this->float_unit->setIsInteger(false);
$this->int_unit = new MeasurementUnit();
$this->int_unit->setIsInteger(true);
}
public function testUseFloatAmount()
{
$part = new Part();
$part->setPartUnit(null);
$this->assertFalse($part->useFloatAmount());
$part->setPartUnit($this->float_unit);
$this->assertTrue($part->useFloatAmount());
$part->setPartUnit($this->int_unit);
$this->assertFalse($part->useFloatAmount());
}
public function testGetMinAmount()
{
$part = new Part();
$part->setMinAmount(10.32);
$part->setPartUnit(null);
$this->assertEquals(10.0, $part->getMinAmount());
$part->setPartUnit($this->float_unit);
$this->assertEquals(10.32, $part->getMinAmount());
}
public function testAddPartLot()
{
$part = new Part();
//Part must be empty after creation
$this->assertEmpty($part->getPartLots());
$part_lot = new PartLot();
$part->addPartLot($part_lot);
$this->assertCount(1, $part->getPartLots());
//PartLot must now be assigned to part
$this->assertEquals($part, $part_lot->getPart());
}
public function testGetAmountSum()
{
$part = new Part();
$part->addPartLot((new PartLot())->setAmount(5.42));
$part->addPartLot((new PartLot())->setAmount(0.4));
$part->addPartLot((new PartLot())->setAmount(10.4));
$part->addPartLot((new PartLot())->setAmount(100)->setInstockUnknown(true));
$part->setPartUnit(null);
//It is important that we get 15 here (values are round and then summed), not 16 (sum and then round)
$this->assertEquals(15, $part->getAmountSum());
$part->setPartUnit($this->float_unit);
$this->assertEquals(16.22, $part->getAmountSum());
}
}

View file

@ -0,0 +1,44 @@
<?php
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony)
*
* Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*
*/
namespace App\Tests\Entity\Parts;
use App\Entity\Parts\PartLot;
use PHPUnit\Framework\TestCase;
class PartLotTest extends TestCase
{
public function testIsExpired()
{
$lot = new PartLot();
$this->assertNull($lot->isExpired(), 'Lot must be return null when no Expiration date is set!');
$datetime = new \DateTime();
$lot->setExpirationDate($datetime->setTimestamp(strtotime('now +1 hour')));
$this->assertFalse($lot->isExpired(), 'Lot with expiration date in the future must not be expired!');
$lot->setExpirationDate($datetime->setTimestamp(strtotime('now -1 hour')));
$this->assertTrue($lot->isExpired(), 'Lot with expiration date in the past must be expired!');
}
}

View file

@ -0,0 +1,112 @@
<?php
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony)
*
* Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*
*/
namespace App\Tests\Entity\Parts;
use App\Entity\Parts\MeasurementUnit;
use App\Entity\Parts\Part;
use App\Entity\Parts\PartLot;
use Doctrine\Common\Collections\Collection;
use PHPUnit\Framework\TestCase;
class PartTest extends TestCase
{
public function testAddRemovePartLot()
{
$part = new Part();
$this->assertInstanceOf(Collection::class, $part->getPartLots());
$this->assertTrue($part->getPartLots()->isEmpty());
//Add element
$lot = new PartLot();
$part->addPartLot($lot);
$this->assertEquals($part, $lot->getPart());
$this->assertEquals(1, $part->getPartLots()->count());
//Remove element
$part->removePartLot($lot);
$this->assertTrue($part->getPartLots()->isEmpty());
}
public function testGetSetMinamount()
{
$part = new Part();
$measurement_unit = new MeasurementUnit();
//Without an set measurement unit the part must return an int
$part->setMinAmount(1.345);
$this->assertEquals(1, $part->getMinAmount());
//If an non int-based unit is assigned, an float is returned
$part->setPartUnit($measurement_unit);
$this->assertEquals(1.345, $part->getMinAmount());
//If an int-based unit is assigned an int is returned
$measurement_unit->setIsInteger(true);
$this->assertEquals(1, $part->getMinAmount());
}
public function testUseFloatAmount()
{
$part = new Part();
$measurement_unit = new MeasurementUnit();
//Without an measurement unit int should be used
$this->assertFalse($part->useFloatAmount());
$part->setPartUnit($measurement_unit);
$this->assertTrue($part->useFloatAmount());
$measurement_unit->setIsInteger(true);
$this->assertFalse($part->useFloatAmount());
}
public function testGetAmountSum()
{
$part = new Part();
$measurement_unit = new MeasurementUnit();
$datetime = new \DateTime();
$this->assertEquals(0, $part->getAmountSum());
$part->addPartLot((new PartLot())->setAmount(3.141));
$part->addPartLot((new PartLot())->setAmount(10.0));
$part->addPartLot((new PartLot())->setAmount(5)->setInstockUnknown(true));
$part->addPartLot(
(new PartLot())
->setAmount(6)
->setExpirationDate($datetime->setTimestamp(strtotime('now -1 hour')))
);
$this->assertEquals(13, $part->getAmountSum());
$part->setPartUnit($measurement_unit);
$this->assertEquals(13.141, $part->getAmountSum());
//1 billion part lot
$part->addPartLot((new PartLot())->setAmount(1000000000));
$this->assertEquals(1000000013.141, $part->getAmountSum());
$measurement_unit->setIsInteger(true);
$this->assertEquals(1000000013, $part->getAmountSum());
}
}

View file

@ -0,0 +1,44 @@
<?php
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony)
*
* Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*
*/
namespace App\Tests\Entity\PriceSystem;
use App\Entity\PriceInformations\Currency;
use PHPUnit\Framework\TestCase;
class CurrencyTest extends TestCase
{
public function testGetInverseExchangeRate()
{
$currency = new Currency();
//By default the inverse exchange rate is not set:
$this->assertNull($currency->getInverseExchangeRate());
$currency->setExchangeRate('0');
$this->assertNull($currency->getInverseExchangeRate());
$currency->setExchangeRate("1.45643");
$this->assertEquals("0.68661", $currency->getInverseExchangeRate());
}
}

View file

@ -0,0 +1,65 @@
<?php
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony)
*
* Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*
*/
namespace App\Tests\Entity\PriceSystem;
use App\Entity\PriceInformations\Orderdetail;
use App\Entity\PriceInformations\Pricedetail;
use Doctrine\Common\Collections\Collection;
use PHPUnit\Framework\TestCase;
class OrderdetailTest extends TestCase
{
public function testAddRemovePricdetails()
{
$orderdetail = new Orderdetail();
$this->assertInstanceOf(Collection::class, $orderdetail->getPricedetails());
$this->assertTrue($orderdetail->getPricedetails()->isEmpty());
$pricedetail = new Pricedetail();
$orderdetail->addPricedetail($pricedetail);
$this->assertEquals($orderdetail, $pricedetail->getOrderdetail());
$this->assertEquals(1, $orderdetail->getPricedetails()->count());
//After removal of the pricedetail, the orderdetail must be empty again
$orderdetail->removePricedetail($pricedetail);
$this->assertTrue($orderdetail->getPricedetails()->isEmpty());
}
public function testFindPriceForQty()
{
$price0 = (new Pricedetail())->setMinDiscountQuantity(0.23);
$price1 = (new Pricedetail())->setMinDiscountQuantity(1);
$price5 = (new Pricedetail())->setMinDiscountQuantity(5.3);
$orderdetail = (new Orderdetail())->addPricedetail($price0)->addPricedetail($price1)->addPricedetail($price5);
$this->assertNull($orderdetail->findPriceForQty(0));
$this->assertNull($orderdetail->findPriceForQty(0.1));
$this->assertEquals($price0, $orderdetail->findPriceForQty(0.5));
$this->assertEquals($price1, $orderdetail->findPriceForQty(1));
$this->assertEquals($price1, $orderdetail->findPriceForQty(1.5));
$this->assertEquals($price5, $orderdetail->findPriceForQty(5.3));
$this->assertEquals($price5, $orderdetail->findPriceForQty(10000));
}
}

View file

@ -0,0 +1,108 @@
<?php
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony)
*
* Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*
*/
namespace App\Tests\Entity\PriceSystem;
use App\Entity\Parts\MeasurementUnit;
use App\Entity\Parts\Part;
use App\Entity\PriceInformations\Orderdetail;
use App\Entity\PriceInformations\Pricedetail;
use PHPUnit\Framework\TestCase;
class PricedetailTest extends TestCase
{
public function testGetPricePerUnit()
{
$pricedetail = new Pricedetail();
$pricedetail->setPrice('100.234');
$this->assertEquals('100.23400', $pricedetail->getPricePerUnit());
$pricedetail->setPriceRelatedQuantity('2.3');
$this->assertEquals('43.58000', $pricedetail->getPricePerUnit());
$this->assertEquals('139.45600', $pricedetail->getPricePerUnit('3.2'));
$pricedetail->setPrice('10000000.2345'); //Ten million
$pricedetail->setPriceRelatedQuantity(1.234e9); //100 billion
$this->assertEquals('0.00810', $pricedetail->getPricePerUnit());
}
public function testGetPriceRelatedQuantity()
{
$pricedetail = new Pricedetail();
$part = $this->createMock(Part::class);
$part->method('useFloatAmount')->willReturn(false);
$orderdetail = $this->createMock(Orderdetail::class);
$orderdetail->method('getPart')->willReturn($part);
$part2 = $this->createMock(Part::class);
$part2->method('useFloatAmount')->willReturn(true);
$orderdetail2 = $this->createMock(Orderdetail::class);
$orderdetail2->method('getPart')->willReturn($part2);
//By default a price detail returns 1
$this->assertEquals(1, $pricedetail->getPriceRelatedQuantity());
$pricedetail->setOrderdetail($orderdetail);
$pricedetail->setPriceRelatedQuantity(10.23);
$this->assertEquals(10, $pricedetail->getPriceRelatedQuantity());
//Price related quantity must not be zero!
$pricedetail->setPriceRelatedQuantity(0.23);
$this->assertEquals(1, $pricedetail->getPriceRelatedQuantity());
//With an part that has an float amount unit, also values like 0.23 can be returned
$pricedetail->setOrderdetail($orderdetail2);
$this->assertEquals(0.23, $pricedetail->getPriceRelatedQuantity());
}
public function testGetMinDiscountQuantity()
{
$pricedetail = new Pricedetail();
$part = $this->createMock(Part::class);
$part->method('useFloatAmount')->willReturn(false);
$orderdetail = $this->createMock(Orderdetail::class);
$orderdetail->method('getPart')->willReturn($part);
$part2 = $this->createMock(Part::class);
$part2->method('useFloatAmount')->willReturn(true);
$orderdetail2 = $this->createMock(Orderdetail::class);
$orderdetail2->method('getPart')->willReturn($part2);
//By default a price detail returns 1
$this->assertEquals(1, $pricedetail->getMinDiscountQuantity());
$pricedetail->setOrderdetail($orderdetail);
$pricedetail->setMinDiscountQuantity(10.23);
$this->assertEquals(10, $pricedetail->getMinDiscountQuantity());
//Price related quantity must not be zero!
$pricedetail->setMinDiscountQuantity(0.23);
$this->assertEquals(1, $pricedetail->getMinDiscountQuantity());
//With an part that has an float amount unit, also values like 0.23 can be returned
$pricedetail->setOrderdetail($orderdetail2);
$this->assertEquals(0.23, $pricedetail->getMinDiscountQuantity());
}
}

View file

@ -20,7 +20,7 @@
*
*/
namespace App\Tests\Entity;
namespace App\Tests\Entity\UserSystem;
use App\Entity\UserSystem\PermissionsEmbed;
use Doctrine\ORM\Mapping\Embedded;

View file

@ -0,0 +1,41 @@
<?php
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony)
*
* Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*
*/
namespace App\Tests\Entity\UserSystem;
use App\Entity\UserSystem\User;
use PHPUnit\Framework\TestCase;
class UserTest extends TestCase
{
public function testGetFullName()
{
$user = new User();
$user->setName('username');
$user->setFirstName('John');
$user->setLastName('Doe');
$this->assertEquals('John Doe', $user->getFullName(false));
$this->assertEquals('John Doe (username)', $user->getFullName(true));
}
}