OrderFixturePool   A
last analyzed

Complexity

Total Complexity 7

Size/Duplication

Total Lines 38
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 12
c 1
b 0
f 0
dl 0
loc 38
ccs 14
cts 14
cp 1
rs 10
wmc 7

3 Methods

Rating   Name   Duplication   Size   Complexity  
A add() 0 6 2
A rollback() 0 4 1
A get() 0 9 4
1
<?php
2
declare(strict_types=1);
3
4
namespace TddWizard\Fixtures\Sales;
5
6
use Magento\Sales\Model\Order;
7
use function array_values as values;
8
9
class OrderFixturePool
10
{
11
12
    /**
13
     * @var OrderFixture[]
14
     */
15
    private $orderFixtures = [];
16
17 6
    public function add(Order $order, string $key = null): void
18
    {
19 6
        if ($key === null) {
20 3
            $this->orderFixtures[] = new OrderFixture($order);
21
        } else {
22 3
            $this->orderFixtures[$key] = new OrderFixture($order);
23
        }
24 6
    }
25
26
    /**
27
     * Returns order fixture by key, or last added if key not specified
28
     *
29
     * @param string|null $key
30
     * @return OrderFixture
31
     */
32 6
    public function get(string $key = null): OrderFixture
33
    {
34 6
        if ($key === null) {
35 4
            $key = \array_key_last($this->orderFixtures);
36
        }
37 6
        if ($key === null || !array_key_exists($key, $this->orderFixtures)) {
38 4
            throw new \OutOfBoundsException('No matching order found in fixture pool');
39
        }
40 2
        return $this->orderFixtures[$key];
41
    }
42
43 3
    public function rollback(): void
44
    {
45 3
        OrderFixtureRollback::create()->execute(...values($this->orderFixtures));
46 3
        $this->orderFixtures = [];
47 3
    }
48
}
49