Optimized overhead a tiny bit
This commit is contained in:
parent
29384a4b91
commit
46e47f6f39
11 changed files with 75 additions and 36 deletions
|
@ -1 +1 @@
|
|||
Subproject commit ba4284ea7d1a43123e5be23afa62322932467125
|
||||
Subproject commit eba4f6f486f540a4301f5b20fb68e14bb9b20466
|
|
@ -6,9 +6,19 @@ class Access
|
|||
|
||||
public static function init()
|
||||
{
|
||||
self::$privileges = [];
|
||||
self::$checkPrivileges = true;
|
||||
self::$privileges = \Chibi\Cache::getCache('privileges', [get_called_class(), 'getPrivilegesFromConfig']);
|
||||
}
|
||||
|
||||
public static function initWithoutCache()
|
||||
{
|
||||
self::$checkPrivileges = true;
|
||||
self::$privileges = self::getPrivilegesFromConfig();
|
||||
}
|
||||
|
||||
public static function getPrivilegesFromConfig()
|
||||
{
|
||||
$privileges = [];
|
||||
foreach (Core::getConfig()->privileges as $key => $minAccessRankName)
|
||||
{
|
||||
if (strpos($key, '.') === false)
|
||||
|
@ -19,14 +29,15 @@ class Access
|
|||
if (!in_array($privilegeName, Privilege::getAllConstants()))
|
||||
throw new Exception('Invalid privilege name in config: ' . $privilegeName);
|
||||
|
||||
if (!isset(self::$privileges[$privilegeName]))
|
||||
if (!isset($privileges[$privilegeName]))
|
||||
{
|
||||
self::$privileges[$privilegeName] = [];
|
||||
self::$privileges[$privilegeName][null] = $minAccessRank;
|
||||
$privileges[$privilegeName] = [];
|
||||
$privileges[$privilegeName][null] = $minAccessRank;
|
||||
}
|
||||
|
||||
self::$privileges[$privilegeName][$subPrivilegeName] = $minAccessRank;
|
||||
$privileges[$privilegeName][$subPrivilegeName] = $minAccessRank;
|
||||
}
|
||||
return $privileges;
|
||||
}
|
||||
|
||||
public static function check(Privilege $privilege, $user = null)
|
||||
|
|
|
@ -3,6 +3,12 @@ class Assets extends \Chibi\Util\Assets
|
|||
{
|
||||
private $pageThumbnail = null;
|
||||
private $subTitle = null;
|
||||
private $engineVersion = null;
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$this->engineVersion = PropertyModel::get(PropertyModel::EngineVersion);
|
||||
}
|
||||
|
||||
public function setSubTitle($text)
|
||||
{
|
||||
|
@ -16,7 +22,7 @@ class Assets extends \Chibi\Util\Assets
|
|||
|
||||
public function addStylesheet($path)
|
||||
{
|
||||
return $this->addStylesheetFullPath($this->decorateUrl('/media/css/' . $path));
|
||||
return parent::addStylesheet('/media/css/' . $path . '?' . $this->engineVersion);
|
||||
}
|
||||
|
||||
public function addStylesheetFullPath($path)
|
||||
|
@ -26,7 +32,7 @@ class Assets extends \Chibi\Util\Assets
|
|||
|
||||
public function addScript($path)
|
||||
{
|
||||
return $this->addScriptFullPath($this->decorateUrl('/media/js/' . $path));
|
||||
return $this->addScriptFullPath('/media/js/' . $path . '?' . $this->engineVersion);
|
||||
}
|
||||
|
||||
public function addScriptFullPath($path)
|
||||
|
@ -57,10 +63,4 @@ class Assets extends \Chibi\Util\Assets
|
|||
$html = str_replace('</body>', $bodySnippet . '</body>', $html);
|
||||
return $html;
|
||||
}
|
||||
|
||||
|
||||
private function decorateUrl($url)
|
||||
{
|
||||
return $url . '?' . PropertyModel::get(PropertyModel::EngineVersion);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -199,9 +199,19 @@ class TextHelper
|
|||
|
||||
public static function reprTags($tags)
|
||||
{
|
||||
if (empty($tags))
|
||||
return '';
|
||||
$x = [];
|
||||
if (is_object($tags[0]))
|
||||
{
|
||||
foreach ($tags as $tag)
|
||||
$x []= self::reprTag($tag);
|
||||
$x []= '#' . $tag->getName();
|
||||
}
|
||||
else
|
||||
{
|
||||
foreach ($tags as $tag)
|
||||
$x []= '#' . $tag;
|
||||
}
|
||||
natcasesort($x);
|
||||
return join(', ', $x);
|
||||
}
|
||||
|
|
|
@ -11,9 +11,6 @@ if (!empty(Core::getConfig()->appearance->extraScripts))
|
|||
if (!empty(Core::getConfig()->appearance->extraStylesheets))
|
||||
foreach (Core::getConfig()->appearance->extraStylesheets as $path)
|
||||
$this->assets->addStylesheetFullPath($path);
|
||||
$lastSearchQuery = isset($this->context->transport->lastSearchQuery)
|
||||
? $this->context->transport->lastSearchQuery
|
||||
: '';
|
||||
?>
|
||||
|
||||
<!DOCTYPE html>
|
||||
|
@ -29,6 +26,11 @@ $lastSearchQuery = isset($this->context->transport->lastSearchQuery)
|
|||
</head>
|
||||
|
||||
<body>
|
||||
<?php
|
||||
$lastSearchQuery = isset($this->context->transport->lastSearchQuery)
|
||||
? $this->context->transport->lastSearchQuery
|
||||
: '';
|
||||
?>
|
||||
<div id="settings"
|
||||
data-last-search-query="<?= htmlspecialchars($lastSearchQuery) ?>"
|
||||
data-thumbnail-width="<?= Core::getConfig()->browsing->thumbnailWidth ?>"
|
||||
|
|
|
@ -25,7 +25,7 @@ final class Core
|
|||
require_once self::$rootDir . 'lib' . DS . 'chibi-sql' . DS . 'include.php';
|
||||
\Chibi\AutoLoader::registerFilesystem(__DIR__);
|
||||
|
||||
self::$router = new Router();
|
||||
self::$router = \Chibi\Cache::getCache('router', function() { return new Router(); });
|
||||
self::prepareConfig();
|
||||
self::checkExtensions();
|
||||
}
|
||||
|
|
|
@ -11,8 +11,7 @@ class ReflectionBasedTestRunner implements ITestRunner
|
|||
public function run()
|
||||
{
|
||||
$testFixtures = $this->getTestFixtures($this->filter);
|
||||
$success = $this->runAll($testFixtures);
|
||||
exit($success ? 0 : 1);
|
||||
return $this->runAll($testFixtures);
|
||||
}
|
||||
|
||||
public function setFilter($filter)
|
||||
|
|
|
@ -1,4 +1,7 @@
|
|||
<?php
|
||||
require_once __DIR__ . '/../src/core.php';
|
||||
\Chibi\Autoloader::registerFileSystem(__DIR__);
|
||||
|
||||
class SzurubooruTestRunner implements ITestRunner
|
||||
{
|
||||
public function run()
|
||||
|
@ -40,7 +43,21 @@ class SzurubooruTestRunner implements ITestRunner
|
|||
});
|
||||
});
|
||||
|
||||
$testRunner->run();
|
||||
$success = $testRunner->run();
|
||||
$this->removeCache();
|
||||
return $success;
|
||||
}
|
||||
|
||||
private function removeCache()
|
||||
{
|
||||
$cachePath = __DIR__
|
||||
. DIRECTORY_SEPARATOR . '..'
|
||||
. DIRECTORY_SEPARATOR . 'lib'
|
||||
. DIRECTORY_SEPARATOR . 'chibi-core'
|
||||
. DIRECTORY_SEPARATOR . 'cache';
|
||||
|
||||
foreach (glob($cachePath . DIRECTORY_SEPARATOR . '*.dat') as $fn)
|
||||
unlink($fn);
|
||||
}
|
||||
|
||||
private function printHelp()
|
||||
|
@ -157,7 +174,7 @@ class SzurubooruTestRunner implements ITestRunner
|
|||
private function prepareTestConfig($options)
|
||||
{
|
||||
$config = new \Chibi\Config();
|
||||
$config->loadIni(Core::getConfig()->rootDir . DS . 'tests' . DS . 'config.ini');
|
||||
$config->loadIni(Core::getConfig()->rootDir . DIRECTORY_SEPARATOR . 'tests' . DIRECTORY_SEPARATOR . 'config.ini');
|
||||
$config->isForTests = true;
|
||||
|
||||
$config->main->dbDriver = $options->dbDriver;
|
||||
|
@ -180,6 +197,7 @@ class SzurubooruTestRunner implements ITestRunner
|
|||
$_SESSION = [];
|
||||
Auth::setCurrentUser(null);
|
||||
|
||||
$this->removeCache();
|
||||
$this->removeTestFolders();
|
||||
$this->prepareTestConfig($options);
|
||||
Core::prepareEnvironment();
|
||||
|
|
|
@ -34,12 +34,12 @@ class AbstractTest
|
|||
protected function grantAccess($privilege)
|
||||
{
|
||||
Core::getConfig()->privileges->$privilege = 'anonymous';
|
||||
Access::init();
|
||||
Access::initWithoutCache();
|
||||
}
|
||||
|
||||
protected function revokeAccess($privilege)
|
||||
{
|
||||
Core::getConfig()->privileges->$privilege = 'nobody';
|
||||
Access::init();
|
||||
Access::initWithoutCache();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -29,7 +29,7 @@ class AccessTest extends AbstractTest
|
|||
public function testAccessRanks2()
|
||||
{
|
||||
Core::getConfig()->privileges->listPosts = 'power-user';
|
||||
Access::init();
|
||||
Access::initWithoutCache();
|
||||
|
||||
$user = $this->userMocker->mockSingle();
|
||||
$user->setAccessRank(new AccessRank(AccessRank::Admin));
|
||||
|
@ -51,7 +51,7 @@ class AccessTest extends AbstractTest
|
|||
public function testSubPrivilegesOnlySub()
|
||||
{
|
||||
Core::getConfig()->privileges->{'listPosts.own'} = 'power-user';
|
||||
Access::init();
|
||||
Access::initWithoutCache();
|
||||
|
||||
$user = $this->userMocker->mockSingle();
|
||||
$user->setAccessRank(new AccessRank(AccessRank::PowerUser));
|
||||
|
@ -64,7 +64,7 @@ class AccessTest extends AbstractTest
|
|||
{
|
||||
Core::getConfig()->privileges->{'listPosts.own'} = 'power-user';
|
||||
Core::getConfig()->privileges->{'listPosts'} = 'admin';
|
||||
Access::init();
|
||||
Access::initWithoutCache();
|
||||
$this->testSubPrivilegesSubAndGeneral();
|
||||
}
|
||||
|
||||
|
@ -72,7 +72,7 @@ class AccessTest extends AbstractTest
|
|||
{
|
||||
Core::getConfig()->privileges->{'listPosts'} = 'admin';
|
||||
Core::getConfig()->privileges->{'listPosts.own'} = 'power-user';
|
||||
Access::init();
|
||||
Access::initWithoutCache();
|
||||
$this->testSubPrivilegesSubAndGeneral();
|
||||
}
|
||||
|
||||
|
@ -95,7 +95,7 @@ class AccessTest extends AbstractTest
|
|||
Core::getConfig()->privileges->{'listPosts.own'} = 'power-user';
|
||||
Core::getConfig()->privileges->{'listPosts.all'} = 'admin';
|
||||
Core::getConfig()->privileges->{'listPosts'} = 'nobody';
|
||||
Access::init();
|
||||
Access::initWithoutCache();
|
||||
$this->testSubPrivilegesMultipleSubAndGeneral();
|
||||
}
|
||||
|
||||
|
@ -104,7 +104,7 @@ class AccessTest extends AbstractTest
|
|||
Core::getConfig()->privileges->{'listPosts'} = 'nobody';
|
||||
Core::getConfig()->privileges->{'listPosts.own'} = 'power-user';
|
||||
Core::getConfig()->privileges->{'listPosts.all'} = 'admin';
|
||||
Access::init();
|
||||
Access::initWithoutCache();
|
||||
$this->testSubPrivilegesMultipleSubAndGeneral();
|
||||
}
|
||||
|
||||
|
|
|
@ -1,6 +1,5 @@
|
|||
<?php
|
||||
require_once __DIR__ . '/../src/core.php';
|
||||
\Chibi\Autoloader::registerFileSystem(__DIR__);
|
||||
|
||||
require_once 'SzurubooruTestRunner.php';
|
||||
$runner = new SzurubooruTestRunner();
|
||||
$runner->run();
|
||||
$success = $runner->run();
|
||||
exit($success ? 0 : 1);
|
||||
|
|
Loading…
Reference in a new issue