问题的助手

编辑该页面

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

这个页面的更新版本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 /我

2.7

正则表达式参数是在Symfony 2.7中引入的。ob娱乐下载开始之前,只有答案y被认为是“是的”。

要求用户信息

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

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

用户将被要求“请输入包名称”。他们可以将返回的输入一些名字问()方法。如果他们把它空,默认值(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 13 14
使用ob娱乐下载\组件\控制台\问题\问题;/ /……公共函数执行(InputInterface美元输入,OutputInterface美元输出){/ /……美元助手=美元- >getHelper (“问题”);美元=数组(“AcmeDemoBundle”,“AcmeBlogBundle”,“AcmeStoreBundle”);美元问题=问题(“请输入一个包的名字”,“FooBundle”);美元问题- >setAutocompleterValues (美元);美元bundleName=美元助手- >问(美元输入,美元输出,美元问题);}

隐藏用户的响应

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

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

谨慎

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

正常化的答案

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

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

谨慎

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

验证答案

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

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

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

你可以设置的最大次数要求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日26日27日28
使用ob娱乐下载\组件\控制台\助手\QuestionHelper;使用ob娱乐下载\组件\控制台\助手\HelperSet;使用ob娱乐下载\组件\控制台\测试人员\CommandTester;/ /……公共函数testExecute(){/ /……美元commandTester=CommandTester (美元命令);美元助手=美元命令- >getHelper (“问题”);美元助手- >setInputStream (美元- >getInputStream (“测试\ n”));/ /等于用户输入“测试”和输入/ /如果你需要输入一个确认,“是的\ n”工作美元commandTester- >执行(数组(“命令”= >美元命令- >getName ()));/ / $ this - > assertRegExp (' /…/ ',$ commandTester - > getDisplay ());}受保护的函数getInputStream(美元输入){美元= fopen (“php: / /记忆”,' r + ',);fputs (美元,美元输入);倒带(美元);返回美元;}

通过设置的输入流QuestionHelper,你模仿控制台内部与所有用户输入CLI。这样你可以测试任何用户交互(即使是复杂的)通过一个适当的输入流。

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