123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600 |
- <?php
- /*
- * This file is part of PHP CS Fixer.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- * Dariusz Rumiński <dariusz.ruminski@gmail.com>
- *
- * This source file is subject to the MIT license that is bundled
- * with this source code in the file LICENSE.
- */
- namespace PhpCsFixer\Tests\Fixer\PhpUnit;
- use PhpCsFixer\Fixer\PhpUnit\PhpUnitTargetVersion;
- use PhpCsFixer\Tests\Test\AbstractFixerTestCase;
- /**
- * @author SpacePossum
- *
- * @internal
- *
- * @covers \PhpCsFixer\Fixer\PhpUnit\PhpUnitDedicateAssertFixer
- */
- final class PhpUnitDedicateAssertFixerTest extends AbstractFixerTestCase
- {
- /**
- * @param string $expected
- * @param null|string $input
- *
- * @dataProvider provideTestFixCases
- */
- public function testFix($expected, $input = null, array $config = [])
- {
- $this->fixer->configure($config);
- $this->doTest($expected, $input);
- }
- /**
- * @param string $expected
- * @param null|string $input
- *
- * @dataProvider provideTestFixLegacyCases
- * @group legacy
- * @expectedDeprecation Option "functions" for rule "php_unit_dedicate_assert" is deprecated and will be removed in version 3.0. Use option "target" instead.
- */
- public function testFixLegacy($expected, $input = null)
- {
- $defaultFunctions = [
- 'array_key_exists',
- 'empty',
- 'file_exists',
- 'is_array',
- 'is_bool',
- 'is_callable',
- 'is_double',
- 'is_float',
- 'is_infinite',
- 'is_int',
- 'is_integer',
- 'is_long',
- 'is_nan',
- 'is_null',
- 'is_numeric',
- 'is_object',
- 'is_real',
- 'is_resource',
- 'is_scalar',
- 'is_string',
- ];
- $this->fixer->configure(['functions' => $defaultFunctions]);
- $this->doTest($expected, $input);
- }
- public function provideTestFixCases()
- {
- $cases = [
- [
- self::generateTest('
- $this->assertNan($a);
- $this->assertNan($a);
- $this->assertTrue(test\is_nan($a));
- $this->assertTrue(test\a\is_nan($a));
- '),
- self::generateTest('
- $this->assertTrue(is_nan($a));
- $this->assertTrue(\is_nan($a));
- $this->assertTrue(test\is_nan($a));
- $this->assertTrue(test\a\is_nan($a));
- '),
- ],
- [
- self::generateTest('
- $this->assertFileExists($a);
- $this->assertFileNotExists($a);
- $this->assertFileExists($a);
- $this->assertFileNotExists($a);
- '),
- self::generateTest('
- $this->assertTrue(file_exists($a));
- $this->assertFalse(file_exists($a));
- $this->assertTrue(\file_exists($a));
- $this->assertFalse(\file_exists($a));
- '),
- ],
- [
- self::generateTest('
- $this->assertNull($a);
- $this->assertNotNull($a);
- $this->assertNull($a);
- $this->assertNotNull($a, "my message");
- '),
- self::generateTest('
- $this->assertTrue(is_null($a));
- $this->assertFalse(is_null($a));
- $this->assertTrue(\is_null($a));
- $this->assertFalse(\is_null($a), "my message");
- '),
- ],
- [
- self::generateTest('
- $this->assertEmpty($a);
- $this->assertNotEmpty($a);
- '),
- self::generateTest('
- $this->assertTrue(empty($a));
- $this->ASSERTFALSE(empty($a));
- '),
- ],
- [
- self::generateTest('
- $this->assertInfinite($a);
- $this->assertFinite($a, "my message");
- $this->assertInfinite($a);
- $this->assertFinite($a, "my message");
- '),
- self::generateTest('
- $this->assertTrue(is_infinite($a));
- $this->assertFalse(is_infinite($a), "my message");
- $this->assertTrue(\is_infinite($a));
- $this->assertFalse(\is_infinite($a), "my message");
- '),
- ],
- [
- self::generateTest('
- $this->assertArrayHasKey("test", $a);
- $this->assertArrayNotHasKey($b, $a, $c);
- '),
- self::generateTest('
- $this->assertTrue(\array_key_exists("test", $a));
- $this->ASSERTFALSE(array_key_exists($b, $a), $c);
- '),
- ],
- [
- self::generateTest('
- $this->assertTrue(is_dir($a));
- $this->assertTrue(is_writable($a));
- $this->assertTrue(is_readable($a));
- '),
- null,
- ],
- [
- self::generateTest('
- $this->assertTrue(is_dir($a));
- $this->assertTrue(is_writable($a));
- $this->assertTrue(is_readable($a));
- '),
- null,
- ['target' => PhpUnitTargetVersion::VERSION_3_0],
- ],
- [
- self::generateTest('
- $this->assertDirectoryNotExists($a);
- $this->assertNotIsWritable($a);
- $this->assertNotIsReadable($a);
- '),
- self::generateTest('
- $this->assertFalse(is_dir($a));
- $this->assertFalse(is_writable($a));
- $this->assertFalse(is_readable($a));
- '),
- ['target' => PhpUnitTargetVersion::VERSION_5_6],
- ],
- [
- self::generateTest('
- $this->assertDirectoryExists($a);
- $this->assertIsWritable($a);
- $this->assertIsReadable($a);
- '),
- self::generateTest('
- $this->assertTrue(is_dir($a));
- $this->assertTrue(is_writable($a));
- $this->assertTrue(is_readable($a));
- '),
- ['target' => PhpUnitTargetVersion::VERSION_NEWEST],
- ],
- ];
- foreach (['array', 'bool', 'callable', 'double', 'float', 'int', 'integer', 'long', 'numeric', 'object', 'resource', 'real', 'scalar', 'string'] as $type) {
- $cases[] = [
- self::generateTest(sprintf('$this->assertInternalType(\'%s\', $a);', $type)),
- self::generateTest(sprintf('$this->assertTrue(is_%s($a));', $type)),
- ];
- $cases[] = [
- self::generateTest(sprintf('$this->assertNotInternalType(\'%s\', $a);', $type)),
- self::generateTest(sprintf('$this->assertFalse(is_%s($a));', $type)),
- ];
- }
- $cases[] = [
- self::generateTest('$this->assertInternalType(\'float\', $a, "my message");'),
- self::generateTest('$this->assertTrue(is_float( $a), "my message");'),
- ];
- $cases[] = [
- self::generateTest('$this->assertInternalType(\'float\', $a);'),
- self::generateTest('$this->assertTrue(\IS_FLOAT($a));'),
- ];
- $cases[] = [
- self::generateTest('$this->assertInternalType(#
- \'float\'#
- , #
- $a#
- #
- )#
- ;'),
- self::generateTest('$this->assertTrue(#
- \IS_FLOAT#
- (#
- $a#
- )#
- )#
- ;'),
- ];
- $cases[] = [
- self::generateTest('static::assertInternalType(\'float\', $a);'),
- self::generateTest('static::assertTrue(is_float( $a));'),
- ];
- $cases[] = [
- self::generateTest('self::assertInternalType(\'float\', $a);'),
- self::generateTest('self::assertTrue(is_float( $a));'),
- ];
- $cases[] = [
- self::generateTest('static::assertNull($a);'),
- self::generateTest('static::assertTrue(is_null($a));'),
- ];
- $cases[] = [
- self::generateTest('self::assertNull($a);'),
- self::generateTest('self::assertTrue(is_null($a));'),
- ];
- $cases[] = [
- self::generateTest('SELF::assertNull($a);'),
- self::generateTest('SELF::assertTrue(is_null($a));'),
- ];
- return $cases;
- }
- public function provideTestFixLegacyCases()
- {
- return array_filter($this->provideTestFixCases(), static function (array $case) { return !isset($case[2]); });
- }
- /**
- * @param string $expected
- *
- * @dataProvider provideNotFixCases
- */
- public function testNotFix($expected)
- {
- $this->doTest($expected);
- }
- public function provideNotFixCases()
- {
- return [
- [
- self::generateTest('echo $this->assertTrue;'),
- ],
- [
- self::generateTest('
- $this->assertTrue(is_null);
- $this->assertTrue(is_int($a) && $b);
- $this->assertFalse(is_nan($a));
- $this->assertTrue(is_int($a) || \is_bool($b));
- $this->assertTrue($a&&is_int($a));
- static::assertTrue(is_null);
- self::assertTrue(is_null);
- '),
- ],
- 'not in class' => [
- '<?php self::assertTrue(is_null($a));',
- ],
- ];
- }
- /**
- * @group legacy
- * @expectedDeprecation Passing "functions" at the root of the configuration for rule "php_unit_dedicate_assert" is deprecated and will not be supported in 3.0, use "functions" => array(...) option instead.
- */
- public function testLegacyConfig()
- {
- $this->fixer->configure(['file_exists']);
- $this->doTest(
- self::generateTest('
- $this->assertFileExists($a);
- $this->assertTrue(is_infinite($a));
- '),
- self::generateTest('
- $this->assertTrue(file_exists($a));
- $this->assertTrue(is_infinite($a));
- ')
- );
- }
- /**
- * @group legacy
- * @expectedDeprecation Option "functions" for rule "php_unit_dedicate_assert" is deprecated and will be removed in version 3.0. Use option "target" instead.
- */
- public function testConfig()
- {
- $this->fixer->configure(['functions' => ['file_exists']]);
- $this->doTest(
- self::generateTest('
- $this->assertFileExists($a);
- $this->assertTrue(is_infinite($a));
- '),
- self::generateTest('
- $this->assertTrue(file_exists($a));
- $this->assertTrue(is_infinite($a));
- ')
- );
- }
- public function testInvalidConfig()
- {
- $this->expectException(\PhpCsFixer\ConfigurationException\InvalidFixerConfigurationException::class);
- $this->expectExceptionMessageMatches('/^\[php_unit_dedicate_assert\] Invalid configuration: The option "target" .*\.$/');
- $this->fixer->configure(['target' => '_unknown_']);
- }
- /**
- * @param string $expected
- * @param null|string $input
- *
- * @dataProvider provideTestAssertCountCases
- */
- public function testAssertCount($expected, $input = null)
- {
- if (null === $input) {
- $expected = sprintf($expected, 'count');
- } else {
- $input = sprintf($input, 'count');
- }
- $this->doTest($expected, $input);
- }
- /**
- * @param string $expected
- * @param null|string $input
- *
- * @dataProvider provideTestAssertCountCases
- */
- public function testAssertCountFromSizeOf($expected, $input = null)
- {
- if (null === $input) {
- $expected = sprintf($expected, 'sizeof');
- } else {
- $input = sprintf($input, 'sizeof');
- }
- $this->doTest($expected, $input);
- }
- public function provideTestAssertCountCases()
- {
- return [
- // positive fixing
- 'assert same' => [
- self::generateTest('$this->assertCount(1, $a);'),
- self::generateTest('$this->assertSame(1, %s($a));'),
- ],
- 'assert equals' => [
- self::generateTest('$this->assertCount(2, $b);'),
- self::generateTest('$this->assertEquals(2, %s($b));'),
- ],
- // negative fixing
- 'assert not same' => [
- self::generateTest('$this->assertNotCount(11, $c);'),
- self::generateTest('$this->assertNotSame(11, %s($c));'),
- ],
- 'assert not equals' => [
- self::generateTest('$this->assertNotCount(122, $d);'),
- self::generateTest('$this->assertNotEquals(122, %s($d));'),
- ],
- // other cases
- 'assert same with namespace' => [
- self::generateTest('$this->assertCount(1, $a);'),
- self::generateTest('$this->assertSame(1, \%s($a));'),
- ],
- 'no spacing' => [
- self::generateTest('$this->assertCount(1,$a);'),
- self::generateTest('$this->assertSame(1,%s($a));'),
- ],
- 'lot of spacing' => [
- self::generateTest('$this->assertCount(
- 1
- ,
- '.'
- '.'
- $a
- '.'
- )
- ;'),
- self::generateTest('$this->assertSame(
- 1
- ,
- %s
- (
- $a
- )
- )
- ;'),
- ],
- 'lot of fix cases' => [
- self::generateTest('
- $this->assertCount(1, $a);
- $this->assertCount(2, $a);
- $this->assertCount(3, $a);
- $this->assertNotCount(4, $a);
- $this->assertCount(5, $a, "abc");
- $this->assertCount(6, $a, "def");
- '),
- self::generateTest('
- $this->assertSame(1, %1$s($a));
- $this->assertSame(2, %1$s($a));
- $this->assertEquals(3, %1$s($a));
- $this->assertNotSame(4, %1$s($a));
- $this->assertEquals(5, %1$s($a), "abc");
- $this->assertSame(6, \%1$s($a), "def");
- '),
- ],
- 'comment handling' => [
- self::generateTest('$this->assertCount(# 0
- 1# 1
- ,# 2
- # 3
- # 4
- $a# 5
- # 6
- )# 7
- ;# 8'),
- self::generateTest('$this->assertSame(# 0
- 1# 1
- ,# 2
- %s# 3
- (# 4
- $a# 5
- )# 6
- )# 7
- ;# 8'),
- ],
- 'do not fix 1' => [
- self::generateTest('$this->assertSame($b, %s($a));'),
- ],
- 'do not fix 2' => [
- self::generateTest('$this->assertSame(b(), %s($a));'),
- ],
- 'do not fix 3' => [
- self::generateTest('$this->assertSame(1.0, %s($a));'),
- ],
- 'do not fix 4' => [
- self::generateTest('$this->assertSame(1);'),
- ],
- 'do not fix 5' => [
- self::generateTest('$this->assertSame(1, "%s");'),
- ],
- 'do not fix 6' => [
- self::generateTest('$this->test(); // $this->assertSame($b, %s($a));'),
- ],
- 'do not fix 7' => [
- self::generateTest('$this->assertSame(2, count($array) - 1);'),
- ],
- 'do not fix 8' => [
- self::generateTest('
- Foo::assertSame(1, sizeof($a));
- $this->assertSame(1, sizeof2(2));
- $this->assertSame(1, sizeof::foo);
- '),
- ],
- ];
- }
- /**
- * @param string $expected
- * @param string $input
- *
- * @dataProvider provideTestAssertCountCasingCases
- */
- public function testAssertCountCasing($expected, $input)
- {
- $expected = sprintf($expected, 'count');
- $input = sprintf($input, 'COUNT');
- $this->doTest($expected, $input);
- }
- /**
- * @param string $expected
- * @param string $input
- *
- * @dataProvider provideTestAssertCountCasingCases
- */
- public function testAssertCountFromSizeOfCasing($expected, $input)
- {
- $expected = sprintf($expected, 'sizeof');
- $input = sprintf($input, 'SIZEOF');
- $this->doTest($expected, $input);
- }
- public function provideTestAssertCountCasingCases()
- {
- return [
- [
- self::generateTest('$this->assertCount(1, $a);'),
- self::generateTest('$this->assertSame(1, %s($a));'),
- ],
- [
- self::generateTest('$this->assertCount(1, $a);'),
- self::generateTest('$this->assertSame(1, \%s($a));'),
- ],
- ];
- }
- /**
- * @param string $expected
- * @param string $input
- *
- * @requires PHP 7.3
- * @dataProvider provideFix73Cases
- */
- public function testFix73($expected, $input)
- {
- $this->doTest($expected, $input);
- }
- public function provideFix73Cases()
- {
- return [
- [
- self::generateTest('$this->assertNan($a, );'),
- self::generateTest('$this->assertTrue(is_nan($a), );'),
- ],
- [
- self::generateTest('$this->assertNan($a);'),
- self::generateTest('$this->assertTrue(is_nan($a, ));'),
- ],
- [
- self::generateTest('$this->assertNan($a, );'),
- self::generateTest('$this->assertTrue(is_nan($a, ), );'),
- ],
- [
- self::generateTest('$this->assertInternalType(\'array\', $a,);'),
- self::generateTest('$this->assertTrue(is_array($a,),);'),
- ],
- [
- self::generateTest('$this->assertNan($b);'),
- self::generateTest('$this->assertTrue(\is_nan($b,));'),
- ],
- [
- self::generateTest('$this->assertFileExists($f, \'message\',);'),
- self::generateTest('$this->assertTrue(file_exists($f,), \'message\',);'),
- ],
- [
- self::generateTest('$this->assertNan($y , );'),
- self::generateTest('$this->assertTrue(is_nan($y) , );'),
- ],
- ];
- }
- /**
- * @param string $content
- *
- * @return string
- */
- private static function generateTest($content)
- {
- return "<?php final class FooTest extends \\PHPUnit_Framework_TestCase {\n public function testSomething() {\n ".$content."\n }\n}\n";
- }
- }
|