2018-03-04 10:09:32 -05:00
|
|
|
require_relative '../../../spec_helper'
|
|
|
|
require_relative '../fixtures/common'
|
2017-05-07 08:04:49 -04:00
|
|
|
|
|
|
|
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
|
|
|
|
|
2019-09-29 13:13:37 -04:00
|
|
|
File.should.exist?(path)
|
2017-05-07 08:04:49 -04:00
|
|
|
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
|
2019-09-29 10:03:58 -04:00
|
|
|
-> {
|
|
|
|
Logger::LogDevice.new(STDERR, shift_age: 8, shift_size: 10)
|
|
|
|
}.should_not raise_error
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
end
|