1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/spec/ruby/library/logger/device/new_spec.rb
eregon 401b64c4e8 Update to ruby/spec@c1b568b
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@62656 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2018-03-04 15:09:32 +00:00

47 lines
1.2 KiB
Ruby

require_relative '../../../spec_helper'
require_relative '../fixtures/common'
describe "Logger::LogDevice#new" do
before :each do
@file_path = tmp("test_log.log")
@log_file = File.open(@file_path, "w+")
end
after :each do
@log_file.close unless @log_file.closed?
rm_r @file_path
end
it "creates a new log device" do
l = Logger::LogDevice.new(@log_file)
l.dev.should be_kind_of(File)
end
it "receives an IO object to log there as first argument" do
@log_file.should be_kind_of(IO)
l = Logger::LogDevice.new(@log_file)
l.write("foo")
@log_file.rewind
@log_file.readlines.first.should == "foo"
end
it "creates a File if the IO object does not exist" do
path = tmp("test_logger_file")
l = Logger::LogDevice.new(path)
l.write("Test message")
l.close
File.exist?(path).should be_true
File.open(path) do |f|
f.readlines.should_not be_empty
end
rm_r path
end
it "receives options via a hash as second argument" do
lambda { Logger::LogDevice.new(STDERR,
{ shift_age: 8, shift_size: 10
})}.should_not raise_error
end
end