问题的助手

编辑该页面

警告:你浏览的文档欧宝官网下载appob娱乐下载Symfony 3.2,不再维护。

这个页面的更新版本Symfob娱乐下载ony 6.2(当前的稳定版本)。

问题的助手

QuestionHelper提供功能要求用户的更多信息。它包含在默认辅助设置,您可以通过调用getHelperSet ():

1
美元助手=美元- >getHelper (“问题”);

助手,只有一个方法的问题问()这需要一个InputInterface实例作为第一个参数,一个OutputInterface第二个参数和实例问题作为最后一个参数。

要求用户确认

假设你想确认操作之前执行它。添加以下命令:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
/ /……使用ob娱乐下载\组件\控制台\输入\InputInterface;使用ob娱乐下载\组件\控制台\输出\OutputInterface;使用ob娱乐下载\组件\控制台\问题\ConfirmationQuestion;YourCommand扩展命令{/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){美元助手=美元- >getHelper (“问题”);美元问题=ConfirmationQuestion (“继续这个动作吗?”,);如果(!美元助手- >问(美元输入,美元输出,美元问题)){返回;}}}

在这种情况下,用户将被要求继续这个行动?。如果用户的答案y它返回真正的如果他们回答n。第二个参数__construct ()是返回的默认值,如果用户没有输入任何有效的输入。如果第二个参数是不提供的,真正的假定。

提示

您可以自定义正则表达式用来检查如果答案是“是”的第三个参数的构造函数。例如,允许任何开始yj,你会将它设置为:

1 2 3 4 5
美元问题=ConfirmationQuestion (“继续这个动作吗?”,,' / ^ (y | j) /我);

正则表达式默认为/ ^ y /我

要求用户信息

你也可以问一个问题,超过一个简单的是或否的答案。例如,如果你想知道一个包的名字,你可以将它添加到你的命令:

1 2 3 4 5 6 7 8 9 10
使用ob娱乐下载\组件\控制台\问题\问题;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元问题=问题(“请输入包名称”,“AcmeDemoBundle”);美元=美元助手- >问(美元输入,美元输出,美元问题);}

用户将被要求“请输入包名称”。他们可以将返回的输入一些名字问()方法。如果他们把它空,默认值(AcmeDemoBundle返回)。

让用户从列表中选择的答案

如果你有一组预定义的回答用户可以选择,你可以使用ChoiceQuestion确保用户只能输入一个有效的字符串从预定义列表:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
使用ob娱乐下载\组件\控制台\问题\ChoiceQuestion;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元助手=美元- >getHelper (“问题”);美元问题=ChoiceQuestion (“请选择你最喜欢的颜色(默认为红色),数组(“红色”,“蓝”,“黄色”),0);美元问题- >setErrorMessage (颜色%年代是无效的。);美元颜色=美元助手- >问(美元输入,美元输出,美元问题);美元输出- >writeln (你只有选择:美元颜色);/ /……做一些颜色吗}

应该是默认选中的选项提供的第三个参数的构造函数。默认值是,这意味着没有选项是默认的。

如果用户输入一个无效的字符串,显示一个错误消息和用户要求提供答案还有一次,直到他们输入有效的字符串或达到的最大数量。尝试的最大数量的默认值,这意味着无数的尝试。你可以定义自己的错误消息setErrorMessage ()

多个选择

有时候,可以将多个答案。的ChoiceQuestion使用逗号分隔值提供了这个功能。这是禁用默认情况下,启用此用setMultiselect ():

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
使用ob娱乐下载\组件\控制台\问题\ChoiceQuestion;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元助手=美元- >getHelper (“问题”);美元问题=ChoiceQuestion (“请选择你喜欢的颜色(默认为红色和蓝色),数组(“红色”,“蓝”,“黄色”),“0 1”);美元问题- >setMultiselect (真正的);美元颜色=美元助手- >问(美元输入,美元输出,美元问题);美元输出- >writeln (你只有选择:。内爆(”、“,美元颜色));}

现在,当用户输入1、2结果将是:你刚刚选择:蓝色、黄色

如果用户不输入任何东西,结果将是:你刚刚选择:红、蓝

自动完成

您还可以指定数组的潜在回答了对于一个给定的问题。这些将自动完成用户类型:

1 2 3 4 5 6 7 8 9 10 11 12
使用ob娱乐下载\组件\控制台\问题\问题;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元=数组(“AcmeDemoBundle”,“AcmeBlogBundle”,“AcmeStoreBundle”);美元问题=问题(“请输入一个包的名字”,“FooBundle”);美元问题- >setAutocompleterValues (美元);美元的名字=美元助手- >问(美元输入,美元输出,美元问题);}

隐藏用户的响应

你也可以问一个问题和隐藏的响应。这是特别方便的密码:

1 2 3 4 5 6 7 8 9 10 11 12
使用ob娱乐下载\组件\控制台\问题\问题;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元问题=问题(“什么是数据库密码?”);美元问题- >setHidden (真正的);美元问题- >setHiddenFallback ();美元密码=美元助手- >问(美元输入,美元输出,美元问题);}

谨慎

当你问一个隐藏的回应,Symfony会使用二进制,改变stty模式或使用ob娱乐下载另一个隐藏的响应。如果没有,它将回退和允许的响应是可见的,除非你设置这个行为使用setHiddenFallback ()就像在上面的例子中。在这种情况下,RuntimeException会抛出。

正常化的答案

验证答案之前,你可以修复“正常化”小错误或根据需要调整它。例如,在前面的例子你要包名称。以防误周围的用户添加空白的名字,你可以修剪在验证之前的名字。为此,配置标准化者使用setNormalizer ()方法:

1 2 3 4 5 6 7 8 9 10 11 12 13 14
使用ob娱乐下载\组件\控制台\问题\问题;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元问题=问题(“请输入包名称”,“AppBundle”);美元问题- >setNormalizer (函数(美元价值){/ /美元值可以为空返回美元价值吗?削减(美元价值):;});美元的名字=美元助手- >问(美元输入,美元输出,美元问题);}

谨慎

标准化者称为第一和返回的值用作输入验证器。如果答案是无效的,不抛出异常的标准化者,让验证器处理这些错误。

验证答案

你甚至可以验证答案。例如,在前面的例子你要包名称。Symfony的命名约定后,ob娱乐下载应该后缀为。你可以验证通过setValidator ()方法:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
使用ob娱乐下载\组件\控制台\问题\问题;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元问题=问题(“请输入包名称”,“AcmeDemoBundle”);美元问题- >setValidator (函数(美元回答){如果(! is_string (美元回答)| |“包”! = = substr (美元回答,6)){\ RuntimeException (的包的名称应该后缀为\ '包\”);}返回美元回答;});美元问题- >setMaxAttempts (2);美元的名字=美元助手- >问(美元输入,美元输出,美元问题);}

美元的验证器是一个回调处理验证。它应该抛出一个异常是否有错了。异常消息显示在控制台中,所以这是一个很好的实践,把一些有用的信息。回调函数也应该返回用户输入的值如果验证成功。

你可以设置的最大次数要求setMaxAttempts ()方法。如果你达到这个最大数量它将使用默认值。使用意味着尝试的数量是无限的。用户将被要求,只要他们提供了一个无效的答案,只能继续如果他们的输入是有效的。

验证一个隐藏的响应

您还可以使用一个验证器和一个隐藏的问题:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
使用ob娱乐下载\组件\控制台\问题\问题;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元助手=美元- >getHelper (“问题”);美元问题=问题(“请输入密码”);美元问题- >setValidator (函数(美元价值){如果(修剪(美元价值)= =){\异常(密码不能是空的);}返回美元价值;});美元问题- >setHidden (真正的);美元问题- >setMaxAttempts (20.);美元密码=美元助手- >问(美元输入,美元输出,美元问题);}

预计输入测试命令

如果你想编写一个单元测试的命令预计从命令行输入,您需要设置输入命令预计:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21日22日23日24日25
使用ob娱乐下载\组件\控制台\助手\QuestionHelper;使用ob娱乐下载\组件\控制台\助手\HelperSet;使用ob娱乐下载\组件\控制台\测试人员\CommandTester;/ /……公共函数testExecute(){/ /……美元commandTester=CommandTester (美元命令);/ /等于用户输入“测试”和输入美元commandTester- >setInputs (数组(“测试”));/ / =用户输入“这”、“那”和输入/ /这可以用于回答两个分离的问题美元commandTester- >setInputs (数组(“这”,“,”));/ /模拟一个肯定的答复确认问题,添加一个/ /额外的输入说“是的”美元commandTester- >setInputs (数组(“是的”));美元commandTester- >执行(数组(“命令”= >美元命令- >getName ()));/ / $ this - > assertRegExp (' /…/ ',$ commandTester - > getDisplay ());}

3.2

CommandTester: setInputs ()方法是在Symfony 3.2中引入的。ob娱乐下载

通过调用setInputs (),你模仿控制台内部与所有用户输入CLI。这个方法只以数组为参数,对每个输入命令预计,代表用户会输入字符串。这样你可以测试任何用户交互(即使是复杂的)通过适当的输入。

请注意

CommandTester自动模拟用户打输入每个输入后,不需要通过一个额外的输入。

这项工作,包括代码示例,许可下Creative Commons冲锋队3.0许可证。