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/syslog/open_spec.rb
eregon 1d15d5f080 Move spec/rubyspec to spec/ruby for consistency
* Other ruby implementations use the spec/ruby directory.
  [Misc #13792] [ruby-core:82287]

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59979 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2017-09-20 20:18:52 +00:00

86 lines
2.2 KiB
Ruby

platform_is_not :windows do
require File.expand_path('../../../spec_helper', __FILE__)
require File.expand_path('../shared/reopen', __FILE__)
require 'syslog'
describe "Syslog.open" do
platform_is_not :windows do
before :each do
Syslog.opened?.should be_false
end
after :each do
Syslog.opened?.should be_false
end
it "returns the module" do
Syslog.open.should == Syslog
Syslog.close
Syslog.open("Test", 5, 9).should == Syslog
Syslog.close
end
it "receives an identity as first argument" do
Syslog.open("rubyspec")
Syslog.ident.should == "rubyspec"
Syslog.close
end
it "defaults the identity to $0" do
Syslog.open
Syslog.ident.should == $0
Syslog.close
end
it "receives the logging options as second argument" do
Syslog.open("rubyspec", Syslog::LOG_PID)
Syslog.options.should == Syslog::LOG_PID
Syslog.close
end
it "defaults the logging options to LOG_PID | LOG_CONS" do
Syslog.open
Syslog.options.should == Syslog::LOG_PID | Syslog::LOG_CONS
Syslog.close
end
it "receives a facility as third argument" do
Syslog.open("rubyspec", Syslog::LOG_PID, 0)
Syslog.facility.should == 0
Syslog.close
end
it "defaults the facility to LOG_USER" do
Syslog.open
Syslog.facility.should == Syslog::LOG_USER
Syslog.close
end
it "receives a block and calls it with the module" do
Syslog.open("rubyspec", 3, 8) do |s|
s.should == Syslog
s.ident.should == "rubyspec"
s.options.should == 3
s.facility.should == Syslog::LOG_USER
end
end
it "closes the log if after it receives a block" do
Syslog.open{ }
Syslog.opened?.should be_false
end
it "raises an error if the log is opened" do
Syslog.open
lambda { Syslog.open}.should raise_error
lambda { Syslog.close; Syslog.open }.should_not raise_error
Syslog.close
end
end
end
describe "Syslog.open!" do
it_behaves_like :syslog_reopen, :open!
end
end