* * This file is licensed under the Affero General Public License version 3 or * later. * See the COPYING-README file. */ namespace Test\Settings\Controller; use \OC\Settings\Application; /** * @package OC\Settings\Controller */ class LogSettingsControllerTest extends \Test\TestCase { /** @var \OCP\AppFramework\IAppContainer */ private $container; /** @var LogSettingsController */ private $logSettingsController; protected function setUp() { $app = new Application(); $this->container = $app->getContainer(); $this->container['Config'] = $this->getMockBuilder('\OCP\IConfig') ->disableOriginalConstructor()->getMock(); $this->container['AppName'] = 'settings'; $this->logSettingsController = $this->container['LogSettingsController']; } /** * @dataProvider logLevelData */ public function testSetLogLevel($level, $inRange) { if ($inRange) { $this->container['Config'] ->expects($this->once()) ->method('setSystemValue') ->with('loglevel', $level); } $response = $this->logSettingsController->setLogLevel($level)->getData(); if ($inRange) { $expectedResponse = ['level' => $level]; } else { $expectedResponse = ['message' => 'log-level out of allowed range']; } $this->assertSame($expectedResponse, $response); } public function logLevelData() { return [ [-1, false], [0, true], [1, true], [2, true], [3, true], [4, true], [5, false], ]; } public function testGetFilenameForDownload() { $timestamp = 42; $this->container['Config'] ->expects($this->once()) ->method('getSystemValue') ->with('instanceid') ->will($this->returnValue('0xF')); $filename = \Test_Helper::invokePrivate($this->logSettingsController, 'getFilenameForDownload', [$timestamp]); $this->assertSame('ownCloud-0xF-42.log', $filename); } }