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