PricedetailTest::testGetPricePerUnit()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 14
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 9
nc 1
nop 0
dl 0
loc 14
rs 9.9666
c 0
b 0
f 0
1
<?php
2
/**
3
 * This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony).
4
 *
5
 * Copyright (C) 2019 - 2020 Jan Böhmer (https://github.com/jbtronics)
6
 *
7
 * This program is free software: you can redistribute it and/or modify
8
 * it under the terms of the GNU Affero General Public License as published
9
 * by the Free Software Foundation, either version 3 of the License, or
10
 * (at your option) any later version.
11
 *
12
 * This program is distributed in the hope that it will be useful,
13
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
 * GNU Affero General Public License for more details.
16
 *
17
 * You should have received a copy of the GNU Affero General Public License
18
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
19
 */
20
21
declare(strict_types=1);
22
23
namespace App\Tests\Entity\PriceSystem;
24
25
use App\Entity\Parts\Part;
26
use App\Entity\PriceInformations\Orderdetail;
27
use App\Entity\PriceInformations\Pricedetail;
28
use Brick\Math\BigDecimal;
29
use PHPUnit\Framework\TestCase;
0 ignored issues
show
Bug introduced by
The type PHPUnit\Framework\TestCase was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
30
31
class PricedetailTest extends TestCase
32
{
33
    public function testGetPricePerUnit(): void
34
    {
35
        $pricedetail = new Pricedetail();
36
        $pricedetail->setPrice(BigDecimal::of('100.234'));
0 ignored issues
show
Bug introduced by
It seems like Brick\Math\BigDecimal::of('100.234') can also be of type Brick\Math\BigInteger and Brick\Math\BigRational; however, parameter $new_price of App\Entity\PriceInformat...Pricedetail::setPrice() does only seem to accept Brick\Math\BigDecimal, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

36
        $pricedetail->setPrice(/** @scrutinizer ignore-type */ BigDecimal::of('100.234'));
Loading history...
37
38
        $this->assertSame('100.23400', (string) $pricedetail->getPricePerUnit());
39
40
        $pricedetail->setPriceRelatedQuantity(2.3);
41
        $this->assertSame('43.58000', (string) $pricedetail->getPricePerUnit());
42
        $this->assertSame('139.45600', (string) $pricedetail->getPricePerUnit('3.2'));
43
44
        $pricedetail->setPrice(BigDecimal::of('10000000.2345')); //Ten million
45
        $pricedetail->setPriceRelatedQuantity(1.234e9); //100 billion
46
        $this->assertSame('0.00810', (string) $pricedetail->getPricePerUnit());
47
    }
48
49
    public function testGetPriceRelatedQuantity(): void
50
    {
51
        $pricedetail = new Pricedetail();
52
        $part = $this->createMock(Part::class);
53
        $part->method('useFloatAmount')->willReturn(false);
54
        $orderdetail = $this->createMock(Orderdetail::class);
55
        $orderdetail->method('getPart')->willReturn($part);
56
57
        $part2 = $this->createMock(Part::class);
58
        $part2->method('useFloatAmount')->willReturn(true);
59
        $orderdetail2 = $this->createMock(Orderdetail::class);
60
        $orderdetail2->method('getPart')->willReturn($part2);
61
62
        //By default a price detail returns 1
63
        $this->assertSame(1.0, $pricedetail->getPriceRelatedQuantity());
64
65
        $pricedetail->setOrderdetail($orderdetail);
66
        $pricedetail->setPriceRelatedQuantity(10.23);
67
        $this->assertSame(10.0, $pricedetail->getPriceRelatedQuantity());
68
        //Price related quantity must not be zero!
69
        $pricedetail->setPriceRelatedQuantity(0.23);
70
        $this->assertSame(1.0, $pricedetail->getPriceRelatedQuantity());
71
72
        //With an part that has an float amount unit, also values like 0.23 can be returned
73
        $pricedetail->setOrderdetail($orderdetail2);
74
        $this->assertSame(0.23, $pricedetail->getPriceRelatedQuantity());
75
    }
76
77
    public function testGetMinDiscountQuantity(): void
78
    {
79
        $pricedetail = new Pricedetail();
80
        $part = $this->createMock(Part::class);
81
        $part->method('useFloatAmount')->willReturn(false);
82
        $orderdetail = $this->createMock(Orderdetail::class);
83
        $orderdetail->method('getPart')->willReturn($part);
84
85
        $part2 = $this->createMock(Part::class);
86
        $part2->method('useFloatAmount')->willReturn(true);
87
        $orderdetail2 = $this->createMock(Orderdetail::class);
88
        $orderdetail2->method('getPart')->willReturn($part2);
89
90
        //By default a price detail returns 1
91
        $this->assertSame(1.0, $pricedetail->getMinDiscountQuantity());
92
93
        $pricedetail->setOrderdetail($orderdetail);
94
        $pricedetail->setMinDiscountQuantity(10.23);
95
        $this->assertSame(10.0, $pricedetail->getMinDiscountQuantity());
96
        //Price related quantity must not be zero!
97
        $pricedetail->setMinDiscountQuantity(0.23);
98
        $this->assertSame(1.0, $pricedetail->getMinDiscountQuantity());
99
100
        //With an part that has an float amount unit, also values like 0.23 can be returned
101
        $pricedetail->setOrderdetail($orderdetail2);
102
        $this->assertSame(0.23, $pricedetail->getMinDiscountQuantity());
103
    }
104
}
105