]> git.mxchange.org Git - friendica.git/blob - tests/FixtureTest.php
Code standards
[friendica.git] / tests / FixtureTest.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2010-2022, 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  * FixtureTest class.
21  */
22
23 namespace Friendica\Test;
24
25 use Dice\Dice;
26 use Friendica\App\Arguments;
27 use Friendica\App\Router;
28 use Friendica\Core\Config\ValueObject\Cache;
29 use Friendica\Core\Config\Capability\IManageConfigValues;
30 use Friendica\Core\Session;
31 use Friendica\Core\Session\Capability\IHandleSessions;
32 use Friendica\Database\Database;
33 use Friendica\Database\DBStructure;
34 use Friendica\DI;
35 use Friendica\Test\Util\Database\StaticDatabase;
36
37 /**
38  * Parent class for test cases requiring fixtures
39  */
40 abstract class FixtureTest extends DatabaseTest
41 {
42         /** @var Dice */
43         protected $dice;
44
45         /**
46          * Create variables used by tests.
47          */
48         protected function setUp(): void
49         {
50                 parent::setUp();
51
52                 $server                   = $_SERVER;
53                 $server['REQUEST_METHOD'] = Router::GET;
54
55                 $this->dice = (new Dice())
56                         ->addRules(include __DIR__ . '/../static/dependencies.config.php')
57                         ->addRule(Database::class, ['instanceOf' => StaticDatabase::class, 'shared' => true])
58                         ->addRule(IHandleSessions::class, ['instanceOf' => Session\Type\Memory::class, 'shared' => true, 'call' => null])
59                         ->addRule(Arguments::class, [
60                                 'instanceOf' => Arguments::class,
61                                 'call'       => [
62                                         ['determine', [$server, $_GET], Dice::CHAIN_CALL],
63                                 ],
64                         ]);
65                 DI::init($this->dice);
66
67                 /** @var IManageConfigValues $config */
68                 $configCache = $this->dice->create(Cache::class);
69                 $configCache->set('database', 'disable_pdo', true);
70
71                 /** @var Database $dba */
72                 $dba = $this->dice->create(Database::class);
73
74                 $dba->setTestmode(true);
75
76                 DBStructure::checkInitialValues();
77
78                 // Load the API dataset for the whole API
79                 $this->loadFixture(__DIR__ . '/datasets/api.fixture.php', $dba);
80         }
81
82         protected function useHttpMethod(string $method = Router::GET)
83         {
84                 $server                   = $_SERVER;
85                 $server['REQUEST_METHOD'] = $method;
86
87                 $this->dice = $this->dice
88                         ->addRule(Arguments::class, [
89                                 'instanceOf' => Arguments::class,
90                                 'call'       => [
91                                         ['determine', [$server, $_GET], Dice::CHAIN_CALL],
92                                 ],
93                         ]);
94
95                 DI::init($this->dice);
96         }
97 }