我正在使用Open3的popen3启动在类似控制台中运行的进程的方法/REPL重复接受输入并返回输出的方式。我可以打开流程、发送输入并接收输出,代码如下:Open3.popen3("console_REPL_process")do|stdin,stdout,stderr,wait_thr|stdin.puts"astringofinput"stdin.close_writestdout.each_line{|line|putsline}#successfullyprintsalltheoutputend我想连续多次这样做,而不是重新打开进程,因为启动需要很长时间。我知道我必须关闭std
类似于Gettingoutputofsystem()callsinRuby,我正在运行一个系统命令,但在这种情况下,我需要在命令运行时从命令输出STDOUT。 最佳答案 在链接的问题中,答案还是完全不要使用system,因为system不支持这一点。但是这次解决方案不是使用反引号,而是IO.popen,它返回一个IO对象,您可以使用它来读取正在生成的输入。 关于ruby-如何在运行时获取rubysystem()调用的STDOUT?,我们在StackOverflow上找到一个类似的问题
有没有办法从Ruby程序中验证我是否拥有最新版本的gem?也就是说,有没有办法以编程方式执行bundleoutdated#{gemname}?我尝试查看bundler的源代码,但找不到直接的方法。目前我正在做这个,它很脆弱,很慢而且很不优雅:IO.popen(%w{/usr/bin/envbundleoutdatedgemname})do|proc|output=proc.readlines.join("\n")returnoutput.include?("Yourbundleisuptodate!")end 最佳答案 避免外部执行
我一直在使用Thin来运行我的rubySinatra应用程序,但我现在切换到Puma。Thin创建了我自己使用的日志log/thin.log。我注意到Puma没有生成日志文件(我看不到)。我已经尝试用谷歌搜索有关此的文档,但没有真正找到任何东西。我想知道您是否/如何在Puma中指定日志路径。如有任何帮助,我们将不胜感激。亚历克斯 最佳答案 检查示例config.rb按照repo协议(protocol)的建议README.如图所示:#RedirectSTDOUTandSTDERRtofilesspecified.The3rdpar
我的Ruby程序从stdin读取行并使用puts打印到stdout(终端)。我可以使用RSpec来测试读写吗?我可以像在stdin中编写的那样向我的程序注入(inject)一个字符串,同时检查输出吗?line=STDIN.read.chomp.split另外,我在一个循环中进行读取和写入,直到line[0]被“退出”。我可以在循环运行时进行测试,还是应该调用subject.read_in和subject.write_out? 最佳答案 您可以使用模拟并通过在and_return()方法中列出多个值来多次调用该方法。这些将按照给定的顺
我正在尝试将标准输出复制到一个文件以用于日志记录。我还希望它显示在我正在使用的IDE的Ruby控制台中。我将这段代码插入到我的脚本中,它将$stdout重定向到my.log文件:$stdout.reopen("my.log","w")有没有人知道将$stdout的内容复制到文件而不是将其重定向到文件的gem或技术?另外,我不使用Rails,只使用Ruby。 最佳答案 这样的事情可能对你有帮助:classTeeIOIO中大部分做输出的方法最终都是使用write,所以你只需要重写这一个方法即可。你可以像这样使用它:#setuptee=T
如何立即输出stdout?stdout将在所有输入完成后打印。require'open3'defrun(cmd)Open3.popen3(cmd)do|stdin,stdout,stderr,thread|Thread.newdostdout.each{|l|putsl}endThread.newdowhilethread.alive?stdin.puts$stdin.getsendendthread.joinendendrun("rubyfile_to_test.rb")file_to_test.rb:puts"please,enters"puts"please,enterq"s=g
我在使用popen3时遇到意外行为,我想用它来运行类似工具alacmdfile2的命令.下面的示例挂起,因此stdoutdone永远不会达到。使用cat以外的其他工具可能会导致挂起,所以stdindone永远不会达到。我怀疑,我正在遭受缓冲,但我该如何解决这个问题?#!/usr/bin/envrubyrequire'open3'Open3.popen3("cat")do|stdin,stdout,stderr,wait_thr|stdin.puts"foobar"puts"stdindone"stdout.each_line{|line|putsline}puts"stdoutdone
我正在使用daemonsgem在Ruby中创建一个守护进程。我想将守护进程的输出添加到日志文件中。我想知道将puts从控制台重定向到日志文件的最简单方法是什么。 最佳答案 如果您需要同时捕获STDERR和STDOUT并且不想求助于日志记录:$stdout.reopen("my.log","w")$stdout.sync=true$stderr.reopen($stdout)恢复:$stdout=STDOUT 关于ruby-将"puts"命令输出重定向到日志文件,我们在StackOverf
我正在编写如下一些单元测试:defexecuting_a_signala_method(a_signal.new,a_model,a_helper);assert_equal(new_state,a_model.state)end测试工作正常,但是在执行逻辑的断言之前运行的方法主要通过puts将各种消息打印到控制台。是否有一种快速的(也许是内置的)方法来抑制向控制台的输出?我只对方法对模型对象的最终效果感兴趣,并且为了基本上保持控制台干净,我希望找到一种方法来简单地阻止所有输出到控制台而无需重写或注释掉那些puts语句仅用于我的测试。这绝对不是一个关键问题,但非常希望听到关于它的任何想