annotate vendor/squizlabs/php_codesniffer/tests/Standards/AllSniffs.php @ 5:12f9dff5fda9 tip

Update to Drupal core 8.7.1
author Chris Cannam
date Thu, 09 May 2019 15:34:47 +0100
parents a9cd425dd02b
children
rev   line source
Chris@4 1 <?php
Chris@4 2 /**
Chris@4 3 * A test class for testing all sniffs for installed standards.
Chris@4 4 *
Chris@4 5 * @author Greg Sherwood <gsherwood@squiz.net>
Chris@4 6 * @copyright 2006-2015 Squiz Pty Ltd (ABN 77 084 670 600)
Chris@4 7 * @license https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
Chris@4 8 */
Chris@4 9
Chris@4 10 namespace PHP_CodeSniffer\Tests\Standards;
Chris@4 11
Chris@4 12 use PHP_CodeSniffer\Util\Standards;
Chris@4 13 use PHP_CodeSniffer\Autoload;
Chris@4 14 use PHPUnit\TextUI\TestRunner;
Chris@4 15 use PHPUnit\Framework\TestSuite;
Chris@4 16
Chris@4 17 class AllSniffs
Chris@4 18 {
Chris@4 19
Chris@4 20
Chris@4 21 /**
Chris@4 22 * Prepare the test runner.
Chris@4 23 *
Chris@4 24 * @return void
Chris@4 25 */
Chris@4 26 public static function main()
Chris@4 27 {
Chris@4 28 TestRunner::run(self::suite());
Chris@4 29
Chris@4 30 }//end main()
Chris@4 31
Chris@4 32
Chris@4 33 /**
Chris@4 34 * Add all sniff unit tests into a test suite.
Chris@4 35 *
Chris@4 36 * Sniff unit tests are found by recursing through the 'Tests' directory
Chris@4 37 * of each installed coding standard.
Chris@4 38 *
Chris@4 39 * @return \PHPUnit\Framework\TestSuite
Chris@4 40 */
Chris@4 41 public static function suite()
Chris@4 42 {
Chris@4 43 $GLOBALS['PHP_CODESNIFFER_SNIFF_CODES'] = [];
Chris@4 44 $GLOBALS['PHP_CODESNIFFER_FIXABLE_CODES'] = [];
Chris@4 45 $GLOBALS['PHP_CODESNIFFER_SNIFF_CASE_FILES'] = [];
Chris@4 46
Chris@4 47 $suite = new TestSuite('PHP CodeSniffer Standards');
Chris@4 48
Chris@4 49 $isInstalled = !is_file(__DIR__.'/../../autoload.php');
Chris@4 50
Chris@4 51 // Optionally allow for ignoring the tests for one or more standards.
Chris@4 52 $ignoreTestsForStandards = getenv('PHPCS_IGNORE_TESTS');
Chris@4 53 if ($ignoreTestsForStandards === false) {
Chris@4 54 $ignoreTestsForStandards = [];
Chris@4 55 } else {
Chris@4 56 $ignoreTestsForStandards = explode(',', $ignoreTestsForStandards);
Chris@4 57 }
Chris@4 58
Chris@4 59 $installedStandards = self::getInstalledStandardDetails();
Chris@4 60
Chris@4 61 foreach ($installedStandards as $standard => $details) {
Chris@4 62 Autoload::addSearchPath($details['path'], $details['namespace']);
Chris@4 63
Chris@4 64 // If the test is running PEAR installed, the built-in standards
Chris@4 65 // are split into different directories; one for the sniffs and
Chris@4 66 // a different file system location for tests.
Chris@4 67 if ($isInstalled === true && is_dir(dirname($details['path']).DIRECTORY_SEPARATOR.'Generic') === true) {
Chris@4 68 $testPath = realpath(__DIR__.'/../../src/Standards/'.$standard);
Chris@4 69 } else {
Chris@4 70 $testPath = $details['path'];
Chris@4 71 }
Chris@4 72
Chris@5 73 if (in_array($standard, $ignoreTestsForStandards, true) === true) {
Chris@4 74 continue;
Chris@4 75 }
Chris@4 76
Chris@4 77 $testsDir = $testPath.DIRECTORY_SEPARATOR.'Tests'.DIRECTORY_SEPARATOR;
Chris@4 78 if (is_dir($testsDir) === false) {
Chris@4 79 // No tests for this standard.
Chris@4 80 continue;
Chris@4 81 }
Chris@4 82
Chris@4 83 $di = new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($testsDir));
Chris@4 84
Chris@4 85 foreach ($di as $file) {
Chris@4 86 // Skip hidden files.
Chris@4 87 if (substr($file->getFilename(), 0, 1) === '.') {
Chris@4 88 continue;
Chris@4 89 }
Chris@4 90
Chris@4 91 // Tests must have the extension 'php'.
Chris@4 92 $parts = explode('.', $file);
Chris@4 93 $ext = array_pop($parts);
Chris@4 94 if ($ext !== 'php') {
Chris@4 95 continue;
Chris@4 96 }
Chris@4 97
Chris@4 98 $className = Autoload::loadFile($file->getPathname());
Chris@4 99 $GLOBALS['PHP_CODESNIFFER_STANDARD_DIRS'][$className] = $details['path'];
Chris@4 100 $GLOBALS['PHP_CODESNIFFER_TEST_DIRS'][$className] = $testsDir;
Chris@4 101 $suite->addTestSuite($className);
Chris@4 102 }
Chris@4 103 }//end foreach
Chris@4 104
Chris@4 105 return $suite;
Chris@4 106
Chris@4 107 }//end suite()
Chris@4 108
Chris@4 109
Chris@4 110 /**
Chris@4 111 * Get the details of all coding standards installed.
Chris@4 112 *
Chris@4 113 * @return array
Chris@4 114 * @see Standards::getInstalledStandardDetails()
Chris@4 115 */
Chris@4 116 protected static function getInstalledStandardDetails()
Chris@4 117 {
Chris@4 118 return Standards::getInstalledStandardDetails(true);
Chris@4 119
Chris@4 120 }//end getInstalledStandardDetails()
Chris@4 121
Chris@4 122
Chris@4 123 }//end class