. * */ namespace Tests\Core\Command\Config; use OC\Core\Command\App\Enable; use Symfony\Component\Console\Tester\CommandTester; use Test\TestCase; /** * Class AppsEnableTest * * @group DB */ class AppsEnableTest extends TestCase { /** @var CommandTester */ private $commandTester; public function setUp() { parent::setUp(); $command = new Enable( \OC::$server->getAppManager(), \OC::$server->getGroupManager() ); $this->commandTester = new CommandTester($command); } /** * @dataProvider dataCommandInput * @param $appId * @param $groups * @param $statusCode * @param $output */ public function testCommandInput($appId, $groups, $statusCode, $output) { $input = ['app-id' => $appId]; if (is_array($groups)) { $input['--groups'] = $groups; } $this->commandTester->execute($input); $this->assertContains($output, $this->commandTester->getDisplay()); $this->assertSame($statusCode, $this->commandTester->getStatusCode()); } public function dataCommandInput() { return [ [['admin_audit'], null, 0, 'admin_audit enabled'], [['comments'], null, 0, 'comments enabled'], [['invalid_app'], null, 1, 'invalid_app not found'], [['admin_audit', 'comments'], null, 0, "admin_audit enabled\ncomments enabled"], [['admin_audit', 'comments', 'invalid_app'], null, 1, "admin_audit enabled\ncomments enabled\ninvalid_app not found"], [['admin_audit'], ['admin'], 1, "admin_audit can't be enabled for groups"], [['comments'], ['admin'], 1, "comments can't be enabled for groups"], [['updatenotification'], ['admin'], 0, 'updatenotification enabled for groups: admin'], [['updatenotification', 'logreader'], ['admin'], 0, "updatenotification enabled for groups: admin\nlogreader enabled for groups: admin"], [['updatenotification'], ['admin', 'invalid_group'], 0, 'updatenotification enabled for groups: admin'], [['updatenotification', 'logreader'], ['admin', 'invalid_group'], 0, "updatenotification enabled for groups: admin\nlogreader enabled for groups: admin"], [['updatenotification', 'logreader', 'invalid_app'], ['admin', 'invalid_group'], 0, "updatenotification enabled for groups: admin\nlogreader enabled for groups: admin"], ]; } }