]> git.mxchange.org Git - friendica.git/blob - tests/src/Database/DBStructureTest.php
Merge pull request #12697 from MrPetovan/bug/deprecated
[friendica.git] / tests / src / Database / DBStructureTest.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2010-2023, the Friendica project
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(): void
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                 self::assertTrue(DBStructure::existsTable('user'));
48                 self::assertFalse(DBStructure::existsTable('notatable'));
49
50                 self::assertTrue(DBStructure::existsColumn('user', ['uid']));
51                 self::assertFalse(DBStructure::existsColumn('user', ['nonsense']));
52                 self::assertFalse(DBStructure::existsColumn('user', ['uid', 'nonsense']));
53         }
54
55         /**
56          * @small
57          */
58         public function testRename() {
59                 $fromColumn = 'email';
60                 $toColumn = 'email_key';
61                 $fromType = 'varchar(255) NOT NULL DEFAULT \'\' COMMENT \'the users email address\'';
62                 $toType = 'varchar(255) NOT NULL DEFAULT \'\' COMMENT \'Adapted column\'';
63
64                 self::assertTrue(DBStructure::rename('user', [ $fromColumn => [ $toColumn, $toType ]]));
65                 self::assertTrue(DBStructure::existsColumn('user', [ $toColumn ]));
66                 self::assertFalse(DBStructure::existsColumn('user', [ $fromColumn ]));
67
68                 self::assertTrue(DBStructure::rename('user', [ $toColumn => [ $fromColumn, $fromType ]]));
69                 self::assertTrue(DBStructure::existsColumn('user', [ $fromColumn ]));
70                 self::assertFalse(DBStructure::existsColumn('user', [ $toColumn ]));
71         }
72
73         /**
74          * @small
75          */
76         public function testChangePrimaryKey() {
77                 static::markTestSkipped('rename primary key with autoincrement and foreign key support necessary first');
78                 $oldID = 'client_id';
79                 $newID = 'pw';
80
81                 self::assertTrue(DBStructure::rename('clients', [ $newID ], DBStructure::RENAME_PRIMARY_KEY));
82                 self::assertTrue(DBStructure::rename('clients', [ $oldID ], DBStructure::RENAME_PRIMARY_KEY));
83         }
84 }