Part-DB.Part-DB-server/tests/Services/AmountFormatterTest.php

100 lines
3.6 KiB
PHP
Raw Normal View History

<?php
2020-01-05 15:55:16 +01:00
declare(strict_types=1);
/**
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony).
*
2019-11-01 13:40:30 +01:00
* 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\Services;
use App\Entity\Parts\MeasurementUnit;
use App\Services\AmountFormatter;
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
class AmountFormatterTest extends WebTestCase
{
/**
* @var AmountFormatter
*/
protected $service;
2020-01-05 15:55:16 +01:00
protected function setUp(): void
{
parent::setUp(); // TODO: Change the autogenerated stub
//Get an service instance.
self::bootKernel();
$this->service = self::$container->get(AmountFormatter::class);
}
2020-01-05 15:55:16 +01:00
public function testFormatWithoutUnit(): void
{
2020-01-05 15:55:16 +01:00
$this->assertSame('2', $this->service->format(2.321));
$this->assertSame('1002', $this->service->format(1002.356));
$this->assertSame('1000454', $this->service->format(1000454.0));
$this->assertSame('0', $this->service->format(0.01));
$this->assertSame('0', $this->service->format(0));
}
2020-01-05 15:55:16 +01:00
public function testInvalidInput(): void
{
$this->expectException(\InvalidArgumentException::class);
$this->service->format('test');
}
2020-01-05 15:55:16 +01:00
public function testFormatUnitWithoutSI(): void
{
$meters = new MeasurementUnit();
$meters->setIsInteger(false)->setUseSIPrefix(false)->setUnit('m');
2020-01-05 15:55:16 +01:00
$this->assertSame('0.32 m', $this->service->format(0.3245, $meters));
$this->assertSame('10003.56 m', $this->service->format(10003.556, $meters));
$this->assertSame('0.00 m', $this->service->format(0.0004, $meters));
}
2020-01-05 15:55:16 +01:00
public function testFormatUnitWithSI(): void
{
$meters = new MeasurementUnit();
$meters->setIsInteger(false)->setUseSIPrefix(true)->setUnit('m');
2020-01-05 15:55:16 +01:00
$this->assertSame('0.32 m', $this->service->format(0.3245, $meters));
$this->assertSame('12.32 m', $this->service->format(12.323, $meters));
$this->assertSame('120.32 km', $this->service->format(120320.45, $meters));
2020-01-05 15:55:16 +01:00
$this->assertSame('0.32 mm', $this->service->format(0.00032, $meters));
}
2020-01-05 15:55:16 +01:00
public function testFormatMoreDigits(): void
{
2020-01-05 15:55:16 +01:00
$this->assertSame('12.12345', $this->service->format(12.1234532, null, ['is_integer' => false, 'decimals' => 5]));
$this->assertSame('12.1', $this->service->format(12.1234532, null, ['is_integer' => false, 'decimals' => 1]));
}
2020-01-05 15:55:16 +01:00
public function testFormatOptionsOverride(): void
{
$meters = new MeasurementUnit();
$meters->setIsInteger(false)->setUseSIPrefix(true)->setUnit('m');
2020-01-05 15:55:16 +01:00
$this->assertSame('12.32', $this->service->format(12.323, $meters, ['unit' => '']));
$this->assertSame('12002.32 m', $this->service->format(12002.32, $meters, ['show_prefix' => false]));
$this->assertSame('123 m', $this->service->format(123.234, $meters, ['is_integer' => true]));
}
}