Completed
Pull Request — 1.5 (#772)
by Paweł
11:25
created

Version20190403081555   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 33
Duplicated Lines 100 %

Coupling/Cohesion

Components 1
Dependencies 3

Importance

Changes 0
Metric Value
wmc 2
lcom 1
cbo 3
dl 33
loc 33
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A up() 20 20 1
A down() 9 9 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
3
declare(strict_types=1);
4
5
namespace SWP\Migrations;
6
7
use Doctrine\DBAL\Schema\Schema;
8
use Doctrine\Migrations\AbstractMigration;
9
10
/**
11
 * Auto-generated Migration: Please modify to your needs!
12
 */
13 View Code Duplication
final class Version20190403081555 extends AbstractMigration
14
{
15
    public function up(Schema $schema): void
16
    {
17
        // this up() migration is auto-generated, please modify it to your needs
18
        $this->abortIf('postgresql' !== $this->connection->getDatabasePlatform()->getName(), 'Migration can only be executed safely on \'postgresql\'.');
19
20
        $this->addSql('
21
            UPDATE 
22
                swp_article 
23
            SET 
24
                feature_media = NULL
25
            WHERE 
26
                  feature_media IN (
27
                    SELECT id FROM swp_article_media WHERE deleted_at IS NOT NULL 
28
                  )
29
        ');
30
        $this->addSql('DELETE FROM swp_article_media WHERE deleted_at IS NOT NULL');
31
        $this->addSql('ALTER TABLE swp_article_media DROP deleted_at');
32
        $this->addSql('ALTER TABLE swp_article_media ALTER updated_at TYPE TIMESTAMP(0) WITHOUT TIME ZONE');
33
        $this->addSql('ALTER TABLE swp_article_media ALTER updated_at DROP DEFAULT');
34
    }
35
36
    public function down(Schema $schema): void
37
    {
38
        // this down() migration is auto-generated, please modify it to your needs
39
        $this->abortIf('postgresql' !== $this->connection->getDatabasePlatform()->getName(), 'Migration can only be executed safely on \'postgresql\'.');
40
41
        $this->addSql('ALTER TABLE swp_article_media ADD deleted_at TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT NULL');
42
        $this->addSql('ALTER TABLE swp_article_media ALTER updated_at TYPE DATE');
43
        $this->addSql('ALTER TABLE swp_article_media ALTER updated_at DROP DEFAULT');
44
    }
45
}
46