Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 12
0.00% covered (danger)
0.00%
0 / 2
CRAP
0.00% covered (danger)
0.00%
0 / 1
GenerateSchemaChangeSql
0.00% covered (danger)
0.00%
0 / 9
0.00% covered (danger)
0.00%
0 / 2
12
0.00% covered (danger)
0.00%
0 / 1
 __construct
0.00% covered (danger)
0.00%
0 / 3
0.00% covered (danger)
0.00%
0 / 1
2
 generateSchema
0.00% covered (danger)
0.00%
0 / 6
0.00% covered (danger)
0.00%
0 / 1
6
1<?php
2
3/**
4 * Convert a JSON abstract schema change to a schema change file in the given DBMS type
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 * http://www.gnu.org/copyleft/gpl.html
20 *
21 * @file
22 * @ingroup Maintenance
23 */
24
25use Wikimedia\Rdbms\DoctrineSchemaBuilderFactory;
26
27require_once __DIR__ . '/includes/SchemaMaintenance.php';
28
29/**
30 * Maintenance script to generate schema from abstract json files.
31 *
32 * @ingroup Maintenance
33 */
34class GenerateSchemaChangeSql extends SchemaMaintenance {
35    public function __construct() {
36        parent::__construct();
37        $this->addDescription( 'Build SQL files for schema changes from abstract JSON files' );
38        $this->scriptName = 'generateSchemaChangeSql.php';
39    }
40
41    protected function generateSchema( string $platform, array $schema ): string {
42        $schemaChangeBuilder = ( new DoctrineSchemaBuilderFactory() )->getSchemaChangeBuilder( $platform );
43
44        $schemaChangeSqls = $schemaChangeBuilder->getSchemaChangeSql( $schema );
45        if ( !$schemaChangeSqls ) {
46            $this->fatalError( 'No schema changes detected!' );
47        }
48
49        $sql = $this->cleanupSqlArray( $platform, $schemaChangeSqls );
50
51        return $sql;
52    }
53
54}
55
56$maintClass = GenerateSchemaChangeSql::class;
57require_once RUN_MAINTENANCE_IF_MAIN;