NoEmptyCommentFixerTest.php 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  1. <?php
  2. declare(strict_types=1);
  3. /*
  4. * This file is part of PHP CS Fixer.
  5. *
  6. * (c) Fabien Potencier <fabien@symfony.com>
  7. * Dariusz Rumiński <dariusz.ruminski@gmail.com>
  8. *
  9. * This source file is subject to the MIT license that is bundled
  10. * with this source code in the file LICENSE.
  11. */
  12. namespace PhpCsFixer\Tests\Fixer\Comment;
  13. use PhpCsFixer\Tests\Test\AbstractFixerTestCase;
  14. use PhpCsFixer\Tokenizer\Tokens;
  15. /**
  16. * @internal
  17. *
  18. * @covers \PhpCsFixer\Fixer\Comment\NoEmptyCommentFixer
  19. */
  20. final class NoEmptyCommentFixerTest extends AbstractFixerTestCase
  21. {
  22. /**
  23. * @dataProvider provideFixCases
  24. */
  25. public function testFix(string $expected, ?string $input = null): void
  26. {
  27. $this->doTest($expected, $input);
  28. }
  29. public function provideFixCases(): array
  30. {
  31. return [
  32. // fix cases
  33. [
  34. '<?php
  35. echo 0;
  36. echo 1;
  37. ',
  38. '<?php
  39. echo 0;//
  40. echo 1;
  41. ',
  42. ],
  43. [
  44. '<?php
  45. echo 0;
  46. echo 1;
  47. ',
  48. '<?php
  49. echo 0;//
  50. echo 1;
  51. ',
  52. ],
  53. [
  54. '<?php
  55. echo 1;
  56. ',
  57. '<?php
  58. echo 1;//
  59. ',
  60. ],
  61. [
  62. '<?php
  63. echo 2;
  64. '.'
  65. echo 1;
  66. ',
  67. '<?php
  68. echo 2;
  69. //
  70. echo 1;
  71. ',
  72. ],
  73. [
  74. '<?php
  75. ?>',
  76. '<?php
  77. //?>',
  78. ],
  79. [
  80. '<?php
  81. '.'
  82. ',
  83. '<?php
  84. //
  85. ',
  86. ],
  87. [
  88. '<?php
  89. '.'
  90. ',
  91. '<?php
  92. #
  93. ',
  94. ],
  95. [
  96. '<?php
  97. '.'
  98. ',
  99. '<?php
  100. /**/
  101. ',
  102. ],
  103. [
  104. '<?php
  105. echo 0;echo 1;
  106. ',
  107. '<?php
  108. echo 0;/**/echo 1;
  109. ',
  110. ],
  111. [
  112. '<?php
  113. echo 0;echo 1;
  114. ',
  115. '<?php
  116. echo 0;/**//**//**/echo 1/**/;
  117. ',
  118. ],
  119. [
  120. '<?php
  121. ',
  122. '<?php
  123. //',
  124. ],
  125. [
  126. '<?php
  127. ',
  128. '<?php
  129. /*
  130. */',
  131. ],
  132. [
  133. '<?php
  134. '.'
  135. '.'
  136. '.'
  137. '.'
  138. ',
  139. '<?php
  140. //
  141. //
  142. //
  143. /**///
  144. ',
  145. ],
  146. [
  147. "<?php\n \n \n \n \n ",
  148. "<?php\n //\n //\n //\n /**///\n ",
  149. ],
  150. [
  151. "<?php\r \r \r \r \r ",
  152. "<?php\r //\r //\r //\r /**///\r ",
  153. ],
  154. [
  155. "<?php\r\n \r\n \r\n \r\n \r\n ",
  156. "<?php\r\n //\r\n //\r\n //\r\n /**///\r\n ",
  157. ],
  158. [
  159. "<?php\necho 1;\r\recho 2;",
  160. "<?php\necho 1;\r//\recho 2;",
  161. ],
  162. // do not fix cases
  163. [
  164. '<?php
  165. // a
  166. // /**/
  167. // #
  168. /* b */ // s
  169. # c',
  170. ],
  171. [
  172. '<?php
  173. // This comment could be nicely formatted.
  174. //
  175. //
  176. // For that, it could have some empty comment lines inside.
  177. //
  178. ## A 1
  179. ##
  180. ##
  181. ## A 2
  182. ##
  183. // B 1
  184. //
  185. // B 2
  186. ## C 1
  187. ##
  188. ## C 2
  189. $foo = 1;
  190. //
  191. // a
  192. //
  193. $bar = 2;
  194. ',
  195. ],
  196. [
  197. '<?php
  198. '.'
  199. ',
  200. '<?php
  201. /*
  202. *
  203. */
  204. ',
  205. ],
  206. [
  207. '<?php
  208. '.'
  209. ',
  210. '<?php
  211. /********
  212. *
  213. ********/
  214. ',
  215. ],
  216. [
  217. '<?php /* a */',
  218. '<?php /* *//* a *//* */',
  219. ],
  220. [
  221. '<?php
  222. '.'
  223. /* a */
  224. '.'
  225. ',
  226. '<?php
  227. //
  228. /* a */
  229. //
  230. ',
  231. ],
  232. ];
  233. }
  234. /**
  235. * @param string $source valid PHP source code
  236. * @param int $startIndex start index of the comment block
  237. * @param int $endIndex expected index of the last token of the block
  238. * @param bool $isEmpty expected value of empty flag returned
  239. *
  240. * @dataProvider provideCommentBlockCases
  241. */
  242. public function testGetCommentBlock(string $source, int $startIndex, int $endIndex, bool $isEmpty): void
  243. {
  244. Tokens::clearCache();
  245. $tokens = Tokens::fromCode($source);
  246. static::assertTrue($tokens[$startIndex]->isComment(), sprintf('Misconfiguration of test, expected comment token at index "%d".', $startIndex));
  247. $method = new \ReflectionMethod($this->fixer, 'getCommentBlock');
  248. $method->setAccessible(true);
  249. [$foundStart, $foundEnd, $foundIsEmpty] = $method->invoke($this->fixer, $tokens, $startIndex);
  250. static::assertSame($startIndex, $foundStart, 'Find start index of block failed.');
  251. static::assertSame($endIndex, $foundEnd, 'Find end index of block failed.');
  252. static::assertSame($isEmpty, $foundIsEmpty, 'Is empty comment block detection failed.');
  253. }
  254. public function provideCommentBlockCases(): array
  255. {
  256. $cases = [
  257. [
  258. '<?php // a',
  259. 1,
  260. 1,
  261. false,
  262. ],
  263. [
  264. '<?php
  265. // This comment could be nicely formatted.
  266. //
  267. //
  268. // For that, it could have some empty comment lines inside.
  269. // ',
  270. 2,
  271. 11,
  272. false,
  273. ],
  274. [
  275. '<?php
  276. /**///',
  277. 1,
  278. 1,
  279. true,
  280. ],
  281. [
  282. '<?php
  283. //
  284. //
  285. #
  286. #
  287. ',
  288. 5,
  289. 8,
  290. true,
  291. ],
  292. [
  293. '<?php
  294. //
  295. //
  296. //
  297. //
  298. ',
  299. 5,
  300. 8,
  301. true,
  302. ],
  303. [
  304. '<?php
  305. //
  306. //
  307. //
  308. //
  309. ',
  310. 1,
  311. 3,
  312. true,
  313. ],
  314. [
  315. str_replace("\n", "\r", "<?php\n//\n//\n\n//\n//\n"),
  316. 1,
  317. 3,
  318. true,
  319. ],
  320. [
  321. str_replace("\n", "\r\n", "<?php\n//\n//\n\n//\n//\n"),
  322. 1,
  323. 3,
  324. true,
  325. ],
  326. [
  327. '<?php
  328. //
  329. //
  330. ',
  331. 1,
  332. 1,
  333. true,
  334. ],
  335. [
  336. '<?php
  337. //
  338. //
  339. $a; ',
  340. 1,
  341. 4,
  342. true,
  343. ],
  344. [
  345. '<?php
  346. //',
  347. 1,
  348. 1,
  349. true,
  350. ],
  351. ];
  352. $src = '<?php
  353. // a2
  354. // /*4*/
  355. // #6
  356. /* b8 */ // s10
  357. # c12';
  358. foreach ([2, 4, 6] as $i) {
  359. $cases[] = [$src, $i, 7, false];
  360. }
  361. $cases[] = [$src, 8, 8, false];
  362. $cases[] = [$src, 10, 11, false];
  363. $cases[] = [$src, 12, 12, false];
  364. return $cases;
  365. }
  366. }