mirror of
https://github.com/Part-DB/Part-DB-server.git
synced 2025-07-14 12:24:33 +02:00
Added a very basic modal on part info page for changing part instock
Related to issue #201
This commit is contained in:
parent
0e020dab74
commit
ba4085d882
7 changed files with 488 additions and 4 deletions
149
tests/Services/Parts/PartLotWithdrawAddHelperTest.php
Normal file
149
tests/Services/Parts/PartLotWithdrawAddHelperTest.php
Normal file
|
@ -0,0 +1,149 @@
|
|||
<?php
|
||||
|
||||
namespace App\Tests\Services\Parts;
|
||||
|
||||
use App\Entity\Parts\Part;
|
||||
use App\Entity\Parts\PartLot;
|
||||
use App\Entity\Parts\Storelocation;
|
||||
use App\Services\ElementTypeNameGenerator;
|
||||
use App\Services\Parts\PartLotWithdrawAddHelper;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
|
||||
|
||||
class PartLotWithdrawAddHelperTest extends WebTestCase
|
||||
{
|
||||
|
||||
/**
|
||||
* @var PartLotWithdrawAddHelper
|
||||
*/
|
||||
protected $service;
|
||||
|
||||
/** @var Part */
|
||||
private $part;
|
||||
|
||||
/** @var Storelocation */
|
||||
private $storageLocation;
|
||||
/** @var Storelocation */
|
||||
private $full_storageLocation;
|
||||
|
||||
/** @var PartLot */
|
||||
private $partLot1;
|
||||
/** @var PartLot */
|
||||
private $partLot2;
|
||||
/** @var PartLot */
|
||||
private $partLot3;
|
||||
|
||||
/** @var PartLot */
|
||||
private $fullLot;
|
||||
/** @var PartLot */
|
||||
private $lotWithUnknownInstock;
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
//Get an service instance.
|
||||
self::bootKernel();
|
||||
$this->service = self::getContainer()->get(PartLotWithdrawAddHelper::class);
|
||||
|
||||
$this->fillTestData();
|
||||
}
|
||||
|
||||
private function fillTestData(): void
|
||||
{
|
||||
$this->part = new Part();
|
||||
|
||||
$this->storageLocation = new Storelocation();
|
||||
$this->full_storageLocation = new Storelocation();
|
||||
$this->full_storageLocation->setIsFull(true);
|
||||
|
||||
$this->partLot1 = new PartLot();
|
||||
$this->partLot1->setPart($this->part);
|
||||
$this->partLot1->setAmount(10);
|
||||
|
||||
$this->partLot2 = new PartLot();
|
||||
$this->partLot2->setPart($this->part);
|
||||
$this->partLot2->setStorageLocation($this->storageLocation);
|
||||
$this->partLot2->setAmount(2);
|
||||
|
||||
$this->partLot3 = new PartLot();
|
||||
$this->partLot3->setPart($this->part);
|
||||
$this->partLot3->setAmount(0);
|
||||
|
||||
$this->fullLot = new PartLot();
|
||||
$this->fullLot->setPart($this->part);
|
||||
$this->fullLot->setAmount(45);
|
||||
$this->fullLot->setStorageLocation($this->full_storageLocation);
|
||||
|
||||
$this->lotWithUnknownInstock = new PartLot();
|
||||
$this->lotWithUnknownInstock->setPart($this->part);
|
||||
$this->lotWithUnknownInstock->setAmount(5);
|
||||
$this->lotWithUnknownInstock->setInstockUnknown(true);
|
||||
$this->lotWithUnknownInstock->setStorageLocation($this->storageLocation);
|
||||
}
|
||||
|
||||
public function testCanWithdraw()
|
||||
{
|
||||
//Normal lots should be withdrawable
|
||||
$this->assertTrue($this->service->canWithdraw($this->partLot1));
|
||||
$this->assertTrue($this->service->canWithdraw($this->partLot2));
|
||||
$this->assertTrue($this->service->canWithdraw($this->partLot3));
|
||||
|
||||
//Full lots should be withdrawable
|
||||
$this->assertTrue($this->service->canWithdraw($this->fullLot));
|
||||
//Lots with unknown instock should not be withdrawable
|
||||
$this->assertFalse($this->service->canWithdraw($this->lotWithUnknownInstock));
|
||||
}
|
||||
|
||||
public function testCanAdd()
|
||||
{
|
||||
//Normal lots should be addable
|
||||
$this->assertTrue($this->service->canAdd($this->partLot1));
|
||||
$this->assertTrue($this->service->canAdd($this->partLot2));
|
||||
$this->assertTrue($this->service->canAdd($this->partLot3));
|
||||
|
||||
//Full lots should not be addable
|
||||
$this->assertFalse($this->service->canAdd($this->fullLot));
|
||||
//Lots with unknown instock should not be addable
|
||||
$this->assertFalse($this->service->canAdd($this->lotWithUnknownInstock));
|
||||
}
|
||||
|
||||
public function testAdd()
|
||||
{
|
||||
//Add 5 to lot 1
|
||||
$this->service->add($this->partLot1, 5, "Test");
|
||||
$this->assertEquals(15, $this->partLot1->getAmount());
|
||||
|
||||
//Add 3.2 to lot 2
|
||||
$this->service->add($this->partLot2, 3.2, "Test");
|
||||
$this->assertEquals(5, $this->partLot2->getAmount());
|
||||
|
||||
//Add 1.5 to lot 3
|
||||
$this->service->add($this->partLot3, 1.5, "Test");
|
||||
$this->assertEquals(2, $this->partLot3->getAmount());
|
||||
|
||||
}
|
||||
|
||||
public function testWithdraw()
|
||||
{
|
||||
//Withdraw 5 from lot 1
|
||||
$this->service->withdraw($this->partLot1, 5, "Test");
|
||||
$this->assertEquals(5, $this->partLot1->getAmount());
|
||||
|
||||
//Withdraw 2.2 from lot 2
|
||||
$this->service->withdraw($this->partLot2, 2.2, "Test");
|
||||
$this->assertEquals(0, $this->partLot2->getAmount());
|
||||
}
|
||||
|
||||
public function testMove()
|
||||
{
|
||||
//Move 5 from lot 1 to lot 2
|
||||
$this->service->move($this->partLot1, $this->partLot2, 5, "Test");
|
||||
$this->assertEquals(5, $this->partLot1->getAmount());
|
||||
$this->assertEquals(7, $this->partLot2->getAmount());
|
||||
|
||||
//Move 2.2 from lot 2 to lot 3
|
||||
$this->service->move($this->partLot2, $this->partLot3, 2.2, "Test");
|
||||
$this->assertEquals(5, $this->partLot2->getAmount());
|
||||
$this->assertEquals(2, $this->partLot3->getAmount());
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue