Skip to content

Commit

Permalink
Fix multiSelect ChoiceQuestion when answers have spaces
Browse files Browse the repository at this point in the history
  • Loading branch information
IceMaD authored and Robin Chalas committed Jul 24, 2019
1 parent c26324c commit 12940f2
Show file tree
Hide file tree
Showing 2 changed files with 68 additions and 6 deletions.
10 changes: 4 additions & 6 deletions Question/ChoiceQuestion.php
Original file line number Diff line number Diff line change
Expand Up @@ -134,17 +134,15 @@ private function getDefaultValidator()
$isAssoc = $this->isAssoc($choices);

return function ($selected) use ($choices, $errorMessage, $multiselect, $isAssoc) {
// Collapse all spaces.
$selectedChoices = str_replace(' ', '', $selected);

if ($multiselect) {
// Check for a separated comma values
if (!preg_match('/^[^,]+(?:,[^,]+)*$/', $selectedChoices, $matches)) {
if (!preg_match('/^[^,]+(?:,[^,]+)*$/', $selected, $matches)) {
throw new InvalidArgumentException(sprintf($errorMessage, $selected));
}
$selectedChoices = explode(',', $selectedChoices);

$selectedChoices = array_map('trim', explode(',', $selected));
} else {
$selectedChoices = [$selected];
$selectedChoices = [trim($selected)];
}

$multiselectChoices = [];
Expand Down
64 changes: 64 additions & 0 deletions Tests/Question/ChoiceQuestionTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
<?php

/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <[email protected]>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

namespace Symfony\Component\Console\Tests\Question;

use PHPUnit\Framework\TestCase;
use Symfony\Component\Console\Question\ChoiceQuestion;

class ChoiceQuestionTest extends TestCase
{
/**
* @dataProvider selectUseCases
*/
public function testSelectUseCases($multiSelect, $answers, $expected, $message)
{
$question = new ChoiceQuestion('A question', [
'First response',
'Second response',
'Third response',
'Fourth response',
]);

$question->setMultiselect($multiSelect);

foreach ($answers as $answer) {
$validator = $question->getValidator();
$actual = $validator($answer);

$this->assertEquals($actual, $expected, $message);
}
}

public function selectUseCases()
{
return [
[
false,
['First response', 'First response ', ' First response', ' First response '],
'First response',
'When passed single answer on singleSelect, the defaultValidator must return this answer as a string',
],
[
true,
['First response', 'First response ', ' First response', ' First response '],
['First response'],
'When passed single answer on MultiSelect, the defaultValidator must return this answer as an array',
],
[
true,
['First response,Second response', ' First response , Second response '],
['First response', 'Second response'],
'When passed multiple answers on MultiSelect, the defaultValidator must return these answers as an array',
],
];
}
}

0 comments on commit 12940f2

Please sign in to comment.