Failed Conditions
Pull Request — experimental/sf (#3240)
by Kentaro
43:45
created

PaymentMethodPass   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 19
Duplicated Lines 47.37 %

Coupling/Cohesion

Components 0
Dependencies 3

Test Coverage

Coverage 77.78%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
dl 9
loc 19
ccs 7
cts 9
cp 0.7778
rs 10
c 1
b 0
f 0
wmc 3
lcom 0
cbo 3

1 Method

Rating   Name   Duplication   Size   Complexity  
A process() 9 14 3

How to fix   Duplicated Code   

Duplicated Code

Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.

Common duplication problems, and corresponding solutions are:

1
<?php
2
3
/*
4
 * This file is part of EC-CUBE
5
 *
6
 * Copyright(c) LOCKON CO.,LTD. All Rights Reserved.
7
 *
8
 * http://www.lockon.co.jp/
9
 *
10
 * For the full copyright and license information, please view the LICENSE
11
 * file that was distributed with this source code.
12
 */
13
14
namespace Eccube\DependencyInjection\Compiler;
15
16
use Eccube\Service\Payment\PaymentMethodInterface;
17
use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
18
use Symfony\Component\DependencyInjection\ContainerBuilder;
19
20
class PaymentMethodPass implements CompilerPassInterface
0 ignored issues
show
introduced by
Missing class doc comment
Loading history...
21
{
22
    const PAYMENT_METHOD_TAG = 'eccube.payment.method';
23
24 1
    public function process(ContainerBuilder $container)
25
    {
26 1
        $ids = $container->findTaggedServiceIds(self::PAYMENT_METHOD_TAG);
27
28 1 View Code Duplication
        foreach ($ids as $id => $tags) {
29 1
            $def = $container->getDefinition($id);
30 1
            $class = $container->getParameterBag()->resolveValue($def->getClass());
31 1
            if (!is_subclass_of($class, PaymentMethodInterface::class)) {
0 ignored issues
show
Bug introduced by
Due to PHP Bug #53727, is_subclass_of might return inconsistent results on some PHP versions if \Eccube\Service\Payment\...tMethodInterface::class can be an interface. If so, you could instead use ReflectionClass::implementsInterface.
Loading history...
32
                throw new \InvalidArgumentException(
33
                    sprintf('Service "%s" must implement interface "%s".', $id, PaymentMethodInterface::class));
34
            }
35 1
            $def->setPublic(true);
36
        }
37
    }
38
}
39