3

我想捕获 rubocop 攻击的总数,以确定我的代码库是变好还是变坏。我几乎没有 ruby​​ 脚本的经验。

到目前为止,这是我的脚本:

#!/usr/bin/env ruby
#script/code_coverage

var = `rubocop ../ -f fuubar -o ../coverage/rubocop_results.txt -f offenses`
puts var

所以我./rails-app/script/code_coverage和我的终端显示

...
--
6844  Total

当我var.inspect得到一个长字符串时。我想rubocop ../ -f ...逐行读取输出(首选)或将每一行输出捕获到一个数组中。

我希望能够做这样的事情:

var.each |line| do
  if line.contains('total')
    ...
    total = ...
end

这可能吗?我想这类似于将输出写入文件然后逐行读取文件。

4

2 回答 2

5

If you want to keep it simple, you can simply split your var string.

var = `rubocop ../ -f fuubar -o ../coverage/rubocop_results.txt -f offenses`.split("\n")

Then you can iterate on var like you wanted to.

于 2014-05-03T00:10:03.373 回答
2

使用 ruby​​ 的 open3 库。Open3 允许您访问标准输入、标准输出、标准错误和一个线程以在运行另一个程序时等待子进程。您可以将程序的各种属性、重定向、当前目录等指定为 Process.spawn。

http://blog.bigbinary.com/2012/10/18/backtick-system-exec-in-ruby.html

require 'open3'


# Run lynx on this file.
cmd = "lynx -crawl -dump /data/feed/#{file_name}.html  > /data/feed/#{file_name}"
Open3.popen3(cmd) do |stdin, stdout, stderr, wait_thr|
   cmdout = stdout.read
   $logger.debug "stdout is:" + stdout.read
   $logger.debug "stderr is:" + stderr.read
end
于 2014-05-02T23:41:56.160 回答