1

popen3在获得实时输出的同时从块内运行 rake 任务似乎是不可能的。所有行在 rake 任务结束时立即出现。popen3我正在尝试通过一个块从 rake 任务中获取实时输出

cmd = 'rake perform_a_task'
Open3::popen3(cmd) do |std_in, std_out, std_err|
  std_out.each_line do |line|
    puts line
  end
end

如何重现

概念证明:rake 任务

  1. 创建任务如下
task :print_and_wait do
  puts 'A'
  sleep 1
  puts 'B'
  sleep 1
  putc 'C'
end
  1. 从命令行调用任务

$ rake print_and_wait输出 3 行(A、B 和 C),中间停顿一秒。正如预期的那样

概念证明 2:popen3

  1. 创建一个shell脚本
$ cat print_and_wait
#!/bin/bash
echo 'A'
sleep 1
echo 'B'
sleep 1
echo 'C'
  1. 创建一个红宝石脚本
$ cat print_and_wait.rb
require 'open3'

def exec_async(cmd)
  Open3::popen3(cmd) do |std_in, std_out, std_err|
    std_out.each_line do |line|
      puts line
    end
  end
end

exec_async './print_and_wait'
  1. 运行红宝石脚本

$ ruby print_and_wait.rb按预期工作:输出 3 行,中间停顿一秒

它不起作用的地方

  • 编辑 ruby​​ 脚本 print_and_wait.rb 并更改exec_async './print_and_wait'exec_async 'rake print_and_wait'
  • $ ruby print_and_wait.rb
  • 没有输出,3 秒后所有 3 行同时打印

我尝试了几种组合,但始终无法使其按预期工作。知道为什么这不起作用吗?这是一个错误吗?

谢谢

4

1 回答 1

1

$stdout.sync = true在 rake 任务开始时添加解决了它。

于 2019-02-20T10:31:21.127 回答