2018-03-04 10:09:32 -05:00
|
|
|
require_relative '../../spec_helper'
|
|
|
|
require_relative 'fixtures/classes'
|
2017-05-07 08:04:49 -04:00
|
|
|
|
|
|
|
describe "Kernel#warn" do
|
|
|
|
before :each do
|
|
|
|
@before_verbose = $VERBOSE
|
|
|
|
@before_separator = $/
|
|
|
|
end
|
|
|
|
|
|
|
|
after :each do
|
2020-01-20 18:37:44 -05:00
|
|
|
$VERBOSE = nil
|
2017-05-07 08:04:49 -04:00
|
|
|
$/ = @before_separator
|
2020-01-20 18:37:44 -05:00
|
|
|
$VERBOSE = @before_verbose
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "is a private method" do
|
|
|
|
Kernel.should have_private_instance_method(:warn)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "requires multiple arguments" do
|
|
|
|
Kernel.method(:warn).arity.should < 0
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not append line-end if last character is line-end" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2017-05-07 08:04:49 -04:00
|
|
|
$VERBOSE = true
|
|
|
|
warn("this is some simple text with line-end\n")
|
|
|
|
}.should output(nil, "this is some simple text with line-end\n")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "calls #write on $stderr if $VERBOSE is true" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2017-05-07 08:04:49 -04:00
|
|
|
$VERBOSE = true
|
|
|
|
warn("this is some simple text")
|
|
|
|
}.should output(nil, "this is some simple text\n")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "calls #write on $stderr if $VERBOSE is false" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2017-05-07 08:04:49 -04:00
|
|
|
$VERBOSE = false
|
|
|
|
warn("this is some simple text")
|
|
|
|
}.should output(nil, "this is some simple text\n")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not call #write on $stderr if $VERBOSE is nil" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2017-05-07 08:04:49 -04:00
|
|
|
$VERBOSE = nil
|
|
|
|
warn("this is some simple text")
|
|
|
|
}.should output(nil, "")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "writes each argument on a line when passed multiple arguments" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2017-05-07 08:04:49 -04:00
|
|
|
$VERBOSE = true
|
|
|
|
warn("line 1", "line 2")
|
|
|
|
}.should output(nil, "line 1\nline 2\n")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "writes each array element on a line when passes an array" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2017-05-07 08:04:49 -04:00
|
|
|
$VERBOSE = true
|
|
|
|
warn(["line 1", "line 2"])
|
|
|
|
}.should output(nil, "line 1\nline 2\n")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not write strings when passed no arguments" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2017-05-07 08:04:49 -04:00
|
|
|
$VERBOSE = true
|
|
|
|
warn
|
|
|
|
}.should output("", "")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "writes the default record separator and NOT $/ to $stderr after the warning message" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2017-05-07 08:04:49 -04:00
|
|
|
$VERBOSE = true
|
|
|
|
$/ = 'rs'
|
|
|
|
warn("")
|
|
|
|
}.should output(nil, /\n/)
|
|
|
|
end
|
2018-06-13 17:41:45 -04:00
|
|
|
|
2019-02-21 10:38:59 -05:00
|
|
|
it "writes to_s representation if passed a non-string" do
|
|
|
|
obj = mock("obj")
|
|
|
|
obj.should_receive(:to_s).and_return("to_s called")
|
2019-07-27 06:40:09 -04:00
|
|
|
-> {
|
2019-02-21 10:38:59 -05:00
|
|
|
$VERBOSE = true
|
|
|
|
warn(obj)
|
|
|
|
}.should output(nil, "to_s called\n")
|
|
|
|
end
|
|
|
|
|
2020-02-08 05:43:27 -05:00
|
|
|
describe ":uplevel keyword argument" do
|
|
|
|
before :each do
|
|
|
|
$VERBOSE = true
|
|
|
|
end
|
|
|
|
|
|
|
|
it "prepends a message with specified line from the backtrace" do
|
|
|
|
w = KernelSpecs::WarnInNestedCall.new
|
|
|
|
|
|
|
|
-> { w.f4("foo", 0) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.warn_call_lineno}: warning: foo|)
|
|
|
|
-> { w.f4("foo", 1) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.f1_call_lineno}: warning: foo|)
|
|
|
|
-> { w.f4("foo", 2) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.f2_call_lineno}: warning: foo|)
|
|
|
|
-> { w.f4("foo", 3) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.f3_call_lineno}: warning: foo|)
|
2018-06-13 17:41:45 -04:00
|
|
|
end
|
2019-09-29 12:01:32 -04:00
|
|
|
|
2020-02-08 05:43:27 -05:00
|
|
|
it "converts first arg using to_s" do
|
|
|
|
w = KernelSpecs::WarnInNestedCall.new
|
|
|
|
|
|
|
|
-> { w.f4(false, 0) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.warn_call_lineno}: warning: false|)
|
|
|
|
-> { w.f4(nil, 1) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.f1_call_lineno}: warning: |)
|
|
|
|
obj = mock("obj")
|
|
|
|
obj.should_receive(:to_s).and_return("to_s called")
|
|
|
|
-> { w.f4(obj, 2) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.f2_call_lineno}: warning: to_s called|)
|
2019-09-29 12:01:32 -04:00
|
|
|
end
|
2020-02-08 05:43:27 -05:00
|
|
|
|
|
|
|
it "does not prepend caller information if the uplevel argument is too large" do
|
|
|
|
w = KernelSpecs::WarnInNestedCall.new
|
|
|
|
-> { w.f4("foo", 100) }.should output(nil, "warning: foo\n")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "prepends even if a message is empty or nil" do
|
|
|
|
w = KernelSpecs::WarnInNestedCall.new
|
|
|
|
|
|
|
|
-> { w.f4("", 0) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.warn_call_lineno}: warning: \n$|)
|
|
|
|
-> { w.f4(nil, 0) }.should output(nil, %r|core/kernel/fixtures/classes.rb:#{w.warn_call_lineno}: warning: \n$|)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "converts value to Integer" do
|
|
|
|
w = KernelSpecs::WarnInNestedCall.new
|
|
|
|
|
|
|
|
-> { w.f4(0.1) }.should output(nil, %r|classes.rb:#{w.warn_call_lineno}:|)
|
|
|
|
-> { w.f4(Rational(1, 2)) }.should output(nil, %r|classes.rb:#{w.warn_call_lineno}:|)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises ArgumentError if passed negative value" do
|
|
|
|
-> { warn "", uplevel: -2 }.should raise_error(ArgumentError)
|
|
|
|
-> { warn "", uplevel: -100 }.should raise_error(ArgumentError)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises ArgumentError if passed -1" do
|
|
|
|
-> { warn "", uplevel: -1 }.should raise_error(ArgumentError)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises TypeError if passed not Integer" do
|
|
|
|
-> { warn "", uplevel: "" }.should raise_error(TypeError)
|
|
|
|
-> { warn "", uplevel: [] }.should raise_error(TypeError)
|
|
|
|
-> { warn "", uplevel: {} }.should raise_error(TypeError)
|
|
|
|
-> { warn "", uplevel: Object.new }.should raise_error(TypeError)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "treats empty hash as no keyword argument" do
|
|
|
|
h = {}
|
|
|
|
-> { warn(**h) }.should_not complain(verbose: true)
|
|
|
|
-> { warn('foo', **h) }.should complain("foo\n")
|
2018-06-13 17:41:45 -04:00
|
|
|
end
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|