6 namespace Friendica\Test;
9 use Friendica\App\Arguments;
10 use Friendica\App\Router;
11 use Friendica\Core\Config\ValueObject\Cache;
12 use Friendica\Core\Config\Capability\IManageConfigValues;
13 use Friendica\Core\Session;
14 use Friendica\Core\Session\Capability\IHandleSessions;
15 use Friendica\Database\Database;
16 use Friendica\Database\DBStructure;
18 use Friendica\Test\Util\Database\StaticDatabase;
21 * Parent class for test cases requiring fixtures
23 abstract class FixtureTest extends DatabaseTest
29 * Create variables used by tests.
31 protected function setUp(): void
36 $server['REQUEST_METHOD'] = Router::GET;
38 $this->dice = (new Dice())
39 ->addRules(include __DIR__ . '/../static/dependencies.config.php')
40 ->addRule(Database::class, ['instanceOf' => StaticDatabase::class, 'shared' => true])
41 ->addRule(IHandleSessions::class, ['instanceOf' => Session\Type\Memory::class, 'shared' => true, 'call' => null])
42 ->addRule(Arguments::class, [
43 'instanceOf' => Arguments::class,
45 ['determine', [$server, $_GET], Dice::CHAIN_CALL],
48 DI::init($this->dice);
50 /** @var IManageConfigValues $config */
51 $configCache = $this->dice->create(Cache::class);
52 $configCache->set('database', 'disable_pdo', true);
54 /** @var Database $dba */
55 $dba = $this->dice->create(Database::class);
57 $dba->setTestmode(true);
59 DBStructure::checkInitialValues();
61 // Load the API dataset for the whole API
62 $this->loadFixture(__DIR__ . '/datasets/api.fixture.php', $dba);
65 protected function useHttpMethod(string $method = Router::GET)
68 $server['REQUEST_METHOD'] = $method;
70 $this->dice = $this->dice
71 ->addRule(Arguments::class, [
72 'instanceOf' => Arguments::class,
74 ['determine', [$server, $_GET], Dice::CHAIN_CALL],
78 DI::init($this->dice);