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

しない理由

ruby testfile.rb > text_output.txt
于 2011-03-30T22:23:21.690 に答える
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 に答える
0

試す:

$stdout = $logfile

それ以外の:

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

これは、stdoutをファイルにリダイレクトしていることを意味します。

于 2011-03-30T15:20:15.343 に答える