annotate vendor/squizlabs/php_codesniffer/CodeSniffer/Reports/Junit.php @ 0:c75dbcec494b

Initial commit from drush-created site
author Chris Cannam
date Thu, 05 Jul 2018 14:24:15 +0000
parents
children
rev   line source
Chris@0 1 <?php
Chris@0 2 /**
Chris@0 3 * JUnit report for PHP_CodeSniffer.
Chris@0 4 *
Chris@0 5 * PHP version 5
Chris@0 6 *
Chris@0 7 * @category PHP
Chris@0 8 * @package PHP_CodeSniffer
Chris@0 9 * @author Oleg Lobach <oleg@lobach.info>
Chris@0 10 * @author Greg Sherwood <gsherwood@squiz.net>
Chris@0 11 * @copyright 2006-2014 Squiz Pty Ltd (ABN 77 084 670 600)
Chris@0 12 * @license https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
Chris@0 13 * @link http://pear.php.net/package/PHP_CodeSniffer
Chris@0 14 */
Chris@0 15
Chris@0 16 /**
Chris@0 17 * JUnit report for PHP_CodeSniffer.
Chris@0 18 *
Chris@0 19 * PHP version 5
Chris@0 20 *
Chris@0 21 * @category PHP
Chris@0 22 * @package PHP_CodeSniffer
Chris@0 23 * @author Oleg Lobach <oleg@lobach.info>
Chris@0 24 * @author Greg Sherwood <gsherwood@squiz.net>
Chris@0 25 * @copyright 2006-2014 Squiz Pty Ltd (ABN 77 084 670 600)
Chris@0 26 * @license https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
Chris@0 27 * @version Release: @package_version@
Chris@0 28 * @link http://pear.php.net/package/PHP_CodeSniffer
Chris@0 29 */
Chris@0 30 class PHP_CodeSniffer_Reports_Junit implements PHP_CodeSniffer_Report
Chris@0 31 {
Chris@0 32
Chris@0 33 /**
Chris@0 34 * A count of tests that have been performed.
Chris@0 35 *
Chris@0 36 * @var int
Chris@0 37 */
Chris@0 38 private $_tests = 0;
Chris@0 39
Chris@0 40
Chris@0 41 /**
Chris@0 42 * Generate a partial report for a single processed file.
Chris@0 43 *
Chris@0 44 * Function should return TRUE if it printed or stored data about the file
Chris@0 45 * and FALSE if it ignored the file. Returning TRUE indicates that the file and
Chris@0 46 * its data should be counted in the grand totals.
Chris@0 47 *
Chris@0 48 * @param array $report Prepared report data.
Chris@0 49 * @param PHP_CodeSniffer_File $phpcsFile The file being reported on.
Chris@0 50 * @param boolean $showSources Show sources?
Chris@0 51 * @param int $width Maximum allowed line width.
Chris@0 52 *
Chris@0 53 * @return boolean
Chris@0 54 */
Chris@0 55 public function generateFileReport(
Chris@0 56 $report,
Chris@0 57 PHP_CodeSniffer_File $phpcsFile,
Chris@0 58 $showSources=false,
Chris@0 59 $width=80
Chris@0 60 ) {
Chris@0 61 if (count($report['messages']) === 0) {
Chris@0 62 $this->_tests++;
Chris@0 63 } else {
Chris@0 64 $this->_tests += ($report['errors'] + $report['warnings']);
Chris@0 65 }
Chris@0 66
Chris@0 67 $out = new XMLWriter;
Chris@0 68 $out->openMemory();
Chris@0 69 $out->setIndent(true);
Chris@0 70
Chris@0 71 $out->startElement('testsuite');
Chris@0 72 $out->writeAttribute('name', $report['filename']);
Chris@0 73
Chris@0 74 if (count($report['messages']) === 0) {
Chris@0 75 $out->writeAttribute('tests', 1);
Chris@0 76 $out->writeAttribute('failures', 0);
Chris@0 77
Chris@0 78 $out->startElement('testcase');
Chris@0 79 $out->writeAttribute('name', $report['filename']);
Chris@0 80 $out->endElement();
Chris@0 81 } else {
Chris@0 82 $failures = ($report['errors'] + $report['warnings']);
Chris@0 83 $out->writeAttribute('tests', $failures);
Chris@0 84 $out->writeAttribute('failures', $failures);
Chris@0 85
Chris@0 86 foreach ($report['messages'] as $line => $lineErrors) {
Chris@0 87 foreach ($lineErrors as $column => $colErrors) {
Chris@0 88 foreach ($colErrors as $error) {
Chris@0 89 $out->startElement('testcase');
Chris@0 90 $out->writeAttribute('name', $error['source'].' at '.$report['filename']." ($line:$column)");
Chris@0 91
Chris@0 92 $error['type'] = strtolower($error['type']);
Chris@0 93 if (PHP_CODESNIFFER_ENCODING !== 'utf-8') {
Chris@0 94 $error['message'] = iconv(PHP_CODESNIFFER_ENCODING, 'utf-8', $error['message']);
Chris@0 95 }
Chris@0 96
Chris@0 97 $out->startElement('failure');
Chris@0 98 $out->writeAttribute('type', $error['type']);
Chris@0 99 $out->writeAttribute('message', $error['message']);
Chris@0 100 $out->endElement();
Chris@0 101
Chris@0 102 $out->endElement();
Chris@0 103 }
Chris@0 104 }
Chris@0 105 }
Chris@0 106 }//end if
Chris@0 107
Chris@0 108 $out->endElement();
Chris@0 109 echo $out->flush();
Chris@0 110 return true;
Chris@0 111
Chris@0 112 }//end generateFileReport()
Chris@0 113
Chris@0 114
Chris@0 115 /**
Chris@0 116 * Prints all violations for processed files, in a proprietary XML format.
Chris@0 117 *
Chris@0 118 * @param string $cachedData Any partial report data that was returned from
Chris@0 119 * generateFileReport during the run.
Chris@0 120 * @param int $totalFiles Total number of files processed during the run.
Chris@0 121 * @param int $totalErrors Total number of errors found during the run.
Chris@0 122 * @param int $totalWarnings Total number of warnings found during the run.
Chris@0 123 * @param int $totalFixable Total number of problems that can be fixed.
Chris@0 124 * @param boolean $showSources Show sources?
Chris@0 125 * @param int $width Maximum allowed line width.
Chris@0 126 * @param boolean $toScreen Is the report being printed to screen?
Chris@0 127 *
Chris@0 128 * @return void
Chris@0 129 */
Chris@0 130 public function generate(
Chris@0 131 $cachedData,
Chris@0 132 $totalFiles,
Chris@0 133 $totalErrors,
Chris@0 134 $totalWarnings,
Chris@0 135 $totalFixable,
Chris@0 136 $showSources=false,
Chris@0 137 $width=80,
Chris@0 138 $toScreen=true
Chris@0 139 ) {
Chris@0 140 $failures = ($totalErrors + $totalWarnings);
Chris@0 141 echo '<?xml version="1.0" encoding="UTF-8"?>'.PHP_EOL;
Chris@0 142 echo '<testsuites name="PHP_CodeSniffer '.PHP_CodeSniffer::VERSION.'" tests="'.$this->_tests.'" failures="'.$failures.'">'.PHP_EOL;
Chris@0 143 echo $cachedData;
Chris@0 144 echo '</testsuites>'.PHP_EOL;
Chris@0 145
Chris@0 146 }//end generate()
Chris@0 147
Chris@0 148
Chris@0 149 }//end class