FopenFlagsFixerTest.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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\FunctionNotation;
  13. use PhpCsFixer\Tests\Test\AbstractFixerTestCase;
  14. /**
  15. * @internal
  16. *
  17. * @covers \PhpCsFixer\AbstractFopenFlagFixer
  18. * @covers \PhpCsFixer\Fixer\FunctionNotation\FopenFlagsFixer
  19. */
  20. final class FopenFlagsFixerTest extends AbstractFixerTestCase
  21. {
  22. /**
  23. * @param array<string, mixed> $config
  24. *
  25. * @dataProvider provideFixCases
  26. */
  27. public function testFix(string $expected, string $input, array $config = []): void
  28. {
  29. $this->fixer->configure($config);
  30. $this->doTest($expected, $input);
  31. }
  32. public static function provideFixCases(): iterable
  33. {
  34. yield 'missing "b"' => [
  35. '<?php
  36. $a = fopen($foo, \'rw+b\');
  37. ',
  38. '<?php
  39. $a = fopen($foo, \'rw+\');
  40. ',
  41. ];
  42. yield 'has "t" and "b"' => [
  43. '<?php
  44. $a = \fopen($foo, "rw+b");
  45. ',
  46. '<?php
  47. $a = \fopen($foo, "rw+bt");
  48. ',
  49. ];
  50. yield 'has "t" and no "b" and binary string mod' => [
  51. '<?php
  52. $a = fopen($foo, b\'rw+b\');
  53. ',
  54. '<?php
  55. $a = fopen($foo, b\'trw+\');
  56. ',
  57. ];
  58. // configure remove b
  59. yield 'missing "b" but not configured' => [
  60. '<?php
  61. $a = fopen($foo, \'rw+\');
  62. ',
  63. '<?php
  64. $a = fopen($foo, \'rw+t\');
  65. ',
  66. ['b_mode' => false],
  67. ];
  68. yield '"t" and superfluous "b"' => [
  69. '<?php
  70. $a = fopen($foo, \'r+\');
  71. $a = fopen($foo, \'w+r\');
  72. $a = fopen($foo, \'r+\');
  73. $a = fopen($foo, \'w+r\');
  74. ',
  75. '<?php
  76. $a = fopen($foo, \'r+bt\');
  77. $a = fopen($foo, \'btw+r\');
  78. $a = fopen($foo, \'r+tb\');
  79. $a = fopen($foo, \'tbw+r\');
  80. ',
  81. ['b_mode' => false],
  82. ];
  83. yield 'superfluous "b"' => [
  84. '<?php
  85. $a = fopen($foo, \'r+\');
  86. $a = fopen($foo, \'w+r\');
  87. ',
  88. '<?php
  89. $a = fopen($foo, \'r+b\');
  90. $a = fopen($foo, \'bw+r\');
  91. ',
  92. ['b_mode' => false],
  93. ];
  94. }
  95. /**
  96. * @dataProvider provideDoNotFixCases
  97. */
  98. public function testDoNotFix(string $expected): void
  99. {
  100. $this->doTest($expected);
  101. $this->fixer->configure(['b_mode' => false]);
  102. $this->doTest($expected);
  103. }
  104. public static function provideDoNotFixCases(): iterable
  105. {
  106. yield 'not simple flags' => [
  107. '<?php $a = fopen($foo, "t".$a);',
  108. ];
  109. yield 'wrong # of arguments' => [
  110. '<?php
  111. $b = fopen("br+");
  112. $c = fopen($foo, "w+", 1, 2 , 3);
  113. ',
  114. ];
  115. yield '"flags" is too long (must be overridden)' => [
  116. '<?php $d = fopen($foo, "r+w+a+x+c+etXY");',
  117. ];
  118. yield '"flags" is too short (must be overridden)' => [
  119. '<?php $d = fopen($foo, "");',
  120. ];
  121. yield 'static method call' => [
  122. '<?php $e = A::fopen($foo, "w+");',
  123. ];
  124. yield 'method call' => [
  125. '<?php $f = $b->fopen($foo, "r+");',
  126. ];
  127. yield 'comments, PHPDoc and literal' => [
  128. '<?php
  129. // fopen($foo, "rw");
  130. /* fopen($foo, "rw"); */
  131. echo("fopen($foo, \"rw\")");
  132. ',
  133. ];
  134. yield 'invalid flag values' => [
  135. '<?php
  136. $a = fopen($foo, \'\');
  137. $a = fopen($foo, \'k\');
  138. $a = fopen($foo, \'kz\');
  139. $a = fopen($foo, \'k+\');
  140. $a = fopen($foo, \'+k\');
  141. $a = fopen($foo, \'xct++\');
  142. $a = fopen($foo, \'w+r+r+\');
  143. $a = fopen($foo, \'+btrw+\');
  144. $a = fopen($foo, \'b+rw\');
  145. $a = fopen($foo, \'bbrw+\');
  146. $a = fopen($foo, \'brw++\');
  147. $a = fopen($foo, \'++brw\');
  148. $a = fopen($foo, \'ybrw+\');
  149. $a = fopen($foo, \'rr\');
  150. $a = fopen($foo, \'ロ\');
  151. $a = fopen($foo, \'ロ+\');
  152. $a = fopen($foo, \'rロ\');
  153. $a = \fopen($foo, \'w+ロ\');
  154. ',
  155. ];
  156. yield [
  157. '<?php
  158. echo "abc"; // to pass the candidate check
  159. $a = fopen($foo, 1);
  160. $a = fopen($foo, $a);
  161. $a = fopen($foo, null);
  162. ',
  163. ];
  164. }
  165. }