mirror of
https://github.com/friendica/friendica
synced 2025-04-01 09:20:15 +00:00
251 lines
6.5 KiB
PHP
251 lines
6.5 KiB
PHP
<?php
|
|
|
|
// Copyright (C) 2010-2024, the Friendica project
|
|
// SPDX-FileCopyrightText: 2010-2024 the Friendica project
|
|
//
|
|
// SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
namespace Friendica\Test\src\App;
|
|
|
|
use Detection\MobileDetect;
|
|
use Friendica\App\Arguments;
|
|
use Friendica\App\Mode;
|
|
use Friendica\Core\Config\Capability\IManageConfigValues;
|
|
use Friendica\Database\Database;
|
|
use Friendica\Test\MockedTest;
|
|
use Friendica\Test\Util\VFSTrait;
|
|
use Friendica\Util\BasePath;
|
|
use Mockery;
|
|
use Mockery\MockInterface;
|
|
|
|
class ModeTest extends MockedTest
|
|
{
|
|
use VFSTrait;
|
|
|
|
/**
|
|
* @var BasePath|MockInterface
|
|
*/
|
|
private $basePathMock;
|
|
|
|
/**
|
|
* @var Database|MockInterface
|
|
*/
|
|
private $databaseMock;
|
|
|
|
/**
|
|
* @var IManageConfigValues|MockInterface
|
|
*/
|
|
private $configMock;
|
|
|
|
protected function setUp(): void
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->setUpVfsDir();
|
|
|
|
$this->databaseMock = Mockery::mock(Database::class);
|
|
$this->configMock = Mockery::mock(IManageConfigValues::class);
|
|
}
|
|
|
|
public function testItEmpty()
|
|
{
|
|
$mode = new Mode();
|
|
self::assertTrue($mode->isInstall());
|
|
self::assertFalse($mode->isNormal());
|
|
}
|
|
|
|
public function testWithoutConfig()
|
|
{
|
|
self::assertTrue($this->root->hasChild('config/local.config.php'));
|
|
|
|
$this->delConfigFile('local.config.php');
|
|
|
|
self::assertFalse($this->root->hasChild('config/local.config.php'));
|
|
|
|
$mode = (new Mode())->determine($this->root->url(), $this->databaseMock, $this->configMock);
|
|
|
|
self::assertTrue($mode->isInstall());
|
|
self::assertFalse($mode->isNormal());
|
|
|
|
self::assertFalse($mode->has(Mode::LOCALCONFIGPRESENT));
|
|
}
|
|
|
|
public function testWithoutDatabase()
|
|
{
|
|
$this->databaseMock->shouldReceive('connected')->andReturn(false)->once();
|
|
|
|
$mode = (new Mode())->determine($this->root->url(), $this->databaseMock, $this->configMock);
|
|
|
|
self::assertFalse($mode->isNormal());
|
|
self::assertTrue($mode->isInstall());
|
|
|
|
self::assertTrue($mode->has(Mode::LOCALCONFIGPRESENT));
|
|
self::assertFalse($mode->has(Mode::DBAVAILABLE));
|
|
}
|
|
|
|
public function testWithMaintenanceMode()
|
|
{
|
|
$this->databaseMock->shouldReceive('connected')->andReturn(true)->once();
|
|
$this->configMock->shouldReceive('get')->with('system', 'maintenance')
|
|
->andReturn(true)->once();
|
|
|
|
$mode = (new Mode())->determine($this->root->url(), $this->databaseMock, $this->configMock);
|
|
|
|
self::assertFalse($mode->isNormal());
|
|
self::assertFalse($mode->isInstall());
|
|
|
|
self::assertFalse($mode->has(Mode::MAINTENANCEDISABLED));
|
|
}
|
|
|
|
public function testNormalMode()
|
|
{
|
|
$this->databaseMock->shouldReceive('connected')->andReturn(true)->once();
|
|
$this->configMock->shouldReceive('get')->with('system', 'maintenance')
|
|
->andReturn(false)->once();
|
|
|
|
$mode = (new Mode())->determine($this->root->url(), $this->databaseMock, $this->configMock);
|
|
|
|
self::assertTrue($mode->isNormal());
|
|
self::assertFalse($mode->isInstall());
|
|
|
|
self::assertTrue($mode->has(Mode::MAINTENANCEDISABLED));
|
|
}
|
|
|
|
/**
|
|
* Test explicit disabled maintenance (in case you manually disable it)
|
|
*/
|
|
public function testDisabledMaintenance()
|
|
{
|
|
$this->databaseMock->shouldReceive('connected')->andReturn(true)->once();
|
|
$this->configMock->shouldReceive('get')->with('system', 'maintenance')
|
|
->andReturn(false)->once();
|
|
|
|
$mode = (new Mode())->determine($this->root->url(), $this->databaseMock, $this->configMock);
|
|
|
|
self::assertTrue($mode->isNormal());
|
|
self::assertFalse($mode->isInstall());
|
|
|
|
self::assertTrue($mode->has(Mode::MAINTENANCEDISABLED));
|
|
}
|
|
|
|
/**
|
|
* Test that modes are immutable
|
|
*/
|
|
public function testImmutable()
|
|
{
|
|
$mode = new Mode();
|
|
|
|
$modeNew = $mode->determine('', $this->databaseMock, $this->configMock);
|
|
|
|
self::assertNotSame($modeNew, $mode);
|
|
}
|
|
|
|
/**
|
|
* Test if not called by index is backend
|
|
*/
|
|
public function testIsBackendNotIsBackend()
|
|
{
|
|
$server = [];
|
|
$args = new Arguments();
|
|
$mobileDetect = new MobileDetect();
|
|
|
|
$mode = (new Mode())->determineRunMode(true, $server, $args, $mobileDetect);
|
|
|
|
self::assertTrue($mode->isBackend());
|
|
}
|
|
|
|
/**
|
|
* Test is called by index but module is backend
|
|
*/
|
|
public function testIsBackendButIndex()
|
|
{
|
|
$server = [];
|
|
$args = new Arguments('', '', Mode::BACKEND_MODULES[0]);
|
|
$mobileDetect = new MobileDetect();
|
|
|
|
$mode = (new Mode())->determineRunMode(false, $server, $args, $mobileDetect);
|
|
|
|
self::assertTrue($mode->isBackend());
|
|
}
|
|
|
|
/**
|
|
* Test is called by index and module is not backend
|
|
*/
|
|
public function testIsNotBackend()
|
|
{
|
|
$server = [];
|
|
$args = new Arguments('', '', Arguments::DEFAULT_MODULE);
|
|
$mobileDetect = new MobileDetect();
|
|
|
|
$mode = (new Mode())->determineRunMode(false, $server, $args, $mobileDetect);
|
|
|
|
self::assertFalse($mode->isBackend());
|
|
}
|
|
|
|
/**
|
|
* Test if the call is an ajax call
|
|
*/
|
|
public function testIsAjax()
|
|
{
|
|
// This is the server environment variable to determine ajax calls
|
|
$server = [
|
|
'HTTP_X_REQUESTED_WITH' => 'xmlhttprequest',
|
|
];
|
|
|
|
$args = new Arguments('', '', Arguments::DEFAULT_MODULE);
|
|
$mobileDetect = new MobileDetect();
|
|
|
|
$mode = (new Mode())->determineRunMode(true, $server, $args, $mobileDetect);
|
|
|
|
self::assertTrue($mode->isAjax());
|
|
}
|
|
|
|
/**
|
|
* Test if the call is not nan ajax call
|
|
*/
|
|
public function testIsNotAjax()
|
|
{
|
|
$server = [];
|
|
$args = new Arguments('', '', Arguments::DEFAULT_MODULE);
|
|
$mobileDetect = new MobileDetect();
|
|
|
|
$mode = (new Mode())->determineRunMode(true, $server, $args, $mobileDetect);
|
|
|
|
self::assertFalse($mode->isAjax());
|
|
}
|
|
|
|
/**
|
|
* Test if the call is a mobile and is a tablet call
|
|
*/
|
|
public function testIsMobileIsTablet()
|
|
{
|
|
$server = [];
|
|
$args = new Arguments('', '', Arguments::DEFAULT_MODULE);
|
|
$mobileDetect = Mockery::mock(MobileDetect::class);
|
|
$mobileDetect->shouldReceive('isMobile')->andReturn(true);
|
|
$mobileDetect->shouldReceive('isTablet')->andReturn(true);
|
|
|
|
$mode = (new Mode())->determineRunMode(true, $server, $args, $mobileDetect);
|
|
|
|
self::assertTrue($mode->isMobile());
|
|
self::assertTrue($mode->isTablet());
|
|
}
|
|
|
|
|
|
/**
|
|
* Test if the call is not a mobile and is not a tablet call
|
|
*/
|
|
public function testIsNotMobileIsNotTablet()
|
|
{
|
|
$server = [];
|
|
$args = new Arguments('', '', Arguments::DEFAULT_MODULE);
|
|
$mobileDetect = Mockery::mock(MobileDetect::class);
|
|
$mobileDetect->shouldReceive('isMobile')->andReturn(false);
|
|
$mobileDetect->shouldReceive('isTablet')->andReturn(false);
|
|
|
|
$mode = (new Mode())->determineRunMode(true, $server, $args, $mobileDetect);
|
|
|
|
self::assertFalse($mode->isMobile());
|
|
self::assertFalse($mode->isTablet());
|
|
}
|
|
}
|