CommentToPhpdocFixerTest.php 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366
  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. /**
  15. * @author Kuba Werłos <werlos@gmail.com>
  16. *
  17. * @internal
  18. *
  19. * @covers \PhpCsFixer\Fixer\Comment\CommentToPhpdocFixer
  20. */
  21. final class CommentToPhpdocFixerTest extends AbstractFixerTestCase
  22. {
  23. /**
  24. * @param array<string, mixed> $config
  25. *
  26. * @dataProvider provideFixCases
  27. */
  28. public function testFix(string $expected, ?string $input = null, array $config = []): void
  29. {
  30. $this->fixer->configure($config);
  31. $this->doTest($expected, $input);
  32. }
  33. public static function provideFixCases(): iterable
  34. {
  35. yield [
  36. '<?php /* header comment */ $foo = true; /* string $bar */ $bar = "baz";',
  37. ];
  38. yield [
  39. '<?php /* header comment */ $foo = true; /* $yoda string @var */',
  40. ];
  41. yield [
  42. '<?php /* header comment */ $foo = true; /* $yoda @var string */',
  43. ];
  44. yield [
  45. '<?php /* header comment */ $foo = true; /** @var string $bar */ $bar = "baz";',
  46. '<?php /* header comment */ $foo = true; /* @var string $bar */ $bar = "baz";',
  47. ];
  48. yield [
  49. '<?php /* header comment */ $foo = true; /** @var string $bar */ $bar = "baz";',
  50. '<?php /* header comment */ $foo = true; /*@var string $bar */ $bar = "baz";',
  51. ];
  52. yield [
  53. '<?php /* header comment */ $foo = true;
  54. /** @var string $bar */
  55. $bar = "baz";
  56. ',
  57. '<?php /* header comment */ $foo = true;
  58. /*** @var string $bar */
  59. $bar = "baz";
  60. ',
  61. ];
  62. yield [
  63. '<?php /* header comment */ $foo = true;
  64. /** @var string $bar */
  65. $bar = "baz";
  66. ',
  67. '<?php /* header comment */ $foo = true;
  68. // @var string $bar
  69. $bar = "baz";
  70. ',
  71. ];
  72. yield [
  73. '<?php /* header comment */ $foo = true;
  74. /** @var string $bar */
  75. $bar = "baz";
  76. ',
  77. '<?php /* header comment */ $foo = true;
  78. //@var string $bar
  79. $bar = "baz";
  80. ',
  81. ];
  82. yield [
  83. '<?php /* header comment */ $foo = true;
  84. /** @var string $bar */
  85. $bar = "baz";
  86. ',
  87. '<?php /* header comment */ $foo = true;
  88. # @var string $bar
  89. $bar = "baz";
  90. ',
  91. ];
  92. yield [
  93. '<?php /* header comment */ $foo = true;
  94. /** @var string $bar */
  95. $bar = "baz";
  96. ',
  97. '<?php /* header comment */ $foo = true;
  98. #@var string $bar
  99. $bar = "baz";
  100. ',
  101. ];
  102. yield [
  103. <<<'EOT'
  104. <?php /* header comment */ $foo = true;
  105. /**
  106. * @var string $bar
  107. */
  108. $bar = "baz";
  109. EOT
  110. ,
  111. <<<'EOT'
  112. <?php /* header comment */ $foo = true;
  113. /*
  114. * @var string $bar
  115. */
  116. $bar = "baz";
  117. EOT
  118. ,
  119. ];
  120. yield [
  121. <<<'EOT'
  122. <?php /* header comment */ $foo = true;
  123. /**
  124. * This is my var
  125. * @var string $foo
  126. * stop using it
  127. * @deprecated since 1.2
  128. */
  129. $foo = 1;
  130. EOT
  131. ,
  132. <<<'EOT'
  133. <?php /* header comment */ $foo = true;
  134. // This is my var
  135. // @var string $foo
  136. // stop using it
  137. // @deprecated since 1.2
  138. $foo = 1;
  139. EOT
  140. ,
  141. ];
  142. yield [
  143. <<<'EOT'
  144. <?php /* header comment */ $foo = true;
  145. for (;;) {
  146. /**
  147. * This is my var
  148. * @var string $foo
  149. */
  150. $foo = someValue();
  151. }
  152. EOT
  153. ,
  154. <<<'EOT'
  155. <?php /* header comment */ $foo = true;
  156. for (;;) {
  157. // This is my var
  158. // @var string $foo
  159. $foo = someValue();
  160. }
  161. EOT
  162. ,
  163. ];
  164. yield [
  165. <<<'EOT'
  166. <?php /* header comment */ $foo = true;
  167. /**
  168. * This is my var
  169. * @var string $foo
  170. * stop using it
  171. * @deprecated since 1.3
  172. */
  173. $foo = 1;
  174. EOT
  175. ,
  176. <<<'EOT'
  177. <?php /* header comment */ $foo = true;
  178. # This is my var
  179. # @var string $foo
  180. # stop using it
  181. # @deprecated since 1.3
  182. $foo = 1;
  183. EOT
  184. ,
  185. ];
  186. yield [
  187. <<<'EOT'
  188. <?php /* header comment */ $foo = true;
  189. /**
  190. * @Column(type="string", length=32, unique=true, nullable=false)
  191. */
  192. $bar = 'baz';
  193. EOT
  194. ,
  195. <<<'EOT'
  196. <?php /* header comment */ $foo = true;
  197. /*
  198. * @Column(type="string", length=32, unique=true, nullable=false)
  199. */
  200. $bar = 'baz';
  201. EOT
  202. ,
  203. ];
  204. yield [
  205. <<<'EOT'
  206. <?php /* header comment */ $foo = true;
  207. /**
  208. * @ORM\Column(name="id", type="integer")
  209. */
  210. $bar = 42;
  211. EOT
  212. ,
  213. <<<'EOT'
  214. <?php /* header comment */ $foo = true;
  215. /*
  216. * @ORM\Column(name="id", type="integer")
  217. */
  218. $bar = 42;
  219. EOT
  220. ,
  221. ];
  222. yield [
  223. <<<'EOT'
  224. <?php /* header comment */ $foo = true;
  225. // This is my var
  226. // /** @var string $foo */
  227. $foo = 1;
  228. EOT
  229. ,
  230. ];
  231. yield [
  232. <<<'EOT'
  233. <?php /* header comment */ $foo = true;
  234. // @todo do something later
  235. $foo = 1;
  236. EOT
  237. ,
  238. null,
  239. ['ignored_tags' => ['todo']],
  240. ];
  241. yield [
  242. <<<'EOT'
  243. <?php /* header comment */ $foo = true;
  244. // @TODO do something later
  245. $foo = 1;
  246. EOT
  247. ,
  248. null,
  249. ['ignored_tags' => ['todo']],
  250. ];
  251. yield [
  252. <<<'EOT'
  253. <?php /* header comment */ $foo = true;
  254. /**
  255. * @todo do something later
  256. * @var int $foo
  257. */
  258. $foo = 1;
  259. EOT
  260. ,
  261. <<<'EOT'
  262. <?php /* header comment */ $foo = true;
  263. // @todo do something later
  264. // @var int $foo
  265. $foo = 1;
  266. EOT
  267. ,
  268. ['ignored_tags' => ['todo']],
  269. ];
  270. yield [
  271. <<<'EOT'
  272. <?php /* header comment */ $foo = true;
  273. /**
  274. * @var int $foo
  275. * @todo do something later
  276. */
  277. $foo = 1;
  278. EOT
  279. ,
  280. <<<'EOT'
  281. <?php /* header comment */ $foo = true;
  282. // @var int $foo
  283. // @todo do something later
  284. $foo = 1;
  285. EOT
  286. ,
  287. ['ignored_tags' => ['todo']],
  288. ];
  289. yield [
  290. '<?php // header
  291. /** /@foo */
  292. namespace Foo\Bar;
  293. ',
  294. '<?php // header
  295. ///@foo
  296. namespace Foo\Bar;
  297. ',
  298. ];
  299. yield [
  300. '<?php // header
  301. /**
  302. * / @foo
  303. * / @bar
  304. */
  305. namespace Foo\Bar;
  306. ',
  307. '<?php // header
  308. /// @foo
  309. /// @bar
  310. namespace Foo\Bar;
  311. ',
  312. ];
  313. yield [
  314. '<?php /* header comment */ $foo = true; class Foo { /** @phpstan-use Bar<Baz> $bar */ use Bar; }',
  315. '<?php /* header comment */ $foo = true; class Foo { /* @phpstan-use Bar<Baz> $bar */ use Bar; }',
  316. ];
  317. }
  318. }