123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- <?php
- /**
- * @author Joas Schilling <nickvergessen@owncloud.com>
- *
- * @copyright Copyright (c) 2015, ownCloud, Inc.
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * 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, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
- */
- namespace Tests\Core\Command\Config\App;
- use OC\Core\Command\Config\App\GetConfig;
- use OCP\IConfig;
- use Symfony\Component\Console\Input\InputInterface;
- use Symfony\Component\Console\Output\OutputInterface;
- use Test\TestCase;
- class GetConfigTest extends TestCase {
- /** @var \PHPUnit_Framework_MockObject_MockObject */
- protected $config;
- /** @var \PHPUnit_Framework_MockObject_MockObject */
- protected $consoleInput;
- /** @var \PHPUnit_Framework_MockObject_MockObject */
- protected $consoleOutput;
- /** @var \Symfony\Component\Console\Command\Command */
- protected $command;
- protected function setUp() {
- parent::setUp();
- $config = $this->config = $this->getMockBuilder(IConfig::class)
- ->disableOriginalConstructor()
- ->getMock();
- $this->consoleInput = $this->getMockBuilder(InputInterface::class)->getMock();
- $this->consoleOutput = $this->getMockBuilder(OutputInterface::class)->getMock();
- /** @var \OCP\IConfig $config */
- $this->command = new GetConfig($config);
- }
- public function getData() {
- return [
- // String output as json
- ['name', 'newvalue', true, null, false, 'json', 0, json_encode('newvalue')],
- // String output as plain text
- ['name', 'newvalue', true, null, false, 'plain', 0, 'newvalue'],
- // String falling back to default output as json
- ['name', null, false, 'newvalue', true, 'json', 0, json_encode('newvalue')],
- // String falling back without default: error
- ['name', null, false, null, false, 'json', 1, null],
- // Int "0" output as json/plain
- ['name', 0, true, null, false, 'json', 0, json_encode(0)],
- ['name', 0, true, null, false, 'plain', 0, '0'],
- // Int "1" output as json/plain
- ['name', 1, true, null, false, 'json', 0, json_encode(1)],
- ['name', 1, true, null, false, 'plain', 0, '1'],
- // Bool "true" output as json/plain
- ['name', true, true, null, false, 'json', 0, json_encode(true)],
- ['name', true, true, null, false, 'plain', 0, 'true'],
- // Bool "false" output as json/plain
- ['name', false, true, null, false, 'json', 0, json_encode(false)],
- ['name', false, true, null, false, 'plain', 0, 'false'],
- // Null output as json/plain
- ['name', null, true, null, false, 'json', 0, json_encode(null)],
- ['name', null, true, null, false, 'plain', 0, 'null'],
- // Array output as json/plain
- ['name', ['a', 'b'], true, null, false, 'json', 0, json_encode(['a', 'b'])],
- ['name', ['a', 'b'], true, null, false, 'plain', 0, "a\nb"],
- // Key array output as json/plain
- ['name', [0 => 'a', 1 => 'b'], true, null, false, 'json', 0, json_encode(['a', 'b'])],
- ['name', [0 => 'a', 1 => 'b'], true, null, false, 'plain', 0, "a\nb"],
- // Associative array output as json/plain
- ['name', ['a' => 1, 'b' => 2], true, null, false, 'json', 0, json_encode(['a' => 1, 'b' => 2])],
- ['name', ['a' => 1, 'b' => 2], true, null, false, 'plain', 0, "a: 1\nb: 2"],
- ];
- }
- /**
- * @dataProvider getData
- *
- * @param string $configName
- * @param mixed $value
- * @param bool $configExists
- * @param mixed $defaultValue
- * @param bool $hasDefault
- * @param string $outputFormat
- * @param int $expectedReturn
- * @param string $expectedMessage
- */
- public function testGet($configName, $value, $configExists, $defaultValue, $hasDefault, $outputFormat, $expectedReturn, $expectedMessage) {
- $this->config->expects($this->atLeastOnce())
- ->method('getAppKeys')
- ->with('app-name')
- ->willReturn($configExists ? [$configName] : []);
- if (!$expectedReturn) {
- if ($configExists) {
- $this->config->expects($this->once())
- ->method('getAppValue')
- ->with('app-name', $configName)
- ->willReturn($value);
- }
- }
- $this->consoleInput->expects($this->exactly(2))
- ->method('getArgument')
- ->willReturnMap([
- ['app', 'app-name'],
- ['name', $configName],
- ]);
- $this->consoleInput->expects($this->any())
- ->method('getOption')
- ->willReturnMap([
- ['default-value', $defaultValue],
- ['output', $outputFormat],
- ]);
- $this->consoleInput->expects($this->any())
- ->method('hasParameterOption')
- ->willReturnMap([
- ['--output', false, true],
- ['--default-value', false, $hasDefault],
- ]);
- if ($expectedMessage !== null) {
- global $output;
- $output = '';
- $this->consoleOutput->expects($this->any())
- ->method('writeln')
- ->willReturnCallback(function($value) {
- global $output;
- $output .= $value . "\n";
- return $output;
- });
- }
- $this->assertSame($expectedReturn, $this->invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]));
- if ($expectedMessage !== null) {
- global $output;
- // Remove the trailing newline
- $this->assertSame($expectedMessage, substr($output, 0, -1));
- }
- }
- }
|