]> git.mxchange.org Git - friendica.git/blob - tests/src/Database/DBStructureTest.php
Fix code
[friendica.git] / tests / src / Database / DBStructureTest.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2020, Friendica
4  *
5  * @license GNU AGPL version 3 or any later version
6  *
7  * This program is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU Affero General Public License as
9  * published by the Free Software Foundation, either version 3 of the
10  * License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU Affero General Public License for more details.
16  *
17  * You should have received a copy of the GNU Affero General Public License
18  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
19  *
20  */
21
22 namespace Friendica\Test\src\Database;
23
24 use Dice\Dice;
25 use Friendica\Database\Database;
26 use Friendica\Database\DBStructure;
27 use Friendica\DI;
28 use Friendica\Test\DatabaseTest;
29 use Friendica\Test\Util\Database\StaticDatabase;
30
31 class DBStructureTest extends DatabaseTest
32 {
33         protected function setUp()
34         {
35                 parent::setUp();
36
37                 $dice = (new Dice())
38                         ->addRules(include __DIR__ . '/../../../static/dependencies.config.php')
39                         ->addRule(Database::class, ['instanceOf' => StaticDatabase::class, 'shared' => true]);
40                 DI::init($dice);
41         }
42
43         /**
44          * @small
45          */
46         public function testExists() {
47                 $this->assertTrue(DBStructure::existsTable('config'));
48
49                 $this->assertFalse(DBStructure::existsTable('notatable'));
50
51                 $this->assertTrue(DBStructure::existsColumn('config', ['k']));
52                 $this->assertFalse(DBStructure::existsColumn('config', ['nonsense']));
53                 $this->assertFalse(DBStructure::existsColumn('config', ['k', 'nonsense']));
54         }
55
56         /**
57          * @small
58          */
59         public function testRename() {
60                 $fromColumn = 'k';
61                 $toColumn = 'key';
62                 $fromType = 'varbinary(255) not null';
63                 $toType = 'varbinary(255) not null comment \'Test To Type\'';
64
65                 $this->assertTrue(DBStructure::rename('config', [ $fromColumn => [ $toColumn, $toType ]]));
66                 $this->assertTrue(DBStructure::existsColumn('config', [ $toColumn ]));
67                 $this->assertFalse(DBStructure::existsColumn('config', [ $fromColumn ]));
68
69                 $this->assertTrue(DBStructure::rename('config', [ $toColumn => [ $fromColumn, $fromType ]]));
70                 $this->assertTrue(DBStructure::existsColumn('config', [ $fromColumn ]));
71                 $this->assertFalse(DBStructure::existsColumn('config', [ $toColumn ]));
72         }
73
74         /**
75          * @small
76          */
77         public function testChangePrimaryKey() {
78                 $oldID = 'id';
79                 $newID = 'pw';
80
81                 $this->assertTrue(DBStructure::rename('poll', [ $newID ], DBStructure::RENAME_PRIMARY_KEY));
82                 $this->assertTrue(DBStructure::rename('poll', [ $oldID ], DBStructure::RENAME_PRIMARY_KEY));
83         }
84 }