mirror of
https://github.com/Karaka-Management/oms-Navigation.git
synced 2026-02-15 16:28:39 +00:00
add tests
This commit is contained in:
parent
dce564c30b
commit
8f143193b3
|
|
@ -48,19 +48,17 @@ final class Installer extends InstallerAbstract
|
||||||
try {
|
try {
|
||||||
$dbPool->get()->con->query('select 1 from `nav`');
|
$dbPool->get()->con->query('select 1 from `nav`');
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
return;
|
return; // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
|
|
||||||
$navFile = \file_get_contents($data['path'] ?? '');
|
$navFile = \file_get_contents($data['path'] ?? '');
|
||||||
|
|
||||||
if ($navFile === false) {
|
if ($navFile === false) {
|
||||||
throw new PathException($data['path'] ?? '');
|
throw new PathException($data['path'] ?? ''); // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
|
|
||||||
$navData = \json_decode($navFile, true);
|
$navData = \json_decode($navFile, true);
|
||||||
|
|
||||||
if ($navData === false) {
|
if ($navData === false) {
|
||||||
throw new \Exception();
|
throw new \Exception(); // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($navData as $link) {
|
foreach ($navData as $link) {
|
||||||
|
|
|
||||||
|
|
@ -21,6 +21,7 @@ use phpOMS\Message\ResponseAbstract;
|
||||||
use phpOMS\Model\Message\Redirect;
|
use phpOMS\Model\Message\Redirect;
|
||||||
use phpOMS\System\MimeType;
|
use phpOMS\System\MimeType;
|
||||||
use phpOMS\Uri\UriFactory;
|
use phpOMS\Uri\UriFactory;
|
||||||
|
use phpOMS\Message\Http\RequestStatusCode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search class.
|
* Search class.
|
||||||
|
|
@ -51,7 +52,14 @@ final class SearchController extends Controller
|
||||||
|
|
||||||
/** @var \Modules\Navigation\Models\NavElement[] $elements */
|
/** @var \Modules\Navigation\Models\NavElement[] $elements */
|
||||||
$elements = NavElementMapper::getAll();
|
$elements = NavElementMapper::getAll();
|
||||||
$search = \strtolower(\explode(' ', $request->getData('search'))[1]);
|
$search = \mb_strtolower(\substr(
|
||||||
|
$request->getData('search'),
|
||||||
|
\stripos(
|
||||||
|
$request->getData('search'),
|
||||||
|
' ',
|
||||||
|
\stripos($request->getData('search'), ':')
|
||||||
|
) + 1
|
||||||
|
));
|
||||||
|
|
||||||
$found = null;
|
$found = null;
|
||||||
foreach ($elements as $element) {
|
foreach ($elements as $element) {
|
||||||
|
|
@ -59,7 +67,7 @@ final class SearchController extends Controller
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$name = \strtolower($this->app->l11nManager->getText(
|
$name = \mb_strtolower($this->app->l11nManager->getText(
|
||||||
$response->getHeader()->getL11n()->getLanguage() ?? 'en',
|
$response->getHeader()->getL11n()->getLanguage() ?? 'en',
|
||||||
'Navigation', '0',
|
'Navigation', '0',
|
||||||
$element->name,
|
$element->name,
|
||||||
|
|
@ -75,6 +83,8 @@ final class SearchController extends Controller
|
||||||
|
|
||||||
if ($found === null) {
|
if ($found === null) {
|
||||||
$this->fillJsonResponse($request, $response, NotificationLevel::WARNING, 'Command', 'Unknown command "' . $search . '"', $search);
|
$this->fillJsonResponse($request, $response, NotificationLevel::WARNING, 'Command', 'Unknown command "' . $search . '"', $search);
|
||||||
|
$response->getHeader()->setStatusCode(RequestStatusCode::R_400);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -95,7 +105,6 @@ final class SearchController extends Controller
|
||||||
* This should either get cached per user or maybe put into one large language file per language (like the routes).
|
* This should either get cached per user or maybe put into one large language file per language (like the routes).
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
* @codeCoverageIgnore
|
|
||||||
*/
|
*/
|
||||||
private function loadLanguage(RequestAbstract $request, ResponseAbstract $response, string $app) : void
|
private function loadLanguage(RequestAbstract $request, ResponseAbstract $response, string $app) : void
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -135,15 +135,17 @@ class Navigation
|
||||||
*/
|
*/
|
||||||
private function setReadable(array &$nav, int $parent) : void
|
private function setReadable(array &$nav, int $parent) : void
|
||||||
{
|
{
|
||||||
if (isset($nav[$parent])) {
|
if (!isset($nav[$parent])) {
|
||||||
$nav[$parent][0]['readable'] = true;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (isset($nav[$nav[$parent][0]['nav_parent']])
|
$nav[$parent][0]['readable'] = true;
|
||||||
&& (!isset($nav[$nav[$parent][0]['nav_parent']][0]['readable'])
|
|
||||||
|| !$nav[$nav[$parent][0]['nav_parent']][0]['readable'])
|
if (isset($nav[$nav[$parent][0]['nav_parent']])
|
||||||
) {
|
&& (!isset($nav[$nav[$parent][0]['nav_parent']][0]['readable'])
|
||||||
$this->setReadable($nav, $nav[$parent][0]['nav_parent']);
|
|| !$nav[$nav[$parent][0]['nav_parent']][0]['readable'])
|
||||||
}
|
) {
|
||||||
|
$this->setReadable($nav, $nav[$parent][0]['nav_parent']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -34,6 +34,8 @@ class AdminTest extends \PHPUnit\Framework\TestCase
|
||||||
/**
|
/**
|
||||||
* Test if navigation model works correct
|
* Test if navigation model works correct
|
||||||
*
|
*
|
||||||
|
* @covers Modules\Navigation\Models\Navigation
|
||||||
|
*
|
||||||
* @group final
|
* @group final
|
||||||
* @group module
|
* @group module
|
||||||
*/
|
*/
|
||||||
|
|
|
||||||
126
tests/Controller/SearchControllerTest.php
Normal file
126
tests/Controller/SearchControllerTest.php
Normal file
|
|
@ -0,0 +1,126 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Orange Management
|
||||||
|
*
|
||||||
|
* PHP Version 7.4
|
||||||
|
*
|
||||||
|
* @package tests
|
||||||
|
* @copyright Dennis Eichhorn
|
||||||
|
* @license OMS License 1.0
|
||||||
|
* @version 1.0.0
|
||||||
|
* @link https://orange-management.org
|
||||||
|
*/
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Modules\Navigation\tests\Controller;
|
||||||
|
|
||||||
|
use Model\CoreSettings;
|
||||||
|
use Modules\Admin\Models\AccountPermission;
|
||||||
|
use phpOMS\Account\Account;
|
||||||
|
use phpOMS\Account\AccountManager;
|
||||||
|
use phpOMS\Account\PermissionType;
|
||||||
|
use phpOMS\Application\ApplicationAbstract;
|
||||||
|
use phpOMS\Dispatcher\Dispatcher;
|
||||||
|
use phpOMS\Event\EventManager;
|
||||||
|
use phpOMS\Module\ModuleAbstract;
|
||||||
|
use phpOMS\Module\ModuleManager;
|
||||||
|
use phpOMS\Router\WebRouter;
|
||||||
|
use phpOMS\Utils\TestUtils;
|
||||||
|
use phpOMS\Message\Http\HttpResponse;
|
||||||
|
use phpOMS\Message\Http\HttpRequest;
|
||||||
|
use phpOMS\Model\Message\Redirect;
|
||||||
|
use phpOMS\Uri\HttpUri;
|
||||||
|
use phpOMS\Localization\L11nManager;
|
||||||
|
use phpOMS\Message\Http\RequestStatusCode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @testdox Modules\Navigation\tests\Controller\SearchControllerTest: Admin api controller
|
||||||
|
*
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
class SearchControllerTest extends \PHPUnit\Framework\TestCase
|
||||||
|
{
|
||||||
|
protected ApplicationAbstract $app;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \Modules\Navigation\Controller\SearchController
|
||||||
|
*/
|
||||||
|
protected ModuleAbstract $module;
|
||||||
|
|
||||||
|
protected function setUp() : void
|
||||||
|
{
|
||||||
|
$this->app = new class() extends ApplicationAbstract
|
||||||
|
{
|
||||||
|
protected string $appName = 'Search';
|
||||||
|
};
|
||||||
|
|
||||||
|
$this->app->dbPool = $GLOBALS['dbpool'];
|
||||||
|
$this->app->orgId = 1;
|
||||||
|
$this->app->accountManager = new AccountManager($GLOBALS['session']);
|
||||||
|
$this->app->appSettings = new CoreSettings($this->app->dbPool->get());
|
||||||
|
$this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules');
|
||||||
|
$this->app->dispatcher = new Dispatcher($this->app);
|
||||||
|
$this->app->l11nManager = new L11nManager($this->app->appName);
|
||||||
|
$this->app->eventManager = new EventManager($this->app->dispatcher);
|
||||||
|
$this->app->eventManager->importFromFile(__DIR__ . '/../../../../Web/Api/Hooks.php');
|
||||||
|
|
||||||
|
$account = new Account();
|
||||||
|
TestUtils::setMember($account, 'id', 1);
|
||||||
|
|
||||||
|
$permission = new AccountPermission();
|
||||||
|
$permission->setUnit(1);
|
||||||
|
$permission->setApp('backend');
|
||||||
|
$permission->setPermission(
|
||||||
|
PermissionType::READ
|
||||||
|
| PermissionType::CREATE
|
||||||
|
| PermissionType::MODIFY
|
||||||
|
| PermissionType::DELETE
|
||||||
|
| PermissionType::PERMISSION
|
||||||
|
);
|
||||||
|
|
||||||
|
$account->addPermission($permission);
|
||||||
|
|
||||||
|
$this->app->accountManager->add($account);
|
||||||
|
$this->app->router = new WebRouter();
|
||||||
|
|
||||||
|
$this->module = $this->app->moduleManager->get('Navigation');
|
||||||
|
|
||||||
|
TestUtils::setMember($this->module, 'app', $this->app);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @covers Modules\Navigation\Controller\SearchController
|
||||||
|
* @group module
|
||||||
|
*/
|
||||||
|
public function testGotoSearch() : void
|
||||||
|
{
|
||||||
|
$response = new HttpResponse();
|
||||||
|
$request = new HttpRequest(new HttpUri('https://127.0.0.1/en/backend'));
|
||||||
|
$request->createRequestHashs(2);
|
||||||
|
|
||||||
|
$request->getHeader()->setAccount(1);
|
||||||
|
$request->setData('search', ':goto General');
|
||||||
|
$request->setData('app', 'Backend');
|
||||||
|
|
||||||
|
$this->module->searchGoto($request, $response);
|
||||||
|
self::assertInstanceOf(Redirect::class, $response->get('https://127.0.0.1/en/backend'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @covers Modules\Navigation\Controller\SearchController
|
||||||
|
* @group module
|
||||||
|
*/
|
||||||
|
public function testInvalidGotoSearch() : void
|
||||||
|
{
|
||||||
|
$response = new HttpResponse();
|
||||||
|
$request = new HttpRequest(new HttpUri('https://127.0.0.1/en/backend'));
|
||||||
|
$request->createRequestHashs(0);
|
||||||
|
|
||||||
|
$request->getHeader()->setAccount(1);
|
||||||
|
$request->setData('search', ':goto Invalid');
|
||||||
|
$request->setData('app', 'Backend');
|
||||||
|
|
||||||
|
$this->module->searchGoto($request, $response);
|
||||||
|
self::assertEquals(RequestStatusCode::R_400, $response->getHeader()->getStatusCode());
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue
Block a user