Completed
Push — devel ( adbcf9...17c44c )
by Alex
03:43 queued 01:44
created

OutgoingMessageMutationFeature   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 40
Duplicated Lines 100 %

Coupling/Cohesion

Components 0
Dependencies 5

Test Coverage

Coverage 86.67%

Importance

Changes 0
Metric Value
wmc 2
lcom 0
cbo 5
dl 40
loc 40
ccs 13
cts 15
cp 0.8667
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A describe() 4 4 1
A setup() 18 18 1

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
namespace PSB\Core\MessageMutation;
3
4
5
use PSB\Core\Feature\Feature;
6
use PSB\Core\MessageMutation\Pipeline\Outgoing\OutgoingLogicalMessageMutationPipelineStep;
7
use PSB\Core\MessageMutation\Pipeline\Outgoing\OutgoingPhysicalMessageMutationPipelineStep;
8
use PSB\Core\MessageMutatorRegistry;
9
use PSB\Core\ObjectBuilder\BuilderInterface;
10
use PSB\Core\Pipeline\PipelineModifications;
11
use PSB\Core\Util\Settings;
12
13 View Code Duplication
class OutgoingMessageMutationFeature extends Feature
14
{
15
16
    /**
17
     * Method will always be executed and should be used to determine whether to enable or disable the feature,
18
     * configure default settings, configure dependencies, configure prerequisites and register startup tasks.
19
     */
20 1
    public function describe()
21
    {
22 1
        $this->enableByDefault();
23 1
    }
24
25
    /**
26
     * Method is called if all defined conditions are met and the feature is marked as enabled.
27
     * Use this method to configure and initialize all required components for the feature like
28
     * the steps in the pipeline or the instances/factories in the container.
29
     *
30
     * @param Settings              $settings
31
     * @param BuilderInterface      $builder
32
     * @param PipelineModifications $pipelineModifications
33
     */
34 1
    public function setup(Settings $settings, BuilderInterface $builder, PipelineModifications $pipelineModifications)
35
    {
36 1
        $pipelineModifications->registerStep(
37 1
            'OutgoingLogicalMessageMutation',
38 1
            OutgoingLogicalMessageMutationPipelineStep::class,
39
            function () use ($builder) {
40
                return new OutgoingLogicalMessageMutationPipelineStep($builder->build(MessageMutatorRegistry::class));
41 1
            }
42
        );
43
44 1
        $pipelineModifications->registerStep(
45 1
            'OutgoingPhysicalMessageMutation',
46 1
            OutgoingPhysicalMessageMutationPipelineStep::class,
47
            function () use ($builder) {
48
                return new OutgoingPhysicalMessageMutationPipelineStep($builder->build(MessageMutatorRegistry::class));
49 1
            }
50
        );
51 1
    }
52
}
53