split db logic from settings manager

Signed-off-by: Robin Appelman <robin@icewind.nl>
This commit is contained in:
Robin Appelman 2016-12-28 16:58:02 +01:00
parent b399ad2fee
commit c4358ff9fd
No known key found for this signature in database
GPG Key ID: CBCA68FBAEBF98C9
6 changed files with 437 additions and 278 deletions

View File

@ -791,7 +791,8 @@ class Server extends ServerContainer implements IServerContainer {
$c->getConfig(), $c->getConfig(),
$c->getEncryptionManager(), $c->getEncryptionManager(),
$c->getUserManager(), $c->getUserManager(),
$c->getLockingProvider() $c->getLockingProvider(),
new \OC\Settings\Mapper($c->getDatabaseConnection())
); );
return $manager; return $manager;
}); });

View File

@ -23,23 +23,23 @@
namespace OC\Settings\Admin; namespace OC\Settings\Admin;
use OC\Encryption\Manager;
use OCP\AppFramework\Http\TemplateResponse; use OCP\AppFramework\Http\TemplateResponse;
use OCP\Encryption\IManager;
use OCP\IUserManager; use OCP\IUserManager;
use OCP\Settings\ISettings; use OCP\Settings\ISettings;
class Encryption implements ISettings { class Encryption implements ISettings {
/** @var Manager */ /** @var IManager */
private $manager; private $manager;
/** @var IUserManager */ /** @var IUserManager */
private $userManager; private $userManager;
/** /**
* @param Manager $manager * @param IManager $manager
* @param IUserManager $userManager * @param IUserManager $userManager
*/ */
public function __construct(Manager $manager, IUserManager $userManager) { public function __construct(IManager $manager, IUserManager $userManager) {
$this->manager = $manager; $this->manager = $manager;
$this->userManager = $userManager; $this->userManager = $userManager;
} }

View File

@ -43,6 +43,8 @@ class Manager implements IManager {
private $log; private $log;
/** @var IDBConnection */ /** @var IDBConnection */
private $dbc; private $dbc;
/** @var Mapper */
private $mapper;
/** @var IL10N */ /** @var IL10N */
private $l; private $l;
/** @var IConfig */ /** @var IConfig */
@ -62,6 +64,8 @@ class Manager implements IManager {
* @param EncryptionManager $encryptionManager * @param EncryptionManager $encryptionManager
* @param IUserManager $userManager * @param IUserManager $userManager
* @param ILockingProvider $lockingProvider * @param ILockingProvider $lockingProvider
* @param Mapper $mapper
* @internal param IDBConnection $dbc
*/ */
public function __construct( public function __construct(
ILogger $log, ILogger $log,
@ -70,10 +74,12 @@ class Manager implements IManager {
IConfig $config, IConfig $config,
EncryptionManager $encryptionManager, EncryptionManager $encryptionManager,
IUserManager $userManager, IUserManager $userManager,
ILockingProvider $lockingProvider ILockingProvider $lockingProvider,
Mapper $mapper
) { ) {
$this->log = $log; $this->log = $log;
$this->dbc = $dbc; $this->dbc = $dbc;
$this->mapper = $mapper;
$this->l = $l; $this->l = $l;
$this->config = $config; $this->config = $config;
$this->encryptionManager = $encryptionManager; $this->encryptionManager = $encryptionManager;
@ -85,10 +91,10 @@ class Manager implements IManager {
* @inheritdoc * @inheritdoc
*/ */
public function setupSettings(array $settings) { public function setupSettings(array $settings) {
if(isset($settings[IManager::KEY_ADMIN_SECTION])) { if (isset($settings[IManager::KEY_ADMIN_SECTION])) {
$this->setupAdminSection($settings[IManager::KEY_ADMIN_SECTION]); $this->setupAdminSection($settings[IManager::KEY_ADMIN_SECTION]);
} }
if(isset($settings[IManager::KEY_ADMIN_SETTINGS])) { if (isset($settings[IManager::KEY_ADMIN_SETTINGS])) {
$this->setupAdminSettings($settings[IManager::KEY_ADMIN_SETTINGS]); $this->setupAdminSettings($settings[IManager::KEY_ADMIN_SETTINGS]);
} }
} }
@ -104,50 +110,33 @@ class Manager implements IManager {
public function onAppDisabled($appId) { public function onAppDisabled($appId) {
$appInfo = \OC_App::getAppInfo($appId); // hello static legacy $appInfo = \OC_App::getAppInfo($appId); // hello static legacy
if(isset($appInfo['settings'][IManager::KEY_ADMIN_SECTION])) { if (isset($appInfo['settings'][IManager::KEY_ADMIN_SECTION])) {
$this->remove(self::TABLE_ADMIN_SECTIONS, trim($appInfo['settings'][IManager::KEY_ADMIN_SECTION], '\\')); $this->mapper->remove(self::TABLE_ADMIN_SECTIONS, trim($appInfo['settings'][IManager::KEY_ADMIN_SECTION], '\\'));
} }
if(isset($appInfo['settings'][IManager::KEY_ADMIN_SETTINGS])) { if (isset($appInfo['settings'][IManager::KEY_ADMIN_SETTINGS])) {
$this->remove(self::TABLE_ADMIN_SETTINGS, trim($appInfo['settings'][IManager::KEY_ADMIN_SETTINGS], '\\')); $this->mapper->remove(self::TABLE_ADMIN_SETTINGS, trim($appInfo['settings'][IManager::KEY_ADMIN_SETTINGS], '\\'));
} }
} }
public function checkForOrphanedClassNames() { public function checkForOrphanedClassNames() {
$tables = [ self::TABLE_ADMIN_SECTIONS, self::TABLE_ADMIN_SETTINGS ]; $tables = [self::TABLE_ADMIN_SECTIONS, self::TABLE_ADMIN_SETTINGS];
foreach ($tables as $table) { foreach ($tables as $table) {
$classes = $this->getClasses($table); $classes = $this->mapper->getClasses($table);
foreach($classes as $className) { foreach ($classes as $className) {
try { try {
\OC::$server->query($className); \OC::$server->query($className);
} catch (QueryException $e) { } catch (QueryException $e) {
$this->remove($table, $className); $this->mapper->remove($table, $className);
} }
} }
} }
} }
/**
* returns the registerd classes in the given table
*
* @param $table
* @return string[]
*/
private function getClasses($table) {
$q = $this->dbc->getQueryBuilder();
$resultStatement = $q->select('class')
->from($table)
->execute();
$data = $resultStatement->fetchAll();
$resultStatement->closeCursor();
return array_map(function($row) { return $row['class']; }, $data);
}
/** /**
* @param string $sectionClassName * @param string $sectionClassName
*/ */
private function setupAdminSection($sectionClassName) { private function setupAdminSection($sectionClassName) {
if(!class_exists($sectionClassName)) { if (!class_exists($sectionClassName)) {
$this->log->debug('Could not find admin section class ' . $sectionClassName); $this->log->debug('Could not find admin section class ' . $sectionClassName);
return; return;
} }
@ -158,14 +147,14 @@ class Manager implements IManager {
return; return;
} }
if(!$section instanceof ISection) { if (!$section instanceof ISection) {
$this->log->error( $this->log->error(
'Admin section instance must implement \OCP\ISection. Invalid class: {class}', 'Admin section instance must implement \OCP\ISection. Invalid class: {class}',
['class' => $sectionClassName] ['class' => $sectionClassName]
); );
return; return;
} }
if(!$this->hasAdminSection(get_class($section))) { if (!$this->hasAdminSection(get_class($section))) {
$this->addAdminSection($section); $this->addAdminSection($section);
} else { } else {
$this->updateAdminSection($section); $this->updateAdminSection($section);
@ -173,7 +162,7 @@ class Manager implements IManager {
} }
private function addAdminSection(ISection $section) { private function addAdminSection(ISection $section) {
$this->add(self::TABLE_ADMIN_SECTIONS, [ $this->mapper->add(self::TABLE_ADMIN_SECTIONS, [
'id' => $section->getID(), 'id' => $section->getID(),
'class' => get_class($section), 'class' => get_class($section),
'priority' => $section->getPriority(), 'priority' => $section->getPriority(),
@ -181,28 +170,15 @@ class Manager implements IManager {
} }
private function addAdminSettings(ISettings $settings) { private function addAdminSettings(ISettings $settings) {
$this->add(self::TABLE_ADMIN_SETTINGS, [ $this->mapper->add(self::TABLE_ADMIN_SETTINGS, [
'class' => get_class($settings), 'class' => get_class($settings),
'section' => $settings->getSection(), 'section' => $settings->getSection(),
'priority' => $settings->getPriority(), 'priority' => $settings->getPriority(),
]); ]);
} }
/**
* @param string $table
* @param array $values
*/
private function add($table, array $values) {
$query = $this->dbc->getQueryBuilder();
$values = array_map(function($value) use ($query) {
return $query->createNamedParameter($value);
}, $values);
$query->insert($table)->values($values);
$query->execute();
}
private function updateAdminSettings(ISettings $settings) { private function updateAdminSettings(ISettings $settings) {
$this->update( $this->mapper->update(
self::TABLE_ADMIN_SETTINGS, self::TABLE_ADMIN_SETTINGS,
'class', 'class',
get_class($settings), get_class($settings),
@ -214,35 +190,23 @@ class Manager implements IManager {
} }
private function updateAdminSection(ISection $section) { private function updateAdminSection(ISection $section) {
$this->update( $this->mapper->update(
self::TABLE_ADMIN_SECTIONS, self::TABLE_ADMIN_SECTIONS,
'class', 'class',
get_class($section), get_class($section),
[ [
'id' => $section->getID(), 'id' => $section->getID(),
'priority' => $section->getPriority(), 'priority' => $section->getPriority(),
] ]
); );
} }
private function update($table, $idCol, $id, $values) {
$query = $this->dbc->getQueryBuilder();
$query->update($table);
foreach($values as $key => $value) {
$query->set($key, $query->createNamedParameter($value));
}
$query
->where($query->expr()->eq($idCol, $query->createParameter($idCol)))
->setParameter($idCol, $id)
->execute();
}
/** /**
* @param string $className * @param string $className
* @return bool * @return bool
*/ */
private function hasAdminSection($className) { private function hasAdminSection($className) {
return $this->has(self::TABLE_ADMIN_SECTIONS, $className); return $this->mapper->has(self::TABLE_ADMIN_SECTIONS, $className);
} }
/** /**
@ -250,44 +214,11 @@ class Manager implements IManager {
* @return bool * @return bool
*/ */
private function hasAdminSettings($className) { private function hasAdminSettings($className) {
return $this->has(self::TABLE_ADMIN_SETTINGS, $className); return $this->mapper->has(self::TABLE_ADMIN_SETTINGS, $className);
}
/**
* @param string $table
* @param string $className
* @return bool
*/
private function has($table, $className) {
$query = $this->dbc->getQueryBuilder();
$query->select('class')
->from($table)
->where($query->expr()->eq('class', $query->createNamedParameter($className)))
->setMaxResults(1);
$result = $query->execute();
$row = $result->fetch();
$result->closeCursor();
return (bool) $row;
}
/**
* deletes an settings or admin entry from the given table
*
* @param $table
* @param $className
*/
private function remove($table, $className) {
$query = $this->dbc->getQueryBuilder();
$query->delete($table)
->where($query->expr()->eq('class', $query->createNamedParameter($className)));
$query->execute();
} }
private function setupAdminSettings($settingsClassName) { private function setupAdminSettings($settingsClassName) {
if(!class_exists($settingsClassName)) { if (!class_exists($settingsClassName)) {
$this->log->debug('Could not find admin section class ' . $settingsClassName); $this->log->debug('Could not find admin section class ' . $settingsClassName);
return; return;
} }
@ -300,14 +231,14 @@ class Manager implements IManager {
return; return;
} }
if(!$settings instanceof ISettings) { if (!$settings instanceof ISettings) {
$this->log->error( $this->log->error(
'Admin section instance must implement \OCP\Settings\ISection. Invalid class: {class}', 'Admin section instance must implement \OCP\Settings\ISection. Invalid class: {class}',
['class' => $settingsClassName] ['class' => $settingsClassName]
); );
return; return;
} }
if(!$this->hasAdminSettings(get_class($settings))) { if (!$this->hasAdminSettings(get_class($settings))) {
$this->addAdminSettings($settings); $this->addAdminSettings($settings);
} else { } else {
$this->updateAdminSettings($settings); $this->updateAdminSettings($settings);
@ -329,24 +260,17 @@ class Manager implements IManager {
public function getAdminSections() { public function getAdminSections() {
// built-in sections // built-in sections
$sections = [ $sections = [
0 => [new Section('server', $this->l->t('Server settings'), 0)], 0 => [new Section('server', $this->l->t('Server settings'), 0)],
5 => [new Section('sharing', $this->l->t('Sharing'), 0)], 5 => [new Section('sharing', $this->l->t('Sharing'), 0)],
45 => [new Section('encryption', $this->l->t('Encryption'), 0)], 45 => [new Section('encryption', $this->l->t('Encryption'), 0)],
98 => [new Section('additional', $this->l->t('Additional settings'), 0)], 98 => [new Section('additional', $this->l->t('Additional settings'), 0)],
99 => [new Section('tips-tricks', $this->l->t('Tips & tricks'), 0)], 99 => [new Section('tips-tricks', $this->l->t('Tips & tricks'), 0)],
]; ];
$query = $this->dbc->getQueryBuilder(); $rows = $this->mapper->getAdminSectionsFromDB();
$query->selectDistinct('s.class')
->addSelect('s.priority')
->from(self::TABLE_ADMIN_SECTIONS, 's')
->from(self::TABLE_ADMIN_SETTINGS, 'f')
->where($query->expr()->eq('s.id', 'f.section'))
;
$result = $query->execute();
while($row = $result->fetch()) { foreach ($rows as $row) {
if(!isset($sections[$row['priority']])) { if (!isset($sections[$row['priority']])) {
$sections[$row['priority']] = []; $sections[$row['priority']] = [];
} }
try { try {
@ -355,38 +279,42 @@ class Manager implements IManager {
// skip // skip
} }
} }
$result->closeCursor();
ksort($sections); ksort($sections);
return $sections; return $sections;
} }
/**
* @param string $section
* @return ISection[]
*/
private function getBuiltInAdminSettings($section) { private function getBuiltInAdminSettings($section) {
$forms = []; $forms = [];
try { try {
if($section === 'server') { if ($section === 'server') {
/** @var ISettings $form */ /** @var ISettings $form */
$form = new Admin\Server($this->dbc, $this->config, $this->lockingProvider, $this->l); $form = new Admin\Server($this->dbc, $this->config, $this->lockingProvider, $this->l);
$forms[$form->getPriority()] = [$form]; $forms[$form->getPriority()] = [$form];
$form = new Admin\ServerDevNotice(); $form = new Admin\ServerDevNotice();
$forms[$form->getPriority()] = [$form]; $forms[$form->getPriority()] = [$form];
} }
if($section === 'encryption') { if ($section === 'encryption') {
/** @var ISettings $form */ /** @var ISettings $form */
$form = new Admin\Encryption($this->encryptionManager, $this->userManager); $form = new Admin\Encryption($this->encryptionManager, $this->userManager);
$forms[$form->getPriority()] = [$form]; $forms[$form->getPriority()] = [$form];
} }
if($section === 'sharing') { if ($section === 'sharing') {
/** @var ISettings $form */ /** @var ISettings $form */
$form = new Admin\Sharing($this->config); $form = new Admin\Sharing($this->config);
$forms[$form->getPriority()] = [$form]; $forms[$form->getPriority()] = [$form];
} }
if($section === 'additional') { if ($section === 'additional') {
/** @var ISettings $form */ /** @var ISettings $form */
$form = new Admin\Additional($this->config); $form = new Admin\Additional($this->config);
$forms[$form->getPriority()] = [$form]; $forms[$form->getPriority()] = [$form];
} }
if($section === 'tips-tricks') { if ($section === 'tips-tricks') {
/** @var ISettings $form */ /** @var ISettings $form */
$form = new Admin\TipsTricks($this->config); $form = new Admin\TipsTricks($this->config);
$forms[$form->getPriority()] = [$form]; $forms[$form->getPriority()] = [$form];
@ -397,16 +325,15 @@ class Manager implements IManager {
return $forms; return $forms;
} }
private function getAdminSettingsFromDB($section, &$settings) { /**
$query = $this->dbc->getQueryBuilder(); * @inheritdoc
$query->select(['class', 'priority']) */
->from(self::TABLE_ADMIN_SETTINGS) public function getAdminSettings($section) {
->where($query->expr()->eq('section', $this->dbc->getQueryBuilder()->createParameter('section'))) $settings = $this->getBuiltInAdminSettings($section);
->setParameter('section', $section); $dbRows = $this->mapper->getAdminSettingsFromDB($section);
$result = $query->execute(); foreach ($dbRows as $row) {
while($row = $result->fetch()) { if (!isset($settings[$row['priority']])) {
if(!isset($settings[$row['priority']])) {
$settings[$row['priority']] = []; $settings[$row['priority']] = [];
} }
try { try {
@ -415,17 +342,8 @@ class Manager implements IManager {
// skip // skip
} }
} }
$result->closeCursor();
ksort($settings); ksort($settings);
}
/**
* @inheritdoc
*/
public function getAdminSettings($section) {
$settings = $this->getBuiltInAdminSettings($section);
$this->getAdminSettingsFromDB($section, $settings);
return $settings; return $settings;
} }
} }

View File

@ -0,0 +1,144 @@
<?php
/**
* @copyright Copyright (c) 2016 Robin Appelman <robin@icewind.nl>
*
* @author Robin Appelman <robin@icewind.nl>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace OC\Settings;
use OCP\IDBConnection;
class Mapper {
const TABLE_ADMIN_SETTINGS = 'admin_settings';
const TABLE_ADMIN_SECTIONS = 'admin_sections';
/** @var IDBConnection */
private $dbc;
/**
* @param IDBConnection $dbc
*/
public function __construct(IDBConnection $dbc) {
$this->dbc = $dbc;
}
public function getAdminSettingsFromDB($section) {
$query = $this->dbc->getQueryBuilder();
$query->select(['class', 'priority'])
->from(self::TABLE_ADMIN_SETTINGS)
->where($query->expr()->eq('section', $this->dbc->getQueryBuilder()->createParameter('section')))
->setParameter('section', $section);
$result = $query->execute();
return $result->fetchAll();
}
public function getAdminSectionsFromDB() {
$query = $this->dbc->getQueryBuilder();
$query->selectDistinct('s.class')
->addSelect('s.priority')
->from(self::TABLE_ADMIN_SECTIONS, 's')
->from(self::TABLE_ADMIN_SETTINGS, 'f')
->where($query->expr()->eq('s.id', 'f.section'));
$result = $query->execute();
return array_map(function ($row) {
$row['priority'] = (int)$row['priority'];
return $row;
}, $result->fetchAll());
}
/**
* @param string $table
* @param array $values
*/
public function add($table, array $values) {
$query = $this->dbc->getQueryBuilder();
$values = array_map(function ($value) use ($query) {
return $query->createNamedParameter($value);
}, $values);
$query->insert($table)->values($values);
$query->execute();
}
/**
* returns the registered classes in the given table
*
* @param $table
* @return string[]
*/
public function getClasses($table) {
$q = $this->dbc->getQueryBuilder();
$resultStatement = $q->select('class')
->from($table)
->execute();
$data = $resultStatement->fetchAll();
$resultStatement->closeCursor();
return array_map(function ($row) {
return $row['class'];
}, $data);
}
/**
* @param string $table
* @param string $className
* @return bool
*/
public function has($table, $className) {
$query = $this->dbc->getQueryBuilder();
$query->select('class')
->from($table)
->where($query->expr()->eq('class', $query->createNamedParameter($className)))
->setMaxResults(1);
$result = $query->execute();
$row = $result->fetch();
$result->closeCursor();
return (bool)$row;
}
/**
* deletes an settings or admin entry from the given table
*
* @param $table
* @param $className
*/
public function remove($table, $className) {
$query = $this->dbc->getQueryBuilder();
$query->delete($table)
->where($query->expr()->eq('class', $query->createNamedParameter($className)));
$query->execute();
}
public function update($table, $idCol, $id, $values) {
$query = $this->dbc->getQueryBuilder();
$query->update($table);
foreach ($values as $key => $value) {
$query->set($key, $query->createNamedParameter($value));
}
$query
->where($query->expr()->eq($idCol, $query->createParameter($idCol)))
->setParameter($idCol, $id)
->execute();
}
}

View File

@ -25,6 +25,7 @@ namespace Tests\Settings;
use OC\Settings\Admin\Sharing; use OC\Settings\Admin\Sharing;
use OC\Settings\Manager; use OC\Settings\Manager;
use OC\Settings\Mapper;
use OC\Settings\Section; use OC\Settings\Section;
use OCP\Encryption\IManager; use OCP\Encryption\IManager;
use OCP\IConfig; use OCP\IConfig;
@ -36,22 +37,24 @@ use OCP\Lock\ILockingProvider;
use Test\TestCase; use Test\TestCase;
class ManagerTest extends TestCase { class ManagerTest extends TestCase {
/** @var Manager */ /** @var Manager|\PHPUnit_Framework_MockObject_MockObject */
private $manager; private $manager;
/** @var ILogger */ /** @var ILogger|\PHPUnit_Framework_MockObject_MockObject */
private $logger; private $logger;
/** @var IDBConnection */ /** @var IDBConnection|\PHPUnit_Framework_MockObject_MockObject */
private $dbConnection; private $dbConnection;
/** @var IL10N */ /** @var IL10N|\PHPUnit_Framework_MockObject_MockObject */
private $l10n; private $l10n;
/** @var IConfig */ /** @var IConfig|\PHPUnit_Framework_MockObject_MockObject */
private $config; private $config;
/** @var IManager */ /** @var IManager|\PHPUnit_Framework_MockObject_MockObject */
private $encryptionManager; private $encryptionManager;
/** @var IUserManager */ /** @var IUserManager|\PHPUnit_Framework_MockObject_MockObject */
private $userManager; private $userManager;
/** @var ILockingProvider */ /** @var ILockingProvider|\PHPUnit_Framework_MockObject_MockObject */
private $lockingProvider; private $lockingProvider;
/** @var Mapper|\PHPUnit_Framework_MockObject_MockObject */
private $mapper;
public function setUp() { public function setUp() {
parent::setUp(); parent::setUp();
@ -63,6 +66,7 @@ class ManagerTest extends TestCase {
$this->encryptionManager = $this->getMockBuilder('\OCP\Encryption\IManager')->getMock(); $this->encryptionManager = $this->getMockBuilder('\OCP\Encryption\IManager')->getMock();
$this->userManager = $this->getMockBuilder('\OCP\IUserManager')->getMock(); $this->userManager = $this->getMockBuilder('\OCP\IUserManager')->getMock();
$this->lockingProvider = $this->getMockBuilder('\OCP\Lock\ILockingProvider')->getMock(); $this->lockingProvider = $this->getMockBuilder('\OCP\Lock\ILockingProvider')->getMock();
$this->mapper = $this->getMockBuilder(Mapper::class)->disableOriginalConstructor()->getMock();
$this->manager = new Manager( $this->manager = new Manager(
$this->logger, $this->logger,
@ -71,63 +75,49 @@ class ManagerTest extends TestCase {
$this->config, $this->config,
$this->encryptionManager, $this->encryptionManager,
$this->userManager, $this->userManager,
$this->lockingProvider $this->lockingProvider,
$this->mapper
); );
} }
public function testSetupSettings() { public function testSetupSettingsUpdate() {
$qb = $this->getMockBuilder('\OCP\DB\QueryBuilder\IQueryBuilder')->getMock(); $this->mapper->expects($this->any())
$qb ->method('has')
->expects($this->once()) ->with('admin_settings', 'OCA\Files\Settings\Admin')
->method('select') ->will($this->returnValue(true));
->with('class')
->willReturn($qb);
$this->dbConnection
->expects($this->at(0))
->method('getQueryBuilder')
->willReturn($qb);
$qb
->expects($this->once())
->method('from')
->with('admin_settings')
->willReturn($qb);
$expressionBuilder = $this->getMockBuilder('\OCP\DB\QueryBuilder\IExpressionBuilder')->getMock();
$qb
->expects($this->once())
->method('expr')
->willReturn($expressionBuilder);
$param = $this->getMockBuilder('\OCP\DB\QueryBuilder\IParameter')->getMock();
$qb
->expects($this->once())
->method('createNamedParameter')
->with('OCA\Files\Settings\Admin')
->willReturn($param);
$expressionBuilder
->expects($this->once())
->method('eq')
->with('class', $param)
->willReturn('myString');
$qb
->expects($this->once())
->method('where')
->with('myString')
->willReturn($qb);
$stmt = $this->getMockBuilder('\Doctrine\DBAL\Driver\Statement')->getMock();
$qb
->expects($this->once())
->method('execute')
->willReturn($stmt);
$qb1 = $this->getMockBuilder('\OCP\DB\QueryBuilder\IQueryBuilder')->getMock(); $this->mapper->expects($this->once())
$qb1 ->method('update')
->expects($this->once()) ->with('admin_settings',
->method('insert') 'class',
->with('admin_settings') 'OCA\Files\Settings\Admin', [
->willReturn($qb1); 'section' => 'additional',
$this->dbConnection 'priority' => 5
->expects($this->at(1)) ]);
->method('getQueryBuilder') $this->mapper->expects($this->never())
->willReturn($qb1); ->method('add');
$this->manager->setupSettings([
'admin' => 'OCA\Files\Settings\Admin',
]);
}
public function testSetupSettingsAdd() {
$this->mapper->expects($this->any())
->method('has')
->with('admin_settings', 'OCA\Files\Settings\Admin')
->will($this->returnValue(false));
$this->mapper->expects($this->once())
->method('add')
->with('admin_settings', [
'class' => 'OCA\Files\Settings\Admin',
'section' => 'additional',
'priority' => 5
]);
$this->mapper->expects($this->never())
->method('update');
$this->manager->setupSettings([ $this->manager->setupSettings([
'admin' => 'OCA\Files\Settings\Admin', 'admin' => 'OCA\Files\Settings\Admin',
@ -135,44 +125,49 @@ class ManagerTest extends TestCase {
} }
public function testGetAdminSections() { public function testGetAdminSections() {
$qb = $this->getMockBuilder('\OCP\DB\QueryBuilder\IQueryBuilder')->getMock();
$expr = $this->getMockBuilder('OCP\DB\QueryBuilder\IExpressionBuilder')->getMock();
$qb
->expects($this->once())
->method('selectDistinct')
->with('s.class')
->willReturn($qb);
$qb
->expects($this->once())
->method('addSelect')
->with('s.priority')
->willReturn($qb);
$qb
->expects($this->exactly(2))
->method('from')
->willReturn($qb);
$qb
->expects($this->once())
->method('expr')
->willReturn($expr);
$qb
->expects($this->once())
->method('where')
->willReturn($qb);
$stmt = $this->getMockBuilder('\Doctrine\DBAL\Driver\Statement')->getMock();
$qb
->expects($this->once())
->method('execute')
->willReturn($stmt);
$this->dbConnection
->expects($this->once())
->method('getQueryBuilder')
->willReturn($qb);
$this->l10n $this->l10n
->expects($this->any()) ->expects($this->any())
->method('t') ->method('t')
->will($this->returnArgument(0)); ->will($this->returnArgument(0));
$this->mapper->expects($this->once())
->method('getAdminSectionsFromDB')
->will($this->returnValue([
['class' => '\OCA\LogReader\Settings\Section', 'priority' => 90]
]));
$this->mapper->expects($this->once())
->method('getAdminSettingsCountFromDB')
->will($this->returnValue([
'logging' => 1
]));
$this->assertEquals([
0 => [new Section('server', 'Server settings', 0)],
5 => [new Section('sharing', 'Sharing', 0)],
45 => [new Section('encryption', 'Encryption', 0)],
90 => [new \OCA\LogReader\Settings\Section(\OC::$server->getL10N('logreader'))],
98 => [new Section('additional', 'Additional settings', 0)],
99 => [new Section('tips-tricks', 'Tips & tricks', 0)],
], $this->manager->getAdminSections());
}
public function testGetAdminSectionsEmptySection() {
$this->l10n
->expects($this->any())
->method('t')
->will($this->returnArgument(0));
$this->mapper->expects($this->once())
->method('getAdminSectionsFromDB')
->will($this->returnValue([
['class' => '\OCA\LogReader\Settings\Section', 'priority' => 90]
]));
$this->mapper->expects($this->once())
->method('getAdminSettingsCountFromDB')
->will($this->returnValue([]));
$this->assertEquals([ $this->assertEquals([
0 => [new Section('server', 'Server settings', 0)], 0 => [new Section('server', 'Server settings', 0)],
5 => [new Section('sharing', 'Sharing', 0)], 5 => [new Section('sharing', 'Sharing', 0)],
@ -183,47 +178,9 @@ class ManagerTest extends TestCase {
} }
public function testGetAdminSettings() { public function testGetAdminSettings() {
$qb = $this->getMockBuilder('\OCP\DB\QueryBuilder\IQueryBuilder')->getMock(); $this->mapper->expects($this->any())
$qb ->method('getAdminSettingsFromDB')
->expects($this->once()) ->will($this->returnValue([]));
->method('select')
->with(['class', 'priority'])
->willReturn($qb);
$qb
->expects($this->once())
->method('from')
->with('admin_settings')
->willReturn($qb);
$expressionBuilder = $this->getMockBuilder('\OCP\DB\QueryBuilder\IExpressionBuilder')->getMock();
$qb
->expects($this->once())
->method('expr')
->willReturn($expressionBuilder);
$param = $this->getMockBuilder('\OCP\DB\QueryBuilder\IParameter')->getMock();
$qb
->expects($this->once())
->method('createParameter')
->with('section')
->willReturn($param);
$expressionBuilder
->expects($this->once())
->method('eq')
->with('section', $param)
->willReturn('myString');
$qb
->expects($this->once())
->method('where')
->with('myString')
->willReturn($qb);
$stmt = $this->getMockBuilder('\Doctrine\DBAL\Driver\Statement')->getMock();
$qb
->expects($this->once())
->method('execute')
->willReturn($stmt);
$this->dbConnection
->expects($this->exactly(2))
->method('getQueryBuilder')
->willReturn($qb);
$this->assertEquals([ $this->assertEquals([
0 => [new Sharing($this->config)], 0 => [new Sharing($this->config)],

View File

@ -0,0 +1,139 @@
<?php
/**
* @copyright Copyright (c) 2016 Robin Appelman <robin@icewind.nl>
*
* @author Robin Appelman <robin@icewind.nl>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace Tests\Settings;
use OC\DB\QueryBuilder\Literal;
use OC\Settings\Mapper;
use Test\TestCase;
/**
* @group DB
*/
class MapperTest extends TestCase {
const SECTION_PREFIX = 'test_section_';
/** @var Mapper */
private $mapper;
public function setUp() {
parent::setUp();
$this->mapper = new Mapper(\OC::$server->getDatabaseConnection());
}
public function tearDown() {
parent::tearDown();
$db = \OC::$server->getDatabaseConnection();
$builder = $db->getQueryBuilder();
$builder->delete(Mapper::TABLE_ADMIN_SECTIONS)
->where($builder->expr()->like('id', new Literal(self::SECTION_PREFIX . '%')));
$builder->delete(Mapper::TABLE_ADMIN_SETTINGS)
->where($builder->expr()->like('section', new Literal(self::SECTION_PREFIX . '%')));
}
public function testManipulateSettings() {
$this->assertEquals(false, $this->mapper->has(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy'));
$this->assertNotContains('\OC\Dummy', $this->mapper->getClasses(Mapper::TABLE_ADMIN_SETTINGS));
$this->mapper->add(Mapper::TABLE_ADMIN_SETTINGS, [
'class' => '\OC\Dummy',
'section' => self::SECTION_PREFIX . '1',
'priority' => 5
]);
$this->assertEquals(true, $this->mapper->has(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy'));
$this->assertContains('\OC\Dummy', $this->mapper->getClasses(Mapper::TABLE_ADMIN_SETTINGS));
$rows = $this->mapper->getAdminSettingsFromDB(self::SECTION_PREFIX . '1');
$this->assertEquals([
['class' => '\OC\Dummy', 'priority' => 5]
], $rows);
$this->mapper->update(Mapper::TABLE_ADMIN_SETTINGS, 'class', '\OC\Dummy', [
'section' => self::SECTION_PREFIX . '1', 'priority' => 15
]);
$rows = $this->mapper->getAdminSettingsFromDB(self::SECTION_PREFIX . '1');
$this->assertEquals([
['class' => '\OC\Dummy', 'priority' => 15]
], $rows);
$this->mapper->update(Mapper::TABLE_ADMIN_SETTINGS, 'class', '\OC\Dummy', [
'section' => self::SECTION_PREFIX . '2', 'priority' => 15
]);
$this->assertEquals([], $this->mapper->getAdminSettingsFromDB(self::SECTION_PREFIX . '1'));
$rows = $this->mapper->getAdminSettingsFromDB(self::SECTION_PREFIX . '2');
$this->assertEquals([
['class' => '\OC\Dummy', 'priority' => 15]
], $rows);
$this->mapper->remove(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy');
$this->assertEquals(false, $this->mapper->has(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy'));
}
public function testGetAdminSections() {
$this->assertFalse($this->mapper->has(Mapper::TABLE_ADMIN_SECTIONS, '\OC\Dummy'));
$this->mapper->add(Mapper::TABLE_ADMIN_SECTIONS, [
'id' => self::SECTION_PREFIX . '1',
'class' => '\OC\Dummy',
'priority' => 1,
]);
$this->assertTrue($this->mapper->has(Mapper::TABLE_ADMIN_SECTIONS, '\OC\Dummy'));
// until we add a setting for the section it's not returned
$this->assertNotContains([
'class' => '\OC\Dummy',
'priority' => 1,
], $this->mapper->getAdminSectionsFromDB());
$this->mapper->add(Mapper::TABLE_ADMIN_SETTINGS, [
'class' => '\OC\Dummy',
'section' => self::SECTION_PREFIX . '1',
'priority' => 5
]);
$this->assertContains([
'class' => '\OC\Dummy',
'priority' => 1,
], $this->mapper->getAdminSectionsFromDB());
$this->mapper->remove(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy');
$this->assertNotContains([
'class' => '\OC\Dummy',
'priority' => 1,
], $this->mapper->getAdminSectionsFromDB());
$this->mapper->remove(Mapper::TABLE_ADMIN_SECTIONS, '\OC\Dummy');
$this->assertFalse($this->mapper->has(Mapper::TABLE_ADMIN_SECTIONS, '\OC\Dummy'));
}
}