|
|
|
|
@ -3,6 +3,7 @@ |
|
|
|
|
* @author Joas Schilling <nickvergessen@owncloud.com> |
|
|
|
|
* @author Morris Jobke <hey@morrisjobke.de> |
|
|
|
|
* @author Thomas Müller <thomas.mueller@tmit.eu> |
|
|
|
|
* @author Robin McCorkell <rmccorkell@karoshi.org.uk> |
|
|
|
|
* |
|
|
|
|
* @copyright Copyright (c) 2015, ownCloud, Inc. |
|
|
|
|
* @license AGPL-3.0 |
|
|
|
|
@ -24,10 +25,7 @@ |
|
|
|
|
namespace OC\Core\Command\App; |
|
|
|
|
|
|
|
|
|
use OC\App\CodeChecker\CodeChecker; |
|
|
|
|
use OC\App\CodeChecker\DeprecationCheck; |
|
|
|
|
use OC\App\CodeChecker\EmptyCheck; |
|
|
|
|
use OC\App\CodeChecker\PrivateCheck; |
|
|
|
|
use OC\App\CodeChecker\StrongComparisonCheck; |
|
|
|
|
use Symfony\Component\Console\Command\Command; |
|
|
|
|
use Symfony\Component\Console\Input\InputArgument; |
|
|
|
|
use Symfony\Component\Console\Input\InputInterface; |
|
|
|
|
@ -35,6 +33,12 @@ use Symfony\Component\Console\Input\InputOption; |
|
|
|
|
use Symfony\Component\Console\Output\OutputInterface; |
|
|
|
|
|
|
|
|
|
class CheckCode extends Command { |
|
|
|
|
protected $checkers = [ |
|
|
|
|
'private' => '\OC\App\CodeChecker\PrivateCheck', |
|
|
|
|
'deprecation' => '\OC\App\CodeChecker\DeprecationCheck', |
|
|
|
|
'strong-comparison' => '\OC\App\CodeChecker\StrongComparisonCheck', |
|
|
|
|
]; |
|
|
|
|
|
|
|
|
|
protected function configure() { |
|
|
|
|
$this |
|
|
|
|
->setName('app:check-code') |
|
|
|
|
@ -45,22 +49,26 @@ class CheckCode extends Command { |
|
|
|
|
'check the specified app' |
|
|
|
|
) |
|
|
|
|
->addOption( |
|
|
|
|
'deprecated', |
|
|
|
|
'd', |
|
|
|
|
InputOption::VALUE_NONE, |
|
|
|
|
'check the specified app' |
|
|
|
|
'checker', |
|
|
|
|
'c', |
|
|
|
|
InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, |
|
|
|
|
'enable the specified checker', |
|
|
|
|
[ 'private', 'deprecation', 'strong-comparison' ] |
|
|
|
|
); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
protected function execute(InputInterface $input, OutputInterface $output) { |
|
|
|
|
$appId = $input->getArgument('app-id'); |
|
|
|
|
|
|
|
|
|
$checkList = new EmptyCheck(); |
|
|
|
|
if ($input->getOption('deprecated')) { |
|
|
|
|
$checkList = new DeprecationCheck($checkList); |
|
|
|
|
$checkList = new StrongComparisonCheck($checkList); |
|
|
|
|
} else { |
|
|
|
|
$checkList = new PrivateCheck($checkList); |
|
|
|
|
foreach ($input->getOption('checker') as $checker) { |
|
|
|
|
if (!isset($this->checkers[$checker])) { |
|
|
|
|
throw new \InvalidArgumentException('Invalid checker: '.$checker); |
|
|
|
|
} |
|
|
|
|
$checkerClass = $this->checkers[$checker]; |
|
|
|
|
$checkList = new $checkerClass($checkList); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$codeChecker = new CodeChecker($checkList); |
|
|
|
|
|
|
|
|
|
$codeChecker->listen('CodeChecker', 'analyseFileBegin', function($params) use ($output) { |
|
|
|
|
@ -92,9 +100,7 @@ class CheckCode extends Command { |
|
|
|
|
$errors = $codeChecker->analyse($appId); |
|
|
|
|
if (empty($errors)) { |
|
|
|
|
$output->writeln('<info>App is compliant - awesome job!</info>'); |
|
|
|
|
} elseif ($input->getOption('deprecated')) { |
|
|
|
|
$output->writeln('<comment>App uses deprecated functionality</comment>'); |
|
|
|
|
return 102; |
|
|
|
|
return 0; |
|
|
|
|
} else { |
|
|
|
|
$output->writeln('<error>App is not compliant</error>'); |
|
|
|
|
return 101; |
|
|
|
|
|