updated packages
This commit is contained in:
@@ -40,7 +40,7 @@ class FormatterHelperTest extends TestCase
|
||||
$this->assertEquals(
|
||||
'<error> Some text to display </error>'."\n".
|
||||
'<error> foo bar </error>',
|
||||
$formatter->formatBlock(array('Some text to display', 'foo bar'), 'error'),
|
||||
$formatter->formatBlock(['Some text to display', 'foo bar'], 'error'),
|
||||
'::formatBlock() formats a message in a block'
|
||||
);
|
||||
|
||||
|
||||
@@ -20,7 +20,7 @@ class HelperSetTest extends TestCase
|
||||
public function testConstructor()
|
||||
{
|
||||
$mock_helper = $this->getGenericMockHelper('fake_helper');
|
||||
$helperset = new HelperSet(array('fake_helper_alias' => $mock_helper));
|
||||
$helperset = new HelperSet(['fake_helper_alias' => $mock_helper]);
|
||||
|
||||
$this->assertEquals($mock_helper, $helperset->get('fake_helper_alias'), '__construct sets given helper to helpers');
|
||||
$this->assertTrue($helperset->has('fake_helper_alias'), '__construct sets helper alias for given helper');
|
||||
@@ -46,7 +46,7 @@ class HelperSetTest extends TestCase
|
||||
|
||||
public function testHas()
|
||||
{
|
||||
$helperset = new HelperSet(array('fake_helper_alias' => $this->getGenericMockHelper('fake_helper')));
|
||||
$helperset = new HelperSet(['fake_helper_alias' => $this->getGenericMockHelper('fake_helper')]);
|
||||
$this->assertTrue($helperset->has('fake_helper'), '->has() finds set helper');
|
||||
$this->assertTrue($helperset->has('fake_helper_alias'), '->has() finds set helper by alias');
|
||||
}
|
||||
@@ -55,7 +55,7 @@ class HelperSetTest extends TestCase
|
||||
{
|
||||
$helper_01 = $this->getGenericMockHelper('fake_helper_01');
|
||||
$helper_02 = $this->getGenericMockHelper('fake_helper_02');
|
||||
$helperset = new HelperSet(array('fake_helper_01_alias' => $helper_01, 'fake_helper_02_alias' => $helper_02));
|
||||
$helperset = new HelperSet(['fake_helper_01_alias' => $helper_01, 'fake_helper_02_alias' => $helper_02]);
|
||||
$this->assertEquals($helper_01, $helperset->get('fake_helper_01'), '->get() returns correct helper by name');
|
||||
$this->assertEquals($helper_01, $helperset->get('fake_helper_01_alias'), '->get() returns correct helper by alias');
|
||||
$this->assertEquals($helper_02, $helperset->get('fake_helper_02'), '->get() returns correct helper by name');
|
||||
@@ -101,7 +101,7 @@ class HelperSetTest extends TestCase
|
||||
$helperset->set($this->getGenericMockHelper('fake_helper_01', $helperset));
|
||||
$helperset->set($this->getGenericMockHelper('fake_helper_02', $helperset));
|
||||
|
||||
$helpers = array('fake_helper_01', 'fake_helper_02');
|
||||
$helpers = ['fake_helper_01', 'fake_helper_02'];
|
||||
$i = 0;
|
||||
|
||||
foreach ($helperset as $helper) {
|
||||
|
||||
@@ -18,28 +18,28 @@ class HelperTest extends TestCase
|
||||
{
|
||||
public function formatTimeProvider()
|
||||
{
|
||||
return array(
|
||||
array(0, '< 1 sec'),
|
||||
array(1, '1 sec'),
|
||||
array(2, '2 secs'),
|
||||
array(59, '59 secs'),
|
||||
array(60, '1 min'),
|
||||
array(61, '1 min'),
|
||||
array(119, '1 min'),
|
||||
array(120, '2 mins'),
|
||||
array(121, '2 mins'),
|
||||
array(3599, '59 mins'),
|
||||
array(3600, '1 hr'),
|
||||
array(7199, '1 hr'),
|
||||
array(7200, '2 hrs'),
|
||||
array(7201, '2 hrs'),
|
||||
array(86399, '23 hrs'),
|
||||
array(86400, '1 day'),
|
||||
array(86401, '1 day'),
|
||||
array(172799, '1 day'),
|
||||
array(172800, '2 days'),
|
||||
array(172801, '2 days'),
|
||||
);
|
||||
return [
|
||||
[0, '< 1 sec'],
|
||||
[1, '1 sec'],
|
||||
[2, '2 secs'],
|
||||
[59, '59 secs'],
|
||||
[60, '1 min'],
|
||||
[61, '1 min'],
|
||||
[119, '1 min'],
|
||||
[120, '2 mins'],
|
||||
[121, '2 mins'],
|
||||
[3599, '59 mins'],
|
||||
[3600, '1 hr'],
|
||||
[7199, '1 hr'],
|
||||
[7200, '2 hrs'],
|
||||
[7201, '2 hrs'],
|
||||
[86399, '23 hrs'],
|
||||
[86400, '1 day'],
|
||||
[86401, '1 day'],
|
||||
[172799, '1 day'],
|
||||
[172800, '2 days'],
|
||||
[172801, '2 days'],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -30,7 +30,7 @@ class ProcessHelperTest extends TestCase
|
||||
}
|
||||
|
||||
$helper = new ProcessHelper();
|
||||
$helper->setHelperSet(new HelperSet(array(new DebugFormatterHelper())));
|
||||
$helper->setHelperSet(new HelperSet([new DebugFormatterHelper()]));
|
||||
$output = $this->getOutputStream($verbosity);
|
||||
$helper->run($output, $cmd, $error);
|
||||
$this->assertEquals($expected, $this->getOutput($output));
|
||||
@@ -39,13 +39,13 @@ class ProcessHelperTest extends TestCase
|
||||
public function testPassedCallbackIsExecuted()
|
||||
{
|
||||
$helper = new ProcessHelper();
|
||||
$helper->setHelperSet(new HelperSet(array(new DebugFormatterHelper())));
|
||||
$helper->setHelperSet(new HelperSet([new DebugFormatterHelper()]));
|
||||
$output = $this->getOutputStream(StreamOutput::VERBOSITY_NORMAL);
|
||||
|
||||
$executed = false;
|
||||
$callback = function () use (&$executed) { $executed = true; };
|
||||
|
||||
$helper->run($output, array('php', '-r', 'echo 42;'), null, $callback);
|
||||
$helper->run($output, ['php', '-r', 'echo 42;'], null, $callback);
|
||||
$this->assertTrue($executed);
|
||||
}
|
||||
|
||||
@@ -96,27 +96,27 @@ EOT;
|
||||
EOT;
|
||||
|
||||
$errorMessage = 'An error occurred';
|
||||
$args = new Process(array('php', '-r', 'echo 42;'));
|
||||
$args = new Process(['php', '-r', 'echo 42;']);
|
||||
$args = $args->getCommandLine();
|
||||
$successOutputProcessDebug = str_replace("'php' '-r' 'echo 42;'", $args, $successOutputProcessDebug);
|
||||
$fromShellCommandline = \method_exists(Process::class, 'fromShellCommandline') ? array(Process::class, 'fromShellCommandline') : function ($cmd) { return new Process($cmd); };
|
||||
$fromShellCommandline = \method_exists(Process::class, 'fromShellCommandline') ? [Process::class, 'fromShellCommandline'] : function ($cmd) { return new Process($cmd); };
|
||||
|
||||
return array(
|
||||
array('', 'php -r "echo 42;"', StreamOutput::VERBOSITY_VERBOSE, null),
|
||||
array($successOutputVerbose, 'php -r "echo 42;"', StreamOutput::VERBOSITY_VERY_VERBOSE, null),
|
||||
array($successOutputDebug, 'php -r "echo 42;"', StreamOutput::VERBOSITY_DEBUG, null),
|
||||
array($successOutputDebugWithTags, 'php -r "echo \'<info>42</info>\';"', StreamOutput::VERBOSITY_DEBUG, null),
|
||||
array('', 'php -r "syntax error"', StreamOutput::VERBOSITY_VERBOSE, null),
|
||||
array($syntaxErrorOutputVerbose, 'php -r "fwrite(STDERR, \'error message\');usleep(50000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_VERY_VERBOSE, null),
|
||||
array($syntaxErrorOutputDebug, 'php -r "fwrite(STDERR, \'error message\');usleep(500000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_DEBUG, null),
|
||||
array($errorMessage.PHP_EOL, 'php -r "fwrite(STDERR, \'error message\');usleep(50000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_VERBOSE, $errorMessage),
|
||||
array($syntaxErrorOutputVerbose.$errorMessage.PHP_EOL, 'php -r "fwrite(STDERR, \'error message\');usleep(50000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_VERY_VERBOSE, $errorMessage),
|
||||
array($syntaxErrorOutputDebug.$errorMessage.PHP_EOL, 'php -r "fwrite(STDERR, \'error message\');usleep(500000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_DEBUG, $errorMessage),
|
||||
array($successOutputProcessDebug, array('php', '-r', 'echo 42;'), StreamOutput::VERBOSITY_DEBUG, null),
|
||||
array($successOutputDebug, $fromShellCommandline('php -r "echo 42;"'), StreamOutput::VERBOSITY_DEBUG, null),
|
||||
array($successOutputProcessDebug, array(new Process(array('php', '-r', 'echo 42;'))), StreamOutput::VERBOSITY_DEBUG, null),
|
||||
array($successOutputPhp, array($fromShellCommandline('php -r '.$PHP), 'PHP' => 'echo 42;'), StreamOutput::VERBOSITY_DEBUG, null),
|
||||
);
|
||||
return [
|
||||
['', 'php -r "echo 42;"', StreamOutput::VERBOSITY_VERBOSE, null],
|
||||
[$successOutputVerbose, 'php -r "echo 42;"', StreamOutput::VERBOSITY_VERY_VERBOSE, null],
|
||||
[$successOutputDebug, 'php -r "echo 42;"', StreamOutput::VERBOSITY_DEBUG, null],
|
||||
[$successOutputDebugWithTags, 'php -r "echo \'<info>42</info>\';"', StreamOutput::VERBOSITY_DEBUG, null],
|
||||
['', 'php -r "syntax error"', StreamOutput::VERBOSITY_VERBOSE, null],
|
||||
[$syntaxErrorOutputVerbose, 'php -r "fwrite(STDERR, \'error message\');usleep(50000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_VERY_VERBOSE, null],
|
||||
[$syntaxErrorOutputDebug, 'php -r "fwrite(STDERR, \'error message\');usleep(500000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_DEBUG, null],
|
||||
[$errorMessage.PHP_EOL, 'php -r "fwrite(STDERR, \'error message\');usleep(50000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_VERBOSE, $errorMessage],
|
||||
[$syntaxErrorOutputVerbose.$errorMessage.PHP_EOL, 'php -r "fwrite(STDERR, \'error message\');usleep(50000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_VERY_VERBOSE, $errorMessage],
|
||||
[$syntaxErrorOutputDebug.$errorMessage.PHP_EOL, 'php -r "fwrite(STDERR, \'error message\');usleep(500000);fwrite(STDOUT, \'out message\');exit(252);"', StreamOutput::VERBOSITY_DEBUG, $errorMessage],
|
||||
[$successOutputProcessDebug, ['php', '-r', 'echo 42;'], StreamOutput::VERBOSITY_DEBUG, null],
|
||||
[$successOutputDebug, $fromShellCommandline('php -r "echo 42;"'), StreamOutput::VERBOSITY_DEBUG, null],
|
||||
[$successOutputProcessDebug, [new Process(['php', '-r', 'echo 42;'])], StreamOutput::VERBOSITY_DEBUG, null],
|
||||
[$successOutputPhp, [$fromShellCommandline('php -r '.$PHP), 'PHP' => 'echo 42;'], StreamOutput::VERBOSITY_DEBUG, null],
|
||||
];
|
||||
}
|
||||
|
||||
private function getOutputStream($verbosity)
|
||||
|
||||
@@ -23,6 +23,19 @@ use Symfony\Component\Console\Output\StreamOutput;
|
||||
*/
|
||||
class ProgressBarTest extends TestCase
|
||||
{
|
||||
private $colSize;
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
$this->colSize = getenv('COLUMNS');
|
||||
putenv('COLUMNS=120');
|
||||
}
|
||||
|
||||
protected function tearDown()
|
||||
{
|
||||
putenv($this->colSize ? 'COLUMNS='.$this->colSize : 'COLUMNS');
|
||||
}
|
||||
|
||||
public function testMultipleStart()
|
||||
{
|
||||
$bar = new ProgressBar($output = $this->getOutputStream());
|
||||
@@ -314,7 +327,7 @@ class ProgressBarTest extends TestCase
|
||||
|
||||
public function testOverwriteWithSectionOutput()
|
||||
{
|
||||
$sections = array();
|
||||
$sections = [];
|
||||
$stream = $this->getOutputStream(true);
|
||||
$output = new ConsoleSectionOutput($stream->getStream(), $sections, $stream->getVerbosity(), $stream->isDecorated(), new OutputFormatter());
|
||||
|
||||
@@ -336,7 +349,7 @@ class ProgressBarTest extends TestCase
|
||||
|
||||
public function testOverwriteMultipleProgressBarsWithSectionOutputs()
|
||||
{
|
||||
$sections = array();
|
||||
$sections = [];
|
||||
$stream = $this->getOutputStream(true);
|
||||
$output1 = new ConsoleSectionOutput($stream->getStream(), $sections, $stream->getVerbosity(), $stream->isDecorated(), new OutputFormatter());
|
||||
$output2 = new ConsoleSectionOutput($stream->getStream(), $sections, $stream->getVerbosity(), $stream->isDecorated(), new OutputFormatter());
|
||||
@@ -365,7 +378,7 @@ class ProgressBarTest extends TestCase
|
||||
|
||||
public function testMultipleSectionsWithCustomFormat()
|
||||
{
|
||||
$sections = array();
|
||||
$sections = [];
|
||||
$stream = $this->getOutputStream(true);
|
||||
$output1 = new ConsoleSectionOutput($stream->getStream(), $sections, $stream->getVerbosity(), $stream->isDecorated(), new OutputFormatter());
|
||||
$output2 = new ConsoleSectionOutput($stream->getStream(), $sections, $stream->getVerbosity(), $stream->isDecorated(), new OutputFormatter());
|
||||
@@ -859,12 +872,12 @@ class ProgressBarTest extends TestCase
|
||||
*/
|
||||
public function provideFormat()
|
||||
{
|
||||
return array(
|
||||
array('normal'),
|
||||
array('verbose'),
|
||||
array('very_verbose'),
|
||||
array('debug'),
|
||||
);
|
||||
return [
|
||||
['normal'],
|
||||
['verbose'],
|
||||
['very_verbose'],
|
||||
['debug'],
|
||||
];
|
||||
}
|
||||
|
||||
protected function getOutputStream($decorated = true, $verbosity = StreamOutput::VERBOSITY_NORMAL)
|
||||
|
||||
@@ -79,7 +79,7 @@ class ProgressIndicatorTest extends TestCase
|
||||
|
||||
public function testCustomIndicatorValues()
|
||||
{
|
||||
$bar = new ProgressIndicator($output = $this->getOutputStream(), null, 100, array('a', 'b', 'c'));
|
||||
$bar = new ProgressIndicator($output = $this->getOutputStream(), null, 100, ['a', 'b', 'c']);
|
||||
|
||||
$bar->start('Starting...');
|
||||
usleep(101000);
|
||||
@@ -106,7 +106,7 @@ class ProgressIndicatorTest extends TestCase
|
||||
*/
|
||||
public function testCannotSetInvalidIndicatorCharacters()
|
||||
{
|
||||
$bar = new ProgressIndicator($this->getOutputStream(), null, 100, array('1'));
|
||||
$bar = new ProgressIndicator($this->getOutputStream(), null, 100, ['1']);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -161,12 +161,12 @@ class ProgressIndicatorTest extends TestCase
|
||||
*/
|
||||
public function provideFormat()
|
||||
{
|
||||
return array(
|
||||
array('normal'),
|
||||
array('verbose'),
|
||||
array('very_verbose'),
|
||||
array('debug'),
|
||||
);
|
||||
return [
|
||||
['normal'],
|
||||
['verbose'],
|
||||
['very_verbose'],
|
||||
['debug'],
|
||||
];
|
||||
}
|
||||
|
||||
protected function getOutputStream($decorated = true, $verbosity = StreamOutput::VERBOSITY_NORMAL)
|
||||
|
||||
@@ -29,10 +29,10 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
{
|
||||
$questionHelper = new QuestionHelper();
|
||||
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$questionHelper->setHelperSet($helperSet);
|
||||
|
||||
$heroes = array('Superman', 'Batman', 'Spiderman');
|
||||
$heroes = ['Superman', 'Batman', 'Spiderman'];
|
||||
|
||||
$inputStream = $this->getInputStream("\n1\n 1 \nFabien\n1\nFabien\n1\n0,2\n 0 , 2 \n\n\n");
|
||||
|
||||
@@ -68,21 +68,21 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
$question->setMaxAttempts(1);
|
||||
$question->setMultiselect(true);
|
||||
|
||||
$this->assertEquals(array('Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(array('Superman', 'Spiderman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(array('Superman', 'Spiderman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Superman', 'Spiderman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Superman', 'Spiderman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
|
||||
$question = new ChoiceQuestion('What is your favorite superhero?', $heroes, '0,1');
|
||||
$question->setMaxAttempts(1);
|
||||
$question->setMultiselect(true);
|
||||
|
||||
$this->assertEquals(array('Superman', 'Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Superman', 'Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
|
||||
$question = new ChoiceQuestion('What is your favorite superhero?', $heroes, ' 0 , 1 ');
|
||||
$question->setMaxAttempts(1);
|
||||
$question->setMultiselect(true);
|
||||
|
||||
$this->assertEquals(array('Superman', 'Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Superman', 'Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
|
||||
$question = new ChoiceQuestion('What is your favorite superhero?', $heroes, 0);
|
||||
// We are supposed to get the default value since we are not in interactive mode
|
||||
@@ -93,11 +93,11 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
{
|
||||
$questionHelper = new QuestionHelper();
|
||||
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$questionHelper->setHelperSet($helperSet);
|
||||
$inputStream = $this->getInputStream("\n1\n 1 \nFabien\n1\nFabien\n1\n0,2\n 0 , 2 \n\n\n");
|
||||
|
||||
$heroes = array('Superman', 'Batman', 'Spiderman');
|
||||
$heroes = ['Superman', 'Batman', 'Spiderman'];
|
||||
|
||||
$question = new ChoiceQuestion('What is your favorite superhero?', $heroes, '0');
|
||||
|
||||
@@ -122,21 +122,24 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
$question = new ChoiceQuestion('Who are your favorite superheros?', $heroes, '0, 1');
|
||||
$question->setMultiselect(true);
|
||||
$this->assertSame(array('Superman', 'Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream, false), $this->createOutputInterface(), $question));
|
||||
$this->assertSame(['Superman', 'Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream, false), $this->createOutputInterface(), $question));
|
||||
|
||||
$question = new ChoiceQuestion('Who are your favorite superheros?', $heroes, '0, 1');
|
||||
$question->setMultiselect(true);
|
||||
$question->setValidator(null);
|
||||
$this->assertSame(array('Superman', 'Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream, false), $this->createOutputInterface(), $question));
|
||||
$this->assertSame(['Superman', 'Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream, false), $this->createOutputInterface(), $question));
|
||||
|
||||
$question = new ChoiceQuestion('Who are your favorite superheros?', $heroes, '0, Batman');
|
||||
$question->setMultiselect(true);
|
||||
$this->assertSame(array('Superman', 'Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream, false), $this->createOutputInterface(), $question));
|
||||
$this->assertSame(['Superman', 'Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream, false), $this->createOutputInterface(), $question));
|
||||
|
||||
$question = new ChoiceQuestion('Who are your favorite superheros?', $heroes, null);
|
||||
$question->setMultiselect(true);
|
||||
$this->assertNull($questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream, false), $this->createOutputInterface(), $question));
|
||||
|
||||
$question = new ChoiceQuestion('Who are your favorite superheros?', ['a' => 'Batman', 'b' => 'Superman'], 'a');
|
||||
$this->assertSame('a', $questionHelper->ask($this->createStreamableInputInterfaceMock('', false), $this->createOutputInterface(), $question), 'ChoiceQuestion validator returns the key if it\'s a string');
|
||||
|
||||
try {
|
||||
$question = new ChoiceQuestion('Who are your favorite superheros?', $heroes, '');
|
||||
$question->setMultiselect(true);
|
||||
@@ -179,11 +182,11 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
$inputStream = $this->getInputStream("Acm\nAc\177\177s\tTest\n\n\033[A\033[A\n\033[A\033[A\033[A\033[A\033[A\tTest\n\033[B\nS\177\177\033[B\033[B\nF00\177\177oo\t\n");
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$question = new Question('Please select a bundle', 'FrameworkBundle');
|
||||
$question->setAutocompleterValues(array('AcmeDemoBundle', 'AsseticBundle', 'SecurityBundle', 'FooBundle'));
|
||||
$question->setAutocompleterValues(['AcmeDemoBundle', 'AsseticBundle', 'SecurityBundle', 'FooBundle']);
|
||||
|
||||
$this->assertEquals('AcmeDemoBundle', $dialog->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals('AsseticBundleTest', $dialog->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
@@ -205,9 +208,9 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
$inputStream = $this->getInputStream("\033[A\033[A\n\033[B\033[B\n");
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$dialog->setHelperSet(new HelperSet(array(new FormatterHelper())));
|
||||
$dialog->setHelperSet(new HelperSet([new FormatterHelper()]));
|
||||
|
||||
$question = new ChoiceQuestion('Please select a bundle', array(1 => 'AcmeDemoBundle', 4 => 'AsseticBundle'));
|
||||
$question = new ChoiceQuestion('Please select a bundle', [1 => 'AcmeDemoBundle', 4 => 'AsseticBundle']);
|
||||
$question->setMaxAttempts(1);
|
||||
|
||||
$this->assertEquals('AcmeDemoBundle', $dialog->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
@@ -222,14 +225,14 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
$inputStream = $this->getInputStream("b\n");
|
||||
|
||||
$possibleChoices = array(
|
||||
$possibleChoices = [
|
||||
'a' => 'berlin',
|
||||
'b' => 'copenhagen',
|
||||
'c' => 'amsterdam',
|
||||
);
|
||||
];
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$dialog->setHelperSet(new HelperSet(array(new FormatterHelper())));
|
||||
$dialog->setHelperSet(new HelperSet([new FormatterHelper()]));
|
||||
|
||||
$question = new ChoiceQuestion('Please select a city', $possibleChoices);
|
||||
$question->setMaxAttempts(1);
|
||||
@@ -237,6 +240,43 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
$this->assertSame('b', $dialog->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
}
|
||||
|
||||
public function getInputs()
|
||||
{
|
||||
return [
|
||||
['$'], // 1 byte character
|
||||
['¢'], // 2 bytes character
|
||||
['€'], // 3 bytes character
|
||||
['𐍈'], // 4 bytes character
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider getInputs
|
||||
*/
|
||||
public function testAskWithAutocompleteWithMultiByteCharacter($character)
|
||||
{
|
||||
if (!$this->hasSttyAvailable()) {
|
||||
$this->markTestSkipped('`stty` is required to test autocomplete functionality');
|
||||
}
|
||||
|
||||
$inputStream = $this->getInputStream("$character\n");
|
||||
|
||||
$possibleChoices = [
|
||||
'$' => '1 byte character',
|
||||
'¢' => '2 bytes character',
|
||||
'€' => '3 bytes character',
|
||||
'𐍈' => '4 bytes character',
|
||||
];
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$dialog->setHelperSet(new HelperSet([new FormatterHelper()]));
|
||||
|
||||
$question = new ChoiceQuestion('Please select a character', $possibleChoices);
|
||||
$question->setMaxAttempts(1);
|
||||
|
||||
$this->assertSame($character, $dialog->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
}
|
||||
|
||||
public function testAutocompleteWithTrailingBackslash()
|
||||
{
|
||||
if (!$this->hasSttyAvailable()) {
|
||||
@@ -246,12 +286,12 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
$inputStream = $this->getInputStream('E');
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$question = new Question('');
|
||||
$expectedCompletion = 'ExampleNamespace\\';
|
||||
$question->setAutocompleterValues(array($expectedCompletion));
|
||||
$question->setAutocompleterValues([$expectedCompletion]);
|
||||
|
||||
$output = $this->createOutputInterface();
|
||||
$dialog->ask($this->createStreamableInputInterfaceMock($inputStream), $output, $question);
|
||||
@@ -262,11 +302,11 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
// Shell control (esc) sequences are not so important: we only care that
|
||||
// <hl> tag is interpreted correctly and replaced
|
||||
$irrelevantEscSequences = array(
|
||||
$irrelevantEscSequences = [
|
||||
"\0337" => '', // Save cursor position
|
||||
"\0338" => '', // Restore cursor position
|
||||
"\033[K" => '', // Clear line from cursor till the end
|
||||
);
|
||||
];
|
||||
|
||||
$importantActualOutput = strtr($actualOutput, $irrelevantEscSequences);
|
||||
|
||||
@@ -304,14 +344,14 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
public function getAskConfirmationData()
|
||||
{
|
||||
return array(
|
||||
array('', true),
|
||||
array('', false, false),
|
||||
array('y', true),
|
||||
array('yes', true),
|
||||
array('n', false),
|
||||
array('no', false),
|
||||
);
|
||||
return [
|
||||
['', true],
|
||||
['', false, false],
|
||||
['y', true],
|
||||
['yes', true],
|
||||
['n', false],
|
||||
['no', false],
|
||||
];
|
||||
}
|
||||
|
||||
public function testAskConfirmationWithCustomTrueAnswer()
|
||||
@@ -328,12 +368,12 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
public function testAskAndValidate()
|
||||
{
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$error = 'This is not a color!';
|
||||
$validator = function ($color) use ($error) {
|
||||
if (!\in_array($color, array('white', 'black'))) {
|
||||
if (!\in_array($color, ['white', 'black'])) {
|
||||
throw new \InvalidArgumentException($error);
|
||||
}
|
||||
|
||||
@@ -361,14 +401,14 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
*/
|
||||
public function testSelectChoiceFromSimpleChoices($providedAnswer, $expectedValue)
|
||||
{
|
||||
$possibleChoices = array(
|
||||
$possibleChoices = [
|
||||
'My environment 1',
|
||||
'My environment 2',
|
||||
'My environment 3',
|
||||
);
|
||||
];
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$question = new ChoiceQuestion('Please select the environment to load', $possibleChoices);
|
||||
@@ -380,14 +420,14 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
public function simpleAnswerProvider()
|
||||
{
|
||||
return array(
|
||||
array(0, 'My environment 1'),
|
||||
array(1, 'My environment 2'),
|
||||
array(2, 'My environment 3'),
|
||||
array('My environment 1', 'My environment 1'),
|
||||
array('My environment 2', 'My environment 2'),
|
||||
array('My environment 3', 'My environment 3'),
|
||||
);
|
||||
return [
|
||||
[0, 'My environment 1'],
|
||||
[1, 'My environment 2'],
|
||||
[2, 'My environment 3'],
|
||||
['My environment 1', 'My environment 1'],
|
||||
['My environment 2', 'My environment 2'],
|
||||
['My environment 3', 'My environment 3'],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -395,14 +435,14 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
*/
|
||||
public function testSpecialCharacterChoiceFromMultipleChoiceList($providedAnswer, $expectedValue)
|
||||
{
|
||||
$possibleChoices = array(
|
||||
$possibleChoices = [
|
||||
'.',
|
||||
'src',
|
||||
);
|
||||
];
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$inputStream = $this->getInputStream($providedAnswer."\n");
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$question = new ChoiceQuestion('Please select the directory', $possibleChoices);
|
||||
@@ -415,10 +455,10 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
public function specialCharacterInMultipleChoice()
|
||||
{
|
||||
return array(
|
||||
array('.', array('.')),
|
||||
array('., src', array('.', 'src')),
|
||||
);
|
||||
return [
|
||||
['.', ['.']],
|
||||
['., src', ['.', 'src']],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -426,15 +466,15 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
*/
|
||||
public function testChoiceFromChoicelistWithMixedKeys($providedAnswer, $expectedValue)
|
||||
{
|
||||
$possibleChoices = array(
|
||||
$possibleChoices = [
|
||||
'0' => 'No environment',
|
||||
'1' => 'My environment 1',
|
||||
'env_2' => 'My environment 2',
|
||||
3 => 'My environment 3',
|
||||
);
|
||||
];
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$question = new ChoiceQuestion('Please select the environment to load', $possibleChoices);
|
||||
@@ -446,14 +486,14 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
public function mixedKeysChoiceListAnswerProvider()
|
||||
{
|
||||
return array(
|
||||
array('0', '0'),
|
||||
array('No environment', '0'),
|
||||
array('1', '1'),
|
||||
array('env_2', 'env_2'),
|
||||
array(3, '3'),
|
||||
array('My environment 1', '1'),
|
||||
);
|
||||
return [
|
||||
['0', '0'],
|
||||
['No environment', '0'],
|
||||
['1', '1'],
|
||||
['env_2', 'env_2'],
|
||||
[3, '3'],
|
||||
['My environment 1', '1'],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -461,14 +501,14 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
*/
|
||||
public function testSelectChoiceFromChoiceList($providedAnswer, $expectedValue)
|
||||
{
|
||||
$possibleChoices = array(
|
||||
$possibleChoices = [
|
||||
'env_1' => 'My environment 1',
|
||||
'env_2' => 'My environment',
|
||||
'env_3' => 'My environment',
|
||||
);
|
||||
];
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$question = new ChoiceQuestion('Please select the environment to load', $possibleChoices);
|
||||
@@ -484,14 +524,14 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
*/
|
||||
public function testAmbiguousChoiceFromChoicelist()
|
||||
{
|
||||
$possibleChoices = array(
|
||||
$possibleChoices = [
|
||||
'env_1' => 'My first environment',
|
||||
'env_2' => 'My environment',
|
||||
'env_3' => 'My environment',
|
||||
);
|
||||
];
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$question = new ChoiceQuestion('Please select the environment to load', $possibleChoices);
|
||||
@@ -502,12 +542,12 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
public function answerProvider()
|
||||
{
|
||||
return array(
|
||||
array('env_1', 'env_1'),
|
||||
array('env_2', 'env_2'),
|
||||
array('env_3', 'env_3'),
|
||||
array('My environment 1', 'env_1'),
|
||||
);
|
||||
return [
|
||||
['env_1', 'env_1'],
|
||||
['env_2', 'env_2'],
|
||||
['env_3', 'env_3'],
|
||||
['My environment 1', 'env_1'],
|
||||
];
|
||||
}
|
||||
|
||||
public function testNoInteraction()
|
||||
@@ -523,22 +563,22 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
public function testChoiceOutputFormattingQuestionForUtf8Keys()
|
||||
{
|
||||
$question = 'Lorem ipsum?';
|
||||
$possibleChoices = array(
|
||||
$possibleChoices = [
|
||||
'foo' => 'foo',
|
||||
'żółw' => 'bar',
|
||||
'łabądź' => 'baz',
|
||||
);
|
||||
$outputShown = array(
|
||||
];
|
||||
$outputShown = [
|
||||
$question,
|
||||
' [<info>foo </info>] foo',
|
||||
' [<info>żółw </info>] bar',
|
||||
' [<info>łabądź</info>] baz',
|
||||
);
|
||||
];
|
||||
$output = $this->getMockBuilder('\Symfony\Component\Console\Output\OutputInterface')->getMock();
|
||||
$output->method('getFormatter')->willReturn(new OutputFormatter());
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$output->expects($this->once())->method('writeln')->with($this->equalTo($outputShown));
|
||||
@@ -549,7 +589,7 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Console\Exception\RuntimeException
|
||||
* @expectedExceptionMessage Aborted
|
||||
* @expectedExceptionMessage Aborted.
|
||||
*/
|
||||
public function testAskThrowsExceptionOnMissingInput()
|
||||
{
|
||||
@@ -559,7 +599,17 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Console\Exception\RuntimeException
|
||||
* @expectedExceptionMessage Aborted
|
||||
* @expectedExceptionMessage Aborted.
|
||||
*/
|
||||
public function testAskThrowsExceptionOnMissingInputForChoiceQuestion()
|
||||
{
|
||||
$dialog = new QuestionHelper();
|
||||
$dialog->ask($this->createStreamableInputInterfaceMock($this->getInputStream('')), $this->createOutputInterface(), new ChoiceQuestion('Choice', ['a', 'b']));
|
||||
}
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Console\Exception\RuntimeException
|
||||
* @expectedExceptionMessage Aborted.
|
||||
*/
|
||||
public function testAskThrowsExceptionOnMissingInputWithValidator()
|
||||
{
|
||||
@@ -581,7 +631,7 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
*/
|
||||
public function testEmptyChoices()
|
||||
{
|
||||
new ChoiceQuestion('Question', array(), 'irrelevant');
|
||||
new ChoiceQuestion('Question', [], 'irrelevant');
|
||||
}
|
||||
|
||||
public function testTraversableAutocomplete()
|
||||
@@ -601,11 +651,11 @@ class QuestionHelperTest extends AbstractQuestionHelperTest
|
||||
$inputStream = $this->getInputStream("Acm\nAc\177\177s\tTest\n\n\033[A\033[A\n\033[A\033[A\033[A\033[A\033[A\tTest\n\033[B\nS\177\177\033[B\033[B\nF00\177\177oo\t\n");
|
||||
|
||||
$dialog = new QuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$dialog->setHelperSet($helperSet);
|
||||
|
||||
$question = new Question('Please select a bundle', 'FrameworkBundle');
|
||||
$question->setAutocompleterValues(new AutocompleteValues(array('irrelevant' => 'AcmeDemoBundle', 'AsseticBundle', 'SecurityBundle', 'FooBundle')));
|
||||
$question->setAutocompleterValues(new AutocompleteValues(['irrelevant' => 'AcmeDemoBundle', 'AsseticBundle', 'SecurityBundle', 'FooBundle']));
|
||||
|
||||
$this->assertEquals('AcmeDemoBundle', $dialog->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals('AsseticBundleTest', $dialog->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
|
||||
@@ -18,10 +18,10 @@ class SymfonyQuestionHelperTest extends AbstractQuestionHelperTest
|
||||
{
|
||||
$questionHelper = new SymfonyQuestionHelper();
|
||||
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$questionHelper->setHelperSet($helperSet);
|
||||
|
||||
$heroes = array('Superman', 'Batman', 'Spiderman');
|
||||
$heroes = ['Superman', 'Batman', 'Spiderman'];
|
||||
|
||||
$inputStream = $this->getInputStream("\n1\n 1 \nFabien\n1\nFabien\n1\n0,2\n 0 , 2 \n\n\n");
|
||||
|
||||
@@ -55,31 +55,31 @@ class SymfonyQuestionHelperTest extends AbstractQuestionHelperTest
|
||||
$question->setMaxAttempts(1);
|
||||
$question->setMultiselect(true);
|
||||
|
||||
$this->assertEquals(array('Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(array('Superman', 'Spiderman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(array('Superman', 'Spiderman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Superman', 'Spiderman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Superman', 'Spiderman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $this->createOutputInterface(), $question));
|
||||
|
||||
$question = new ChoiceQuestion('What is your favorite superhero?', $heroes, '0,1');
|
||||
$question->setMaxAttempts(1);
|
||||
$question->setMultiselect(true);
|
||||
|
||||
$this->assertEquals(array('Superman', 'Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $output = $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Superman', 'Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $output = $this->createOutputInterface(), $question));
|
||||
$this->assertOutputContains('What is your favorite superhero? [Superman, Batman]', $output);
|
||||
|
||||
$question = new ChoiceQuestion('What is your favorite superhero?', $heroes, ' 0 , 1 ');
|
||||
$question->setMaxAttempts(1);
|
||||
$question->setMultiselect(true);
|
||||
|
||||
$this->assertEquals(array('Superman', 'Batman'), $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $output = $this->createOutputInterface(), $question));
|
||||
$this->assertEquals(['Superman', 'Batman'], $questionHelper->ask($this->createStreamableInputInterfaceMock($inputStream), $output = $this->createOutputInterface(), $question));
|
||||
$this->assertOutputContains('What is your favorite superhero? [Superman, Batman]', $output);
|
||||
}
|
||||
|
||||
public function testAskChoiceWithChoiceValueAsDefault()
|
||||
{
|
||||
$questionHelper = new SymfonyQuestionHelper();
|
||||
$helperSet = new HelperSet(array(new FormatterHelper()));
|
||||
$helperSet = new HelperSet([new FormatterHelper()]);
|
||||
$questionHelper->setHelperSet($helperSet);
|
||||
$question = new ChoiceQuestion('What is your favorite superhero?', array('Superman', 'Batman', 'Spiderman'), 'Batman');
|
||||
$question = new ChoiceQuestion('What is your favorite superhero?', ['Superman', 'Batman', 'Spiderman'], 'Batman');
|
||||
$question->setMaxAttempts(1);
|
||||
|
||||
$this->assertSame('Batman', $questionHelper->ask($this->createStreamableInputInterfaceMock($this->getInputStream("Batman\n")), $output = $this->createOutputInterface(), $question));
|
||||
@@ -124,7 +124,7 @@ class SymfonyQuestionHelperTest extends AbstractQuestionHelperTest
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Console\Exception\RuntimeException
|
||||
* @expectedExceptionMessage Aborted
|
||||
* @expectedExceptionMessage Aborted.
|
||||
*/
|
||||
public function testAskThrowsExceptionOnMissingInput()
|
||||
{
|
||||
|
||||
634
vendor/symfony/console/Tests/Helper/TableTest.php
vendored
634
vendor/symfony/console/Tests/Helper/TableTest.php
vendored
@@ -87,16 +87,16 @@ class TableTest extends TestCase
|
||||
|
||||
public function renderProvider()
|
||||
{
|
||||
$books = array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'),
|
||||
array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens'),
|
||||
array('960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'),
|
||||
array('80-902734-1-6', 'And Then There Were None', 'Agatha Christie'),
|
||||
);
|
||||
$books = [
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'],
|
||||
['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens'],
|
||||
['960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'],
|
||||
['80-902734-1-6', 'And Then There Were None', 'Agatha Christie'],
|
||||
];
|
||||
|
||||
return array(
|
||||
array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
return [
|
||||
[
|
||||
['ISBN', 'Title', 'Author'],
|
||||
$books,
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
@@ -110,9 +110,9 @@ class TableTest extends TestCase
|
||||
+---------------+--------------------------+------------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
],
|
||||
[
|
||||
['ISBN', 'Title', 'Author'],
|
||||
$books,
|
||||
'compact',
|
||||
<<<'TABLE'
|
||||
@@ -123,9 +123,9 @@ TABLE
|
||||
80-902734-1-6 And Then There Were None Agatha Christie
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
],
|
||||
[
|
||||
['ISBN', 'Title', 'Author'],
|
||||
$books,
|
||||
'borderless',
|
||||
<<<'TABLE'
|
||||
@@ -139,9 +139,9 @@ TABLE
|
||||
=============== ========================== ==================
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
],
|
||||
[
|
||||
['ISBN', 'Title', 'Author'],
|
||||
$books,
|
||||
'box',
|
||||
<<<'TABLE'
|
||||
@@ -155,16 +155,16 @@ TABLE
|
||||
└───────────────┴──────────────────────────┴──────────────────┘
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'),
|
||||
array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens'),
|
||||
],
|
||||
[
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'],
|
||||
['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens'],
|
||||
new TableSeparator(),
|
||||
array('960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'),
|
||||
array('80-902734-1-6', 'And Then There Were None', 'Agatha Christie'),
|
||||
),
|
||||
['960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'],
|
||||
['80-902734-1-6', 'And Then There Were None', 'Agatha Christie'],
|
||||
],
|
||||
'box-double',
|
||||
<<<'TABLE'
|
||||
╔═══════════════╤══════════════════════════╤══════════════════╗
|
||||
@@ -178,15 +178,15 @@ TABLE
|
||||
╚═══════════════╧══════════════════════════╧══════════════════╝
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array('ISBN', 'Title'),
|
||||
array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'),
|
||||
array('9971-5-0210-0'),
|
||||
array('960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'),
|
||||
array('80-902734-1-6', 'And Then There Were None', 'Agatha Christie'),
|
||||
),
|
||||
],
|
||||
[
|
||||
['ISBN', 'Title'],
|
||||
[
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'],
|
||||
['9971-5-0210-0'],
|
||||
['960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'],
|
||||
['80-902734-1-6', 'And Then There Were None', 'Agatha Christie'],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+---------------+--------------------------+------------------+
|
||||
@@ -199,15 +199,15 @@ TABLE
|
||||
+---------------+--------------------------+------------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array(),
|
||||
array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'),
|
||||
array('9971-5-0210-0'),
|
||||
array('960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'),
|
||||
array('80-902734-1-6', 'And Then There Were None', 'Agatha Christie'),
|
||||
),
|
||||
],
|
||||
[
|
||||
[],
|
||||
[
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'],
|
||||
['9971-5-0210-0'],
|
||||
['960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'],
|
||||
['80-902734-1-6', 'And Then There Were None', 'Agatha Christie'],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+---------------+--------------------------+------------------+
|
||||
@@ -218,15 +218,15 @@ TABLE
|
||||
+---------------+--------------------------+------------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array('99921-58-10-7', "Divine\nComedy", 'Dante Alighieri'),
|
||||
array('9971-5-0210-2', "Harry Potter\nand the Chamber of Secrets", "Rowling\nJoanne K."),
|
||||
array('9971-5-0210-2', "Harry Potter\nand the Chamber of Secrets", "Rowling\nJoanne K."),
|
||||
array('960-425-059-0', 'The Lord of the Rings', "J. R. R.\nTolkien"),
|
||||
),
|
||||
],
|
||||
[
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
['99921-58-10-7', "Divine\nComedy", 'Dante Alighieri'],
|
||||
['9971-5-0210-2', "Harry Potter\nand the Chamber of Secrets", "Rowling\nJoanne K."],
|
||||
['9971-5-0210-2', "Harry Potter\nand the Chamber of Secrets", "Rowling\nJoanne K."],
|
||||
['960-425-059-0', 'The Lord of the Rings', "J. R. R.\nTolkien"],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+---------------+----------------------------+-----------------+
|
||||
@@ -243,10 +243,10 @@ TABLE
|
||||
+---------------+----------------------------+-----------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array('ISBN', 'Title'),
|
||||
array(),
|
||||
],
|
||||
[
|
||||
['ISBN', 'Title'],
|
||||
[],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+------+-------+
|
||||
@@ -254,19 +254,19 @@ TABLE
|
||||
+------+-------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
array(),
|
||||
array(),
|
||||
],
|
||||
[
|
||||
[],
|
||||
[],
|
||||
'default',
|
||||
'',
|
||||
),
|
||||
'Cell text with tags used for Output styling' => array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array('<info>99921-58-10-7</info>', '<error>Divine Comedy</error>', '<fg=blue;bg=white>Dante Alighieri</fg=blue;bg=white>'),
|
||||
array('9971-5-0210-0', 'A Tale of Two Cities', '<info>Charles Dickens</>'),
|
||||
),
|
||||
],
|
||||
'Cell text with tags used for Output styling' => [
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
['<info>99921-58-10-7</info>', '<error>Divine Comedy</error>', '<fg=blue;bg=white>Dante Alighieri</fg=blue;bg=white>'],
|
||||
['9971-5-0210-0', 'A Tale of Two Cities', '<info>Charles Dickens</>'],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+---------------+----------------------+-----------------+
|
||||
@@ -277,13 +277,13 @@ TABLE
|
||||
+---------------+----------------------+-----------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Cell text with tags not used for Output styling' => array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array('<strong>99921-58-10-700</strong>', '<f>Divine Com</f>', 'Dante Alighieri'),
|
||||
array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens'),
|
||||
),
|
||||
],
|
||||
'Cell text with tags not used for Output styling' => [
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
['<strong>99921-58-10-700</strong>', '<f>Divine Com</f>', 'Dante Alighieri'],
|
||||
['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens'],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+----------------------------------+----------------------+-----------------+
|
||||
@@ -294,28 +294,28 @@ TABLE
|
||||
+----------------------------------+----------------------+-----------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Cell with colspan' => array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'),
|
||||
],
|
||||
'Cell with colspan' => [
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'],
|
||||
new TableSeparator(),
|
||||
array(new TableCell('Divine Comedy(Dante Alighieri)', array('colspan' => 3))),
|
||||
[new TableCell('Divine Comedy(Dante Alighieri)', ['colspan' => 3])],
|
||||
new TableSeparator(),
|
||||
array(
|
||||
new TableCell('Arduino: A Quick-Start Guide', array('colspan' => 2)),
|
||||
[
|
||||
new TableCell('Arduino: A Quick-Start Guide', ['colspan' => 2]),
|
||||
'Mark Schmidt',
|
||||
),
|
||||
],
|
||||
new TableSeparator(),
|
||||
array(
|
||||
[
|
||||
'9971-5-0210-0',
|
||||
new TableCell("A Tale of \nTwo Cities", array('colspan' => 2)),
|
||||
),
|
||||
new TableCell("A Tale of \nTwo Cities", ['colspan' => 2]),
|
||||
],
|
||||
new TableSeparator(),
|
||||
array(
|
||||
new TableCell('Cupiditate dicta atque porro, tempora exercitationem modi animi nulla nemo vel nihil!', array('colspan' => 3)),
|
||||
),
|
||||
),
|
||||
[
|
||||
new TableCell('Cupiditate dicta atque porro, tempora exercitationem modi animi nulla nemo vel nihil!', ['colspan' => 3]),
|
||||
],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+-------------------------------+-------------------------------+-----------------------------+
|
||||
@@ -334,21 +334,21 @@ TABLE
|
||||
+-------------------------------+-------------------------------+-----------------------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Cell with rowspan' => array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array(
|
||||
new TableCell('9971-5-0210-0', array('rowspan' => 3)),
|
||||
new TableCell('Divine Comedy', array('rowspan' => 2)),
|
||||
],
|
||||
'Cell with rowspan' => [
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
[
|
||||
new TableCell('9971-5-0210-0', ['rowspan' => 3]),
|
||||
new TableCell('Divine Comedy', ['rowspan' => 2]),
|
||||
'Dante Alighieri',
|
||||
),
|
||||
array(),
|
||||
array("The Lord of \nthe Rings", "J. R. \nR. Tolkien"),
|
||||
],
|
||||
[],
|
||||
["The Lord of \nthe Rings", "J. R. \nR. Tolkien"],
|
||||
new TableSeparator(),
|
||||
array('80-902734-1-6', new TableCell("And Then \nThere \nWere None", array('rowspan' => 3)), 'Agatha Christie'),
|
||||
array('80-902734-1-7', 'Test'),
|
||||
),
|
||||
['80-902734-1-6', new TableCell("And Then \nThere \nWere None", ['rowspan' => 3]), 'Agatha Christie'],
|
||||
['80-902734-1-7', 'Test'],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+---------------+---------------+-----------------+
|
||||
@@ -365,23 +365,23 @@ TABLE
|
||||
+---------------+---------------+-----------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Cell with rowspan and colspan' => array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array(
|
||||
new TableCell('9971-5-0210-0', array('rowspan' => 2, 'colspan' => 2)),
|
||||
],
|
||||
'Cell with rowspan and colspan' => [
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
[
|
||||
new TableCell('9971-5-0210-0', ['rowspan' => 2, 'colspan' => 2]),
|
||||
'Dante Alighieri',
|
||||
),
|
||||
array('Charles Dickens'),
|
||||
],
|
||||
['Charles Dickens'],
|
||||
new TableSeparator(),
|
||||
array(
|
||||
[
|
||||
'Dante Alighieri',
|
||||
new TableCell('9971-5-0210-0', array('rowspan' => 3, 'colspan' => 2)),
|
||||
),
|
||||
array('J. R. R. Tolkien'),
|
||||
array('J. R. R'),
|
||||
),
|
||||
new TableCell('9971-5-0210-0', ['rowspan' => 3, 'colspan' => 2]),
|
||||
],
|
||||
['J. R. R. Tolkien'],
|
||||
['J. R. R'],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+------------------+---------+-----------------+
|
||||
@@ -396,27 +396,27 @@ TABLE
|
||||
+------------------+---------+-----------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Cell with rowspan and colspan contains new line break' => array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array(
|
||||
new TableCell("9971\n-5-\n021\n0-0", array('rowspan' => 2, 'colspan' => 2)),
|
||||
],
|
||||
'Cell with rowspan and colspan contains new line break' => [
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
[
|
||||
new TableCell("9971\n-5-\n021\n0-0", ['rowspan' => 2, 'colspan' => 2]),
|
||||
'Dante Alighieri',
|
||||
),
|
||||
array('Charles Dickens'),
|
||||
],
|
||||
['Charles Dickens'],
|
||||
new TableSeparator(),
|
||||
array(
|
||||
[
|
||||
'Dante Alighieri',
|
||||
new TableCell("9971\n-5-\n021\n0-0", array('rowspan' => 2, 'colspan' => 2)),
|
||||
),
|
||||
array('Charles Dickens'),
|
||||
new TableCell("9971\n-5-\n021\n0-0", ['rowspan' => 2, 'colspan' => 2]),
|
||||
],
|
||||
['Charles Dickens'],
|
||||
new TableSeparator(),
|
||||
array(
|
||||
new TableCell("9971\n-5-\n021\n0-0", array('rowspan' => 2, 'colspan' => 2)),
|
||||
new TableCell("Dante \nAlighieri", array('rowspan' => 2, 'colspan' => 1)),
|
||||
),
|
||||
),
|
||||
[
|
||||
new TableCell("9971\n-5-\n021\n0-0", ['rowspan' => 2, 'colspan' => 2]),
|
||||
new TableCell("Dante \nAlighieri", ['rowspan' => 2, 'colspan' => 1]),
|
||||
],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+-----------------+-------+-----------------+
|
||||
@@ -439,21 +439,21 @@ TABLE
|
||||
+-----------------+-------+-----------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Cell with rowspan and colspan without using TableSeparator' => array(
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
array(
|
||||
array(
|
||||
new TableCell("9971\n-5-\n021\n0-0", array('rowspan' => 2, 'colspan' => 2)),
|
||||
],
|
||||
'Cell with rowspan and colspan without using TableSeparator' => [
|
||||
['ISBN', 'Title', 'Author'],
|
||||
[
|
||||
[
|
||||
new TableCell("9971\n-5-\n021\n0-0", ['rowspan' => 2, 'colspan' => 2]),
|
||||
'Dante Alighieri',
|
||||
),
|
||||
array('Charles Dickens'),
|
||||
array(
|
||||
],
|
||||
['Charles Dickens'],
|
||||
[
|
||||
'Dante Alighieri',
|
||||
new TableCell("9971\n-5-\n021\n0-0", array('rowspan' => 2, 'colspan' => 2)),
|
||||
),
|
||||
array('Charles Dickens'),
|
||||
),
|
||||
new TableCell("9971\n-5-\n021\n0-0", ['rowspan' => 2, 'colspan' => 2]),
|
||||
],
|
||||
['Charles Dickens'],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+-----------------+-------+-----------------+
|
||||
@@ -470,17 +470,17 @@ TABLE
|
||||
+-----------------+-------+-----------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Cell with rowspan and colspan with separator inside a rowspan' => array(
|
||||
array('ISBN', 'Author'),
|
||||
array(
|
||||
array(
|
||||
new TableCell('9971-5-0210-0', array('rowspan' => 3, 'colspan' => 1)),
|
||||
],
|
||||
'Cell with rowspan and colspan with separator inside a rowspan' => [
|
||||
['ISBN', 'Author'],
|
||||
[
|
||||
[
|
||||
new TableCell('9971-5-0210-0', ['rowspan' => 3, 'colspan' => 1]),
|
||||
'Dante Alighieri',
|
||||
),
|
||||
array(new TableSeparator()),
|
||||
array('Charles Dickens'),
|
||||
),
|
||||
],
|
||||
[new TableSeparator()],
|
||||
['Charles Dickens'],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+---------------+-----------------+
|
||||
@@ -492,13 +492,13 @@ TABLE
|
||||
+---------------+-----------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Multiple header lines' => array(
|
||||
array(
|
||||
array(new TableCell('Main title', array('colspan' => 3))),
|
||||
array('ISBN', 'Title', 'Author'),
|
||||
),
|
||||
array(),
|
||||
],
|
||||
'Multiple header lines' => [
|
||||
[
|
||||
[new TableCell('Main title', ['colspan' => 3])],
|
||||
['ISBN', 'Title', 'Author'],
|
||||
],
|
||||
[],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+------+-------+--------+
|
||||
@@ -508,17 +508,17 @@ TABLE
|
||||
+------+-------+--------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Row with multiple cells' => array(
|
||||
array(),
|
||||
array(
|
||||
array(
|
||||
new TableCell('1', array('colspan' => 3)),
|
||||
new TableCell('2', array('colspan' => 2)),
|
||||
new TableCell('3', array('colspan' => 2)),
|
||||
new TableCell('4', array('colspan' => 2)),
|
||||
),
|
||||
),
|
||||
],
|
||||
'Row with multiple cells' => [
|
||||
[],
|
||||
[
|
||||
[
|
||||
new TableCell('1', ['colspan' => 3]),
|
||||
new TableCell('2', ['colspan' => 2]),
|
||||
new TableCell('3', ['colspan' => 2]),
|
||||
new TableCell('4', ['colspan' => 2]),
|
||||
],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+---+--+--+---+--+---+--+---+--+
|
||||
@@ -526,22 +526,22 @@ TABLE
|
||||
+---+--+--+---+--+---+--+---+--+
|
||||
|
||||
TABLE
|
||||
),
|
||||
'Coslpan and table cells with comment style' => array(
|
||||
array(
|
||||
new TableCell('<comment>Long Title</comment>', array('colspan' => 3)),
|
||||
),
|
||||
array(
|
||||
array(
|
||||
new TableCell('9971-5-0210-0', array('colspan' => 3)),
|
||||
),
|
||||
],
|
||||
'Coslpan and table cells with comment style' => [
|
||||
[
|
||||
new TableCell('<comment>Long Title</comment>', ['colspan' => 3]),
|
||||
],
|
||||
[
|
||||
[
|
||||
new TableCell('9971-5-0210-0', ['colspan' => 3]),
|
||||
],
|
||||
new TableSeparator(),
|
||||
array(
|
||||
[
|
||||
'Dante Alighieri',
|
||||
'J. R. R. Tolkien',
|
||||
'J. R. R',
|
||||
),
|
||||
),
|
||||
],
|
||||
],
|
||||
'default',
|
||||
<<<TABLE
|
||||
+-----------------+------------------+---------+
|
||||
@@ -555,22 +555,22 @@ TABLE
|
||||
TABLE
|
||||
,
|
||||
true,
|
||||
),
|
||||
'Row with formatted cells containing a newline' => array(
|
||||
array(),
|
||||
array(
|
||||
array(
|
||||
new TableCell('<error>Dont break'."\n".'here</error>', array('colspan' => 2)),
|
||||
),
|
||||
],
|
||||
'Row with formatted cells containing a newline' => [
|
||||
[],
|
||||
[
|
||||
[
|
||||
new TableCell('<error>Dont break'."\n".'here</error>', ['colspan' => 2]),
|
||||
],
|
||||
new TableSeparator(),
|
||||
array(
|
||||
[
|
||||
'foo',
|
||||
new TableCell('<error>Dont break'."\n".'here</error>', array('rowspan' => 2)),
|
||||
),
|
||||
array(
|
||||
new TableCell('<error>Dont break'."\n".'here</error>', ['rowspan' => 2]),
|
||||
],
|
||||
[
|
||||
'bar',
|
||||
),
|
||||
),
|
||||
],
|
||||
],
|
||||
'default',
|
||||
<<<'TABLE'
|
||||
+-------+------------+
|
||||
@@ -584,16 +584,16 @@ TABLE
|
||||
TABLE
|
||||
,
|
||||
true,
|
||||
),
|
||||
);
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
public function testRenderMultiByte()
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table
|
||||
->setHeaders(array('■■'))
|
||||
->setRows(array(array(1234)))
|
||||
->setHeaders(['■■'])
|
||||
->setRows([[1234]])
|
||||
->setStyle('default')
|
||||
;
|
||||
$table->render();
|
||||
@@ -615,7 +615,7 @@ TABLE;
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
|
||||
$table->setRows(array(array(new TableCell(12345))));
|
||||
$table->setRows([[new TableCell(12345)]]);
|
||||
$table->render();
|
||||
|
||||
$expected =
|
||||
@@ -633,7 +633,7 @@ TABLE;
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
|
||||
$table->setRows(array(array(new TableCell(12345.01))));
|
||||
$table->setRows([[new TableCell(12345.01)]]);
|
||||
$table->render();
|
||||
|
||||
$expected =
|
||||
@@ -659,8 +659,8 @@ TABLE;
|
||||
Table::setStyleDefinition('dotfull', $style);
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table
|
||||
->setHeaders(array('Foo'))
|
||||
->setRows(array(array('Bar')))
|
||||
->setHeaders(['Foo'])
|
||||
->setRows([['Bar']])
|
||||
->setStyle('dotfull');
|
||||
$table->render();
|
||||
|
||||
@@ -681,14 +681,14 @@ TABLE;
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table
|
||||
->setHeaders(array('Foo'))
|
||||
->setRows(array(
|
||||
array('Bar1'),
|
||||
->setHeaders(['Foo'])
|
||||
->setRows([
|
||||
['Bar1'],
|
||||
new TableSeparator(),
|
||||
array('Bar2'),
|
||||
['Bar2'],
|
||||
new TableSeparator(),
|
||||
array('Bar3'),
|
||||
));
|
||||
['Bar3'],
|
||||
]);
|
||||
$table->render();
|
||||
|
||||
$expected =
|
||||
@@ -713,9 +713,9 @@ TABLE;
|
||||
public function testRenderMultiCalls()
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table->setRows(array(
|
||||
array(new TableCell('foo', array('colspan' => 2))),
|
||||
));
|
||||
$table->setRows([
|
||||
[new TableCell('foo', ['colspan' => 2])],
|
||||
]);
|
||||
$table->render();
|
||||
$table->render();
|
||||
$table->render();
|
||||
@@ -741,11 +741,11 @@ TABLE;
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table
|
||||
->setHeaders(array('ISBN', 'Title', 'Author', 'Price'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'),
|
||||
array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'),
|
||||
));
|
||||
->setHeaders(['ISBN', 'Title', 'Author', 'Price'])
|
||||
->setRows([
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'],
|
||||
['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'],
|
||||
]);
|
||||
|
||||
$style = new TableStyle();
|
||||
$style->setPadType(STR_PAD_LEFT);
|
||||
@@ -775,10 +775,10 @@ TABLE;
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table
|
||||
->setHeaders(array('ISBN', 'Title', 'Author', 'Price'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', array(), 'Dante Alighieri', '9.95'),
|
||||
));
|
||||
->setHeaders(['ISBN', 'Title', 'Author', 'Price'])
|
||||
->setRows([
|
||||
['99921-58-10-7', [], 'Dante Alighieri', '9.95'],
|
||||
]);
|
||||
|
||||
$table->render();
|
||||
}
|
||||
@@ -787,11 +787,11 @@ TABLE;
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table
|
||||
->setHeaders(array('ISBN', 'Title', 'Author', 'Price'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'),
|
||||
array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'),
|
||||
))
|
||||
->setHeaders(['ISBN', 'Title', 'Author', 'Price'])
|
||||
->setRows([
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'],
|
||||
['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'],
|
||||
])
|
||||
->setColumnWidth(0, 15)
|
||||
->setColumnWidth(3, 10);
|
||||
|
||||
@@ -819,12 +819,12 @@ TABLE;
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table
|
||||
->setHeaders(array('ISBN', 'Title', 'Author', 'Price'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'),
|
||||
array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'),
|
||||
))
|
||||
->setColumnWidths(array(15, 0, -1, 10));
|
||||
->setHeaders(['ISBN', 'Title', 'Author', 'Price'])
|
||||
->setRows([
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'],
|
||||
['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'],
|
||||
])
|
||||
->setColumnWidths([15, 0, -1, 10]);
|
||||
|
||||
$style = new TableStyle();
|
||||
$style->setPadType(STR_PAD_LEFT);
|
||||
@@ -848,19 +848,19 @@ TABLE;
|
||||
|
||||
public function testSectionOutput()
|
||||
{
|
||||
$sections = array();
|
||||
$sections = [];
|
||||
$stream = $this->getOutputStream(true);
|
||||
$output = new ConsoleSectionOutput($stream->getStream(), $sections, $stream->getVerbosity(), $stream->isDecorated(), new OutputFormatter());
|
||||
$table = new Table($output);
|
||||
$table
|
||||
->setHeaders(array('ISBN', 'Title', 'Author', 'Price'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'),
|
||||
));
|
||||
->setHeaders(['ISBN', 'Title', 'Author', 'Price'])
|
||||
->setRows([
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'],
|
||||
]);
|
||||
|
||||
$table->render();
|
||||
|
||||
$table->appendRow(array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'));
|
||||
$table->appendRow(['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25']);
|
||||
|
||||
$expected =
|
||||
<<<TABLE
|
||||
@@ -883,17 +883,17 @@ TABLE;
|
||||
|
||||
public function testSectionOutputDoesntClearIfTableIsntRendered()
|
||||
{
|
||||
$sections = array();
|
||||
$sections = [];
|
||||
$stream = $this->getOutputStream(true);
|
||||
$output = new ConsoleSectionOutput($stream->getStream(), $sections, $stream->getVerbosity(), $stream->isDecorated(), new OutputFormatter());
|
||||
$table = new Table($output);
|
||||
$table
|
||||
->setHeaders(array('ISBN', 'Title', 'Author', 'Price'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'),
|
||||
));
|
||||
->setHeaders(['ISBN', 'Title', 'Author', 'Price'])
|
||||
->setRows([
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'],
|
||||
]);
|
||||
|
||||
$table->appendRow(array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'));
|
||||
$table->appendRow(['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25']);
|
||||
|
||||
$expected =
|
||||
<<<TABLE
|
||||
@@ -911,19 +911,19 @@ TABLE;
|
||||
|
||||
public function testSectionOutputWithoutDecoration()
|
||||
{
|
||||
$sections = array();
|
||||
$sections = [];
|
||||
$stream = $this->getOutputStream();
|
||||
$output = new ConsoleSectionOutput($stream->getStream(), $sections, $stream->getVerbosity(), $stream->isDecorated(), new OutputFormatter());
|
||||
$table = new Table($output);
|
||||
$table
|
||||
->setHeaders(array('ISBN', 'Title', 'Author', 'Price'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'),
|
||||
));
|
||||
->setHeaders(['ISBN', 'Title', 'Author', 'Price'])
|
||||
->setRows([
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri', '9.95'],
|
||||
]);
|
||||
|
||||
$table->render();
|
||||
|
||||
$table->appendRow(array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'));
|
||||
$table->appendRow(['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25']);
|
||||
|
||||
$expected =
|
||||
<<<TABLE
|
||||
@@ -952,7 +952,7 @@ TABLE;
|
||||
{
|
||||
$table = new Table($this->getOutputStream());
|
||||
|
||||
$table->appendRow(array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25'));
|
||||
$table->appendRow(['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens', '139.25']);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -982,13 +982,13 @@ TABLE;
|
||||
(new Table($output = $this->getOutputStream()))
|
||||
->setHeaderTitle($headerTitle)
|
||||
->setFooterTitle($footerTitle)
|
||||
->setHeaders(array('ISBN', 'Title', 'Author'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'),
|
||||
array('9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens'),
|
||||
array('960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'),
|
||||
array('80-902734-1-6', 'And Then There Were None', 'Agatha Christie'),
|
||||
))
|
||||
->setHeaders(['ISBN', 'Title', 'Author'])
|
||||
->setRows([
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'],
|
||||
['9971-5-0210-0', 'A Tale of Two Cities', 'Charles Dickens'],
|
||||
['960-425-059-0', 'The Lord of the Rings', 'J. R. R. Tolkien'],
|
||||
['80-902734-1-6', 'And Then There Were None', 'Agatha Christie'],
|
||||
])
|
||||
->setStyle($style)
|
||||
->render()
|
||||
;
|
||||
@@ -998,8 +998,8 @@ TABLE;
|
||||
|
||||
public function renderSetTitle()
|
||||
{
|
||||
return array(
|
||||
array(
|
||||
return [
|
||||
[
|
||||
'Books',
|
||||
'Page 1/2',
|
||||
'default',
|
||||
@@ -1014,8 +1014,8 @@ TABLE;
|
||||
+---------------+--------- Page 1/2 -------+------------------+
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
],
|
||||
[
|
||||
'Books',
|
||||
'Page 1/2',
|
||||
'box',
|
||||
@@ -1030,8 +1030,8 @@ TABLE
|
||||
└───────────────┴───────── Page 1/2 ───────┴──────────────────┘
|
||||
|
||||
TABLE
|
||||
),
|
||||
array(
|
||||
],
|
||||
[
|
||||
'Boooooooooooooooooooooooooooooooooooooooooooooooooooooooks',
|
||||
'Page 1/999999999999999999999999999999999999999999999999999',
|
||||
'default',
|
||||
@@ -1046,17 +1046,17 @@ TABLE
|
||||
+- Page 1/99999999999999999999999999999999999999999999999... -+
|
||||
|
||||
TABLE
|
||||
),
|
||||
);
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
public function testColumnMaxWidths()
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table
|
||||
->setRows(array(
|
||||
array('Divine Comedy', 'A Tale of Two Cities', 'The Lord of the Rings', 'And Then There Were None'),
|
||||
))
|
||||
->setRows([
|
||||
['Divine Comedy', 'A Tale of Two Cities', 'The Lord of the Rings', 'And Then There Were None'],
|
||||
])
|
||||
->setColumnMaxWidth(1, 5)
|
||||
->setColumnMaxWidth(2, 10)
|
||||
->setColumnMaxWidth(3, 15);
|
||||
@@ -1072,6 +1072,26 @@ TABLE
|
||||
| | ities | | |
|
||||
+---------------+-------+------------+-----------------+
|
||||
|
||||
TABLE;
|
||||
|
||||
$this->assertEquals($expected, $this->getOutputContent($output));
|
||||
}
|
||||
|
||||
public function testColumnMaxWidthsWithTrailingBackslash()
|
||||
{
|
||||
(new Table($output = $this->getOutputStream()))
|
||||
->setColumnMaxWidth(0, 5)
|
||||
->setRows([['1234\6']])
|
||||
->render()
|
||||
;
|
||||
|
||||
$expected =
|
||||
<<<'TABLE'
|
||||
+-------+
|
||||
| 1234\ |
|
||||
| 6 |
|
||||
+-------+
|
||||
|
||||
TABLE;
|
||||
|
||||
$this->assertEquals($expected, $this->getOutputContent($output));
|
||||
@@ -1089,12 +1109,12 @@ TABLE;
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
$table->setStyle($boxed);
|
||||
$table
|
||||
->setHeaders(array('ISBN', 'Title', 'Author'))
|
||||
->setRows(array(
|
||||
array('99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'),
|
||||
->setHeaders(['ISBN', 'Title', 'Author'])
|
||||
->setRows([
|
||||
['99921-58-10-7', 'Divine Comedy', 'Dante Alighieri'],
|
||||
new TableSeparator(),
|
||||
array(new TableCell('This value spans 3 columns.', array('colspan' => 3))),
|
||||
))
|
||||
[new TableCell('This value spans 3 columns.', ['colspan' => 3])],
|
||||
])
|
||||
;
|
||||
$table->render();
|
||||
|
||||
@@ -1124,4 +1144,56 @@ TABLE;
|
||||
|
||||
return str_replace(PHP_EOL, "\n", stream_get_contents($output->getStream()));
|
||||
}
|
||||
|
||||
public function testWithColspanAndMaxWith(): void
|
||||
{
|
||||
$table = new Table($output = $this->getOutputStream());
|
||||
|
||||
$table->setColumnMaxWidth(0, 15);
|
||||
$table->setColumnMaxWidth(1, 15);
|
||||
$table->setColumnMaxWidth(2, 15);
|
||||
$table->setRows([
|
||||
[new TableCell('Lorem ipsum dolor sit amet, <fg=white;bg=green>consectetur</> adipiscing elit, <fg=white;bg=red>sed</> do <fg=white;bg=red>eiusmod</> tempor', ['colspan' => 3])],
|
||||
new TableSeparator(),
|
||||
[new TableCell('Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor', ['colspan' => 3])],
|
||||
new TableSeparator(),
|
||||
[new TableCell('Lorem ipsum <fg=white;bg=red>dolor</> sit amet, consectetur ', ['colspan' => 2]), 'hello world'],
|
||||
new TableSeparator(),
|
||||
['hello <fg=white;bg=green>world</>', new TableCell('Lorem ipsum dolor sit amet, <fg=white;bg=green>consectetur</> adipiscing elit', ['colspan' => 2])],
|
||||
new TableSeparator(),
|
||||
['hello ', new TableCell('world', ['colspan' => 1]), 'Lorem ipsum dolor sit amet, consectetur'],
|
||||
new TableSeparator(),
|
||||
['Symfony ', new TableCell('Test', ['colspan' => 1]), 'Lorem <fg=white;bg=green>ipsum</> dolor sit amet, consectetur'],
|
||||
])
|
||||
;
|
||||
$table->render();
|
||||
|
||||
$expected =
|
||||
<<<TABLE
|
||||
+-----------------+-----------------+-----------------+
|
||||
| Lorem ipsum dolor sit amet, consectetur adipi |
|
||||
| scing elit, sed do eiusmod tempor |
|
||||
+-----------------+-----------------+-----------------+
|
||||
| Lorem ipsum dolor sit amet, consectetur adipi |
|
||||
| scing elit, sed do eiusmod tempor |
|
||||
+-----------------+-----------------+-----------------+
|
||||
| Lorem ipsum dolor sit amet, co | hello world |
|
||||
| nsectetur | |
|
||||
+-----------------+-----------------+-----------------+
|
||||
| hello world | Lorem ipsum dolor sit amet, co |
|
||||
| | nsectetur adipiscing elit |
|
||||
+-----------------+-----------------+-----------------+
|
||||
| hello | world | Lorem ipsum dol |
|
||||
| | | or sit amet, co |
|
||||
| | | nsectetur |
|
||||
+-----------------+-----------------+-----------------+
|
||||
| Symfony | Test | Lorem ipsum dol |
|
||||
| | | or sit amet, co |
|
||||
| | | nsectetur |
|
||||
+-----------------+-----------------+-----------------+
|
||||
|
||||
TABLE;
|
||||
|
||||
$this->assertSame($expected, $this->getOutputContent($output));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user