summaryrefslogtreecommitdiff
path: root/vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php
diff options
context:
space:
mode:
authorFrédéric Guillot <fred@kanboard.net>2017-12-15 11:24:35 -0800
committerFrédéric Guillot <fred@kanboard.net>2017-12-15 11:55:42 -0800
commita93b8e10f5954be0853eec693c13e84c4bd9e6f2 (patch)
treeeda5de9494b819235616e8623bb3393e9cc373af /vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php
parent2c72a283f2d51034f85f4e2ca8b194d304a3c433 (diff)
Kanboard requires at least PHP 5.6 now
Diffstat (limited to 'vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php')
-rw-r--r--vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php73
1 files changed, 72 insertions, 1 deletions
diff --git a/vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php b/vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php
index b8d5ca6d..a1aa8013 100644
--- a/vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php
+++ b/vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php
@@ -11,10 +11,11 @@
namespace Symfony\Component\Console\Tests\Formatter;
+use PHPUnit\Framework\TestCase;
use Symfony\Component\Console\Formatter\OutputFormatter;
use Symfony\Component\Console\Formatter\OutputFormatterStyle;
-class OutputFormatterTest extends \PHPUnit_Framework_TestCase
+class OutputFormatterTest extends TestCase
{
public function testEmptyTag()
{
@@ -27,6 +28,9 @@ class OutputFormatterTest extends \PHPUnit_Framework_TestCase
$formatter = new OutputFormatter(true);
$this->assertEquals('foo<bar', $formatter->format('foo\\<bar'));
+ $this->assertEquals('foo << bar', $formatter->format('foo << bar'));
+ $this->assertEquals('foo << bar \\', $formatter->format('foo << bar \\'));
+ $this->assertEquals("foo << \033[32mbar \\ baz\033[39m \\", $formatter->format('foo << <info>bar \\ baz</info> \\'));
$this->assertEquals('<info>some info</info>', $formatter->format('\\<info>some info\\</info>'));
$this->assertEquals('\\<info>some info\\</info>', OutputFormatter::escape('<info>some info</info>'));
@@ -152,6 +156,67 @@ class OutputFormatterTest extends \PHPUnit_Framework_TestCase
$this->assertEquals("\033[34;41msome text\033[39;49m", $formatter->format('<fg=blue;bg=red>some text</fg=blue;bg=red>'));
}
+ /**
+ * @param string $tag
+ * @param string|null $expected
+ * @param string|null $input
+ *
+ * @dataProvider provideInlineStyleOptionsCases
+ */
+ public function testInlineStyleOptions($tag, $expected = null, $input = null)
+ {
+ $styleString = substr($tag, 1, -1);
+ $formatter = new OutputFormatter(true);
+ $method = new \ReflectionMethod($formatter, 'createStyleFromString');
+ $method->setAccessible(true);
+ $result = $method->invoke($formatter, $styleString);
+ if (null === $expected) {
+ $this->assertFalse($result);
+ $expected = $tag.$input.'</'.$styleString.'>';
+ $this->assertSame($expected, $formatter->format($expected));
+ } else {
+ /* @var OutputFormatterStyle $result */
+ $this->assertInstanceOf(OutputFormatterStyle::class, $result);
+ $this->assertSame($expected, $formatter->format($tag.$input.'</>'));
+ $this->assertSame($expected, $formatter->format($tag.$input.'</'.$styleString.'>'));
+ }
+ }
+
+ public function provideInlineStyleOptionsCases()
+ {
+ return array(
+ array('<unknown=_unknown_>'),
+ array('<unknown=_unknown_;a=1;b>'),
+ array('<fg=green;>', "\033[32m[test]\033[39m", '[test]'),
+ array('<fg=green;bg=blue;>', "\033[32;44ma\033[39;49m", 'a'),
+ array('<fg=green;options=bold>', "\033[32;1mb\033[39;22m", 'b'),
+ array('<fg=green;options=reverse;>', "\033[32;7m<a>\033[39;27m", '<a>'),
+ array('<fg=green;options=bold,underscore>', "\033[32;1;4mz\033[39;22;24m", 'z'),
+ array('<fg=green;options=bold,underscore,reverse;>', "\033[32;1;4;7md\033[39;22;24;27m", 'd'),
+ );
+ }
+
+ /**
+ * @group legacy
+ * @dataProvider provideInlineStyleTagsWithUnknownOptions
+ * @expectedDeprecation Unknown style options are deprecated since version 3.2 and will be removed in 4.0. Exception "Invalid option specified: "%s". Expected one of (bold, underscore, blink, reverse, conceal)".
+ */
+ public function testInlineStyleOptionsUnknownAreDeprecated($tag, $option)
+ {
+ $formatter = new OutputFormatter(true);
+ $formatter->format($tag);
+ }
+
+ public function provideInlineStyleTagsWithUnknownOptions()
+ {
+ return array(
+ array('<options=abc;>', 'abc'),
+ array('<options=abc,def;>', 'abc'),
+ array('<fg=green;options=xyz;>', 'xyz'),
+ array('<fg=green;options=efg,abc>', 'efg'),
+ );
+ }
+
public function testNonStyleTag()
{
$formatter = new OutputFormatter(true);
@@ -195,6 +260,9 @@ class OutputFormatterTest extends \PHPUnit_Framework_TestCase
$this->assertEquals(
'some question', $formatter->format('<question>some question</question>')
);
+ $this->assertEquals(
+ 'some text with inline style', $formatter->format('<fg=red>some text with inline style</>')
+ );
$formatter->setDecorated(true);
@@ -210,6 +278,9 @@ class OutputFormatterTest extends \PHPUnit_Framework_TestCase
$this->assertEquals(
"\033[30;46msome question\033[39;49m", $formatter->format('<question>some question</question>')
);
+ $this->assertEquals(
+ "\033[31msome text with inline style\033[39m", $formatter->format('<fg=red>some text with inline style</>')
+ );
}
public function testContentWithLineBreaks()