1

当您自己的测试套件执行完毕后,会有一些结果。我想将这些信息保存在 txt 文件或 html 中,但我不知道如何保存那些输出的消息,如果有人知道,请与我分享,提前感谢以下代码是我的实验,但它不起作用.

require File.join(File.dirname(__FILE__),  'person')
require "test/unit"

filename = "logfile.txt"
$logfile = File.new(filename,"a")
open(logfile,'a') { |f| f << $stdout}

class PersonTest < Test::Unit::TestCase

  FIRST_NAME, LAST_NAME, AGE = 'Nathaniel', 'Taldtretbott', 25

  def setup
    @person = Person.new(FIRST_NAME, LAST_NAME, AGE)
  end

  def test_first_name
    assert_equal "asv", @person.first_name,"try to compare"
  end

  def test_last_name
    assert_equal "Taldtretbott", @person.last_name
  end

  def test_full_name
    assert_equal FIRST_NAME + ' ' + LAST_NAME, @person.full_name
  end
end
4

3 回答 3

1

我有一些时间尝试对解决方案进行一些测试。我设法让它以这种方式工作:

require 'test/unit'

STDOUT = $stdout = File.open("stdout.txt", "a+")
STDERR = $stderr = File.open("stderr.txt", "a+")

class AreasTest < Test::Unit::TestCase
  def test_ok
    puts "#{Time.now} Hello "
    a = 10
    assert_equal(a, 10)
  end


  def test_fail
    a = 9
    assert_equal(a, 10)
  end
end

它给出了一个警告,因为 STDOUT 和 STDERR 已经初始化,但只是重定向 $stdout 和 $stderr 不起作用(仅适用于正常的 put)。

我希望它有所帮助。

于 2011-04-01T08:48:01.993 回答
1

为什么不做

ruby testfile.rb > text_output.txt
于 2011-03-30T22:23:21.690 回答
0

尝试:

$stdout = $logfile

代替:

open(logfile,'a') { |f| f << $stdout}

这意味着您正在将标准输出重定向到文件。

于 2011-03-30T15:20:15.343 回答