CommentToPhpdocFixerTest.php 6.6 KB

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