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
|
|||||
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
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
![]() |
|||||
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 |
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:For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths