TagTest.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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\DocBlock;
  13. use PhpCsFixer\DocBlock\Line;
  14. use PhpCsFixer\DocBlock\Tag;
  15. use PhpCsFixer\Tests\TestCase;
  16. /**
  17. * @author Graham Campbell <hello@gjcampbell.co.uk>
  18. *
  19. * @internal
  20. *
  21. * @covers \PhpCsFixer\DocBlock\Tag
  22. */
  23. final class TagTest extends TestCase
  24. {
  25. /**
  26. * @dataProvider provideNameCases
  27. */
  28. public function testName(string $expected, string $new, string $input): void
  29. {
  30. $tag = new Tag(new Line($input));
  31. self::assertSame($expected, $tag->getName());
  32. if ('other' === $expected) {
  33. $this->expectException(\RuntimeException::class);
  34. $this->expectExceptionMessage('Cannot set name on unknown tag');
  35. }
  36. $tag->setName($new);
  37. self::assertSame($new, $tag->getName());
  38. }
  39. public static function provideNameCases(): iterable
  40. {
  41. yield ['param', 'var', ' * @param Foo $foo'];
  42. yield ['return', 'type', '* @return false'];
  43. yield ['thRoWs', 'throws', '*@thRoWs \Exception'];
  44. yield ['THROWSSS', 'throws', "\t@THROWSSS\t \t RUNTIMEEEEeXCEPTION\t\t\t\t\t\t\t\n\n\n"];
  45. yield ['other', 'foobar', ' * @\Foo\Bar(baz = 123)'];
  46. yield ['expectedException', 'baz', ' * @expectedException Exception'];
  47. yield ['property-read', 'property-write', ' * @property-read integer $daysInMonth number of days in the given month'];
  48. yield ['method', 'foo', ' * @method'];
  49. yield ['method', 'hi', ' * @method string getString()'];
  50. yield ['other', 'hello', ' * @method("GET")'];
  51. }
  52. /**
  53. * @dataProvider provideValidCases
  54. */
  55. public function testValid(bool $expected, string $input): void
  56. {
  57. $tag = new Tag(new Line($input));
  58. self::assertSame($expected, $tag->valid());
  59. }
  60. public static function provideValidCases(): iterable
  61. {
  62. yield [true, ' * @param Foo $foo'];
  63. yield [true, '* @return false'];
  64. yield [true, '*@throws \Exception'];
  65. yield [true, ' * @method'];
  66. yield [true, ' * @method string getString()'];
  67. yield [true, ' * @property-read integer $daysInMonth number of days in the given month'];
  68. yield [false, ' * @method("GET")'];
  69. yield [false, '*@thRoWs \InvalidArgumentException'];
  70. yield [false, "\t@THROWSSS\t \t RUNTIMEEEEeXCEPTION\t\t\t\t\t\t\t\n\n\n"];
  71. yield [false, ' * @\Foo\Bar(baz = 123)'];
  72. yield [false, ' * @expectedException Exception'];
  73. }
  74. }